:root{--primary: #4f46e5;--primary-hover: #4338ca;--danger: #dc2626;--danger-hover: #b91c1c;--text-main: #1e293b;--text-muted: #64748b;--panel-bg: #ffffff;--border-color: #e2e8f0;--grid-border: #e2e8f0;--row-even: #ffffff;--row-odd: #f8fafc;--day-header-bg: #f1f5f9;--btn-bg: #f8fafc;--btn-border: #e2e8f0}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:var(--text-main);background:#f1f5f9;min-height:100vh;display:flex;flex-direction:column}#app-header{display:flex;align-items:center;justify-content:space-between;background:var(--panel-bg);border-bottom:1px solid var(--border-color);padding:.5rem 1rem;gap:.75rem;position:sticky;top:0;z-index:100;box-shadow:0 1px 3px #0000000f}.header-left,.header-right{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.app-title{font-weight:700;font-size:1rem;color:var(--primary);margin-right:.25rem}.status-badge{font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:999px}.status-offline{background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}.status-sync{background:#eff6ff;color:#1d4ed8;border:1px solid #bfdbfe}.btn-auth{font-size:.8rem;padding:.3rem .75rem}#app-body{display:flex;flex:1;gap:1rem;padding:1rem;align-items:flex-start;min-height:0}.main{flex:3;min-width:0;display:flex;flex-direction:column;gap:.75rem}.side{flex:1;min-width:240px;max-width:320px;display:flex;flex-direction:column;gap:.75rem;position:sticky;top:56px;max-height:calc(100vh - 56px);overflow-y:auto}.space-container{border:1px solid var(--border-color);border-radius:12px;padding:1rem;background:var(--panel-bg);box-shadow:0 1px 2px #00000008}.space-title{font-weight:600;font-size:1rem;margin-bottom:.75rem;border-bottom:2px solid var(--border-color);padding-bottom:.4rem}details.space-container>summary.space-title{cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}details.space-container>summary.space-title:before{content:"▸ ";font-size:.75rem}details.space-container[open]>summary.space-title:before{content:"▾ "}.header-divider{width:1px;height:24px;background-color:var(--border-color);margin:0 .5rem}.header-controls{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem;font-size:.85rem}.header-controls label{display:flex;align-items:center;gap:.35rem;font-weight:500}.schedule-grid{display:grid;grid-template-columns:75px repeat(5,1fr);grid-auto-rows:32px;position:relative;border-top:1px solid var(--grid-border);border-left:1px solid var(--grid-border);border-radius:4px;overflow:hidden}.time-cell,.day-header,.drop-zone{border-right:1px solid var(--grid-border);border-bottom:1px solid var(--grid-border);font-size:.75rem;display:flex;align-items:center;justify-content:center}.day-header{font-weight:600;background:var(--day-header-bg);position:sticky;top:0;z-index:1;padding:.5rem 0}.time-cell{color:#64748b;font-weight:500}.time-cell.even-row,.drop-zone.even-row{background:var(--row-even)}.time-cell.odd-row,.drop-zone.odd-row{background:var(--row-odd)}.drop-zone{position:relative;transition:background .15s ease}.drop-zone.drag-over{background:#fdf4ff!important;outline:2px dashed #d946ef;outline-offset:-2px}body.dragging-active .session{pointer-events:none}.session{position:absolute;border-radius:6px;padding:2px 4px;font-size:.7rem;color:#111;box-sizing:border-box;cursor:grab;border:1px solid rgba(0,0,0,.15);display:flex;flex-direction:column;justify-content:flex-start;user-select:none;-webkit-user-select:none;z-index:10;box-shadow:0 1px 3px #0000001a;transition:transform .1s ease,box-shadow .1s ease;overflow:hidden}.session:hover{transform:translateY(-1px);box-shadow:0 3px 6px #00000026;z-index:15}.session:active{cursor:grabbing;transform:scale(.98);box-shadow:0 1px 2px #0000001a}.session.selected{box-shadow:0 0 0 2px #1e293b inset,0 4px 8px #0003;z-index:20}.session.has-notes:before{content:"";position:absolute;top:4px;left:4px;width:8px;height:8px;background-color:var(--danger);border-radius:50%;box-shadow:0 0 0 1px #fffc;z-index:5}.session.conflict{border:2px solid #b71c1c;box-shadow:0 0 0 2px #b71c1c inset,0 0 0 3px #b71c1c66;z-index:20}.session.shadow{background:repeating-linear-gradient(45deg,#e0e0e0,#e0e0e0 10px,#d6d6d6 10px,#d6d6d6 20px)!important;opacity:.5;pointer-events:none;z-index:5;border:1px dashed #999;color:#555;box-shadow:none}.session-inner{padding:3px;height:100%;box-sizing:border-box;background:#ffffff80;border-radius:4px;overflow:hidden}.session .title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:3px}.session .title:before{content:"⋮⋮";font-size:.65rem;opacity:.5;cursor:grab}.session .meta{font-size:.65rem;opacity:.9}.session .helpers,.session .roomline,.session .groupline{font-size:.6rem;margin-top:1px}select,input[type=text],input[type=email],input[type=password],input[type=color]{padding:.35rem .5rem;font-size:.85rem;width:100%;box-sizing:border-box;border:1px solid var(--border-color);border-radius:6px;background:#fff;color:var(--text-main);transition:outline .1s ease}select:focus,input[type=text]:focus,input[type=email]:focus,input[type=password]:focus{outline:2px solid var(--primary);outline-offset:-1px}.form-row{display:flex;flex-direction:column;margin-bottom:.75rem;font-size:.85rem}.form-row label{margin-bottom:.3rem;font-weight:500;color:var(--text-main)}.form-row-inline{display:flex;gap:.5rem;flex-wrap:wrap}.form-row-inline>div{flex:1;display:flex;flex-direction:column}button{font-size:.85rem;font-weight:500;padding:.35rem .75rem;border-radius:6px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-main);cursor:pointer;transition:all .15s ease;display:inline-flex;align-items:center;justify-content:center;gap:.3rem}button:hover:not(:disabled){background:#e2e8f0;border-color:#cbd5e1}button.primary{background:var(--primary);border-color:var(--primary-hover);color:#fff}button.primary:hover:not(:disabled){background:var(--primary-hover)}button.danger{background:var(--danger);border-color:var(--danger-hover);color:#fff}button.danger:hover:not(:disabled){background:var(--danger-hover)}button:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--btn-bg);border-color:var(--btn-border)}.btn-danger-ghost{color:var(--danger)}.btn-danger-ghost:hover:not(:disabled){background:#fef2f2;border-color:#fecaca}.btn-file-label{display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;padding:.35rem .75rem;border-radius:6px;border:1px solid var(--btn-border);background:var(--btn-bg);color:var(--text-main);cursor:pointer;transition:all .15s ease;width:100%}.btn-file-label:hover{background:#e2e8f0;border-color:#cbd5e1}.day-checkboxes{display:flex;gap:.4rem;flex-wrap:wrap}.day-checkboxes label{display:flex;align-items:center;gap:.3rem;font-weight:400;background:var(--btn-bg);padding:.25rem .5rem;border-radius:4px;border:1px solid var(--btn-border);cursor:pointer;transition:background .1s ease;font-size:.8rem}.day-checkboxes label:hover{background:#e2e8f0}#editor-mode-bar{background:#f1f5f9;border:1px solid var(--border-color);border-radius:6px;padding:.35rem .6rem;font-size:.8rem;font-weight:600;color:var(--text-main);margin-bottom:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#statusMessage{font-size:.8rem;color:#059669;margin-top:.4rem;font-weight:500;min-height:1.2em}.instructor-row{display:flex;align-items:center;justify-content:space-between;font-size:.85rem;margin-bottom:.35rem;padding:.2rem 0;border-bottom:1px solid var(--grid-border)}.instructor-row:last-child{border-bottom:none}.instructor-row button{font-size:.75rem;padding:.2rem .5rem}.instructor-dot{display:inline-block;width:.75rem;height:.75rem;border-radius:999px;margin-right:.4rem;box-shadow:0 0 0 1px #0000001a inset;vertical-align:middle}.hours-panel ul{list-style:none;padding:0;margin:0}.hours-panel li{display:flex;align-items:center;justify-content:space-between;font-size:.875rem;padding:.25rem 0}.warn-badge{font-size:.7rem;background:#fef3c7;border:1px solid #fcd34d;border-radius:4px;padding:.1rem .3rem;margin-left:.3rem;white-space:nowrap}.conflict-count{background:#dc2626;color:#fff;font-size:.7rem;font-weight:700;border-radius:999px;padding:.1rem .45rem;margin-left:.5rem;vertical-align:middle}#conflict-list{list-style:none;padding:0;margin:0}.conflict-item{padding:.4rem 0;border-bottom:1px solid var(--grid-border);font-size:.8rem}.conflict-item:last-child{border-bottom:none}.conflict-item:hover{background:#f8fafc}.conflict-detail{color:var(--text-muted);font-size:.75rem;margin-top:.2rem}.conflict-type-badge{font-size:.65rem;font-weight:700;padding:.1rem .3rem;border-radius:3px;margin-right:.3rem;text-transform:uppercase;letter-spacing:.03em}.conflict-type-instructor{background:#fce7f3;color:#9d174d}.conflict-type-room{background:#ede9fe;color:#5b21b6}.conflict-type-cohort{background:#dbeafe;color:#1e40af}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:var(--panel-bg);border-radius:12px;padding:1.5rem;width:100%;max-width:380px;box-shadow:0 20px 60px #0003}.modal-box h2{font-size:1.1rem;font-weight:700;margin-bottom:1rem}.login-error{font-size:.8rem;color:var(--danger);margin-top:.5rem}hr{border:0;border-top:1px solid var(--border-color);margin:.75rem 0}.hidden,.auth-hidden{display:none!important}.notes-queue-list{max-height:50vh;overflow-y:auto;padding-right:.25rem}@media (max-width: 768px){#app-body{flex-direction:column;padding:.5rem}.main{flex:none;width:100%}.side{max-width:100%;width:100%;position:static;max-height:none}.space-container{overflow-x:auto}.schedule-grid{min-width:600px}#student-detail-panel:not(.hidden){position:fixed;inset:auto 0 0 0;z-index:1000;margin:0;border-radius:12px 12px 0 0;box-shadow:0 -4px 20px #00000026;background:var(--panel-bg);max-height:80vh;overflow-y:auto}.notes-queue-list{max-height:30vh}}
