.sidebar{position:fixed;top:0;left:0;width:var(--sidebar-width);height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:100;transition:width .2s ease}.sidebar-collapsed{width:52px}.sidebar-header{padding:1.25rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-collapsed .sidebar-header{padding:1.25rem .5rem;justify-content:center}.sidebar-logo{font-size:1.1rem;font-weight:700;color:var(--accent-teal);letter-spacing:-.02em;white-space:nowrap;overflow:hidden}.sidebar-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.7rem;padding:4px;border-radius:4px;flex-shrink:0;transition:color .15s}.sidebar-toggle:hover{color:var(--text-primary);background:var(--bg-hover)}.sidebar-nav{flex:1;overflow-y:auto;padding:.75rem 0}.nav-section{margin-bottom:.5rem}.nav-section-title{padding:.5rem 1.25rem .35rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.sidebar-collapsed .nav-section-title{display:none}.nav-item{display:flex;align-items:center;gap:.6rem;padding:.5rem 1.25rem;color:var(--text-secondary);font-size:.85rem;text-decoration:none;transition:all .15s;border-left:2px solid transparent}.sidebar-collapsed .nav-item{padding:.5rem 0;justify-content:center;border-left:none}.nav-item:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-item.active{color:var(--accent-teal);background:var(--accent-teal-dim);border-left-color:var(--accent-teal);font-weight:500}.nav-icon{font-size:.95rem;width:1.25rem;text-align:center}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:.5rem}.sidebar-user-name{font-size:.85rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-meta{font-size:.7rem;color:var(--text-muted);margin-top:.15rem}.app-layout{display:flex;min-height:100vh}.main-content{margin-left:var(--sidebar-width);flex:1;padding:2rem;max-width:calc(100vw - var(--sidebar-width));transition:margin-left .2s ease,max-width .2s ease}.app-layout:has(.sidebar-collapsed) .main-content{margin-left:52px;max-width:calc(100vw - 52px)}@media(max-width:768px){.main-content{margin-left:0;padding:1rem;max-width:100vw}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary)}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:2.5rem;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.5rem;font-weight:700;color:var(--accent-gold);margin-bottom:.35rem}.login-header p{font-size:.875rem;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error);padding:.5rem .75rem;border-radius:var(--radius);font-size:.85rem}.login-btn{width:100%;justify-content:center;padding:.65rem;font-size:.9rem;margin-top:.5rem}:root{--bg-primary: #0a141a;--bg-secondary: #0f1f25;--bg-card: #13262e;--bg-input: #1a3540;--bg-hover: #214151;--text-primary: #e8ede9;--text-secondary: #a0b5b8;--text-muted: #6b8588;--accent-gold: #D4A84B;--accent-gold-light: #e0c76a;--accent-gold-dim: rgba(212, 168, 75, .15);--accent-teal: #4FB3A9;--accent-teal-dim: rgba(79, 179, 169, .15);--border-color: rgba(255, 255, 255, .08);--border-gold: rgba(212, 168, 75, .2);--success: #4ade80;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--sidebar-width: 240px;--header-height: 56px;--radius: 8px;--radius-sm: 4px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.5}a{color:var(--accent-teal);text-decoration:none}a:hover{color:var(--accent-gold-light)}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent-gold);color:#0a141a}.btn-primary:hover{background:var(--accent-gold-light)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover)}.btn-sm{padding:.35rem .75rem;font-size:.8rem}input,select,textarea{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius);padding:.5rem .75rem;font-size:.875rem;font-family:inherit;width:100%;transition:border-color .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent-teal)}label{display:block;font-size:.8rem;font-weight:500;color:var(--text-secondary);margin-bottom:.35rem}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.25rem}.data-table{width:100%;border-collapse:collapse}.data-table th{text-align:left;padding:.75rem;font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.data-table td{padding:.75rem;font-size:.875rem;border-bottom:1px solid var(--border-color)}.data-table tr.row-clickable{cursor:pointer}.data-table tr.row-clickable:hover td{background:var(--bg-hover)}.badge{display:inline-flex;align-items:center;padding:.2rem .5rem;border-radius:9999px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-success{background:#4ade8026;color:var(--success)}.badge-warning{background:#f59e0b26;color:var(--warning)}.badge-error{background:#ef444426;color:var(--error)}.badge-info{background:#3b82f626;color:var(--info)}.badge-muted{background:#6b857026;color:var(--text-muted)}.badge-teal{background:var(--accent-teal-dim);color:var(--accent-teal)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.page-header h1{font-size:1.5rem;font-weight:600}.page-header-sub{color:var(--text-muted);font-size:.85rem;margin-top:.25rem}.page-header-actions{display:flex;gap:.5rem}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-muted)}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state p{margin-top:.5rem;font-size:.875rem}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);padding:1.25rem}.kpi-card-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.kpi-card-value{font-size:1.75rem;font-weight:700;color:var(--accent-gold)}.progress{width:100%;height:6px;background:var(--bg-input);border-radius:9999px;overflow:hidden}.progress-bar{height:100%;background:var(--accent-teal);transition:width .3s ease}.progress-bar.full{background:var(--success)}.filter-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem;align-items:center}.filter-bar input,.filter-bar select{width:auto;min-width:180px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-hover);border-radius:3px}.admin-bypass-banner{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--warning);padding:.5rem .75rem;border-radius:var(--radius);font-size:.8rem;margin-bottom:1rem}.back-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-muted);font-size:.85rem;margin-bottom:1rem;cursor:pointer;background:none;border:none;padding:0}.back-link:hover{color:var(--accent-teal)}.section{margin-bottom:2rem}.section-title{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:200;padding:1rem}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .5rem}.modal-header h2{font-size:1.1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:0 .25rem;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-subhead{padding:0 1.25rem .75rem;font-size:.8rem;color:var(--text-muted)}.modal-body{padding:.75rem 1.25rem 1.25rem;overflow-y:auto}.assign-list{list-style:none}.assign-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem 0;border-bottom:1px solid var(--border-color)}.assign-row:last-child{border-bottom:none}.assign-row-main{flex:1;min-width:0}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .15s}.sortable:hover{color:var(--text-primary)}.sort-arrow{display:inline-block;margin-left:.3rem;font-size:.6rem;color:var(--text-muted);opacity:.5}.sort-arrow-active{color:var(--accent-teal);opacity:1}.roster-card{padding:0;overflow:hidden}.roster-table th{white-space:nowrap}.roster-name{display:flex;align-items:center;gap:.4rem}.stuck-dot{color:var(--warning);font-size:.55rem;flex-shrink:0}.row-stuck td{position:relative}.row-stuck td:first-child{box-shadow:inset 2px 0 0 0 var(--warning)}.course-chips{display:flex;flex-wrap:wrap;gap:.3rem;max-width:22rem}.course-chip{display:inline-block;padding:.2rem .5rem;background:var(--accent-teal-dim);color:var(--accent-teal);border-radius:var(--radius-sm);font-size:.75rem;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}@media(max-width:900px){.roster-table .course-chips{max-width:12rem}}@media(max-width:768px){.roster-table th:nth-child(4),.roster-table td:nth-child(4){display:none}.course-chips{max-width:10rem}}@media(max-width:560px){.roster-table th:nth-child(2),.roster-table td:nth-child(2){display:none}}.activity-list{list-style:none}.activity-item{padding:.5rem 0;border-bottom:1px solid var(--border-color);font-size:.85rem;display:flex;justify-content:space-between;gap:1rem}.activity-item:last-child{border-bottom:none}.activity-meta{color:var(--text-muted);font-size:.75rem}.quiz-summary{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding-bottom:.75rem;margin-bottom:.75rem;border-bottom:1px solid var(--border-color);font-size:.85rem}.quiz-summary-meta{color:var(--text-muted);font-size:.8rem}.quiz-list{list-style:none}.quiz-item{border-bottom:1px solid var(--border-color)}.quiz-item:last-child{border-bottom:none}.quiz-item-header{display:grid;grid-template-columns:2rem 1fr auto auto 1rem;align-items:center;gap:.5rem;padding:.6rem 0;cursor:pointer}.quiz-item-header:hover{background:var(--bg-hover)}.quiz-item-q{font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.quiz-item-meta{font-size:.75rem;color:var(--text-muted)}.quiz-chevron{color:var(--text-muted);font-size:.75rem}.quiz-item-body{padding:.75rem 0 1rem 2.5rem;display:flex;flex-direction:column;gap:.6rem;font-size:.85rem}.quiz-context{font-size:.75rem;color:var(--text-muted)}.quiz-answer-label{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.2rem}.chat-list{list-style:none}.chat-turn{padding:1rem 0;border-bottom:1px solid var(--border-color)}.chat-turn:last-child{border-bottom:none}.chat-meta{font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem}.chat-bubble{padding:.6rem .85rem;border-radius:var(--radius);font-size:.85rem;margin-bottom:.4rem;max-width:90%;white-space:pre-wrap}.chat-bubble-user{background:var(--bg-input);margin-left:auto;border-bottom-right-radius:2px}.chat-bubble-tutor{background:var(--accent-teal-dim);border:1px solid rgba(79,179,169,.25);border-bottom-left-radius:2px}.chat-bubble-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.25rem}.notes-composer{margin-bottom:1rem}.notes-composer textarea{font-family:inherit;resize:vertical;min-height:5rem}.notes-composer-actions{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;margin-top:.5rem}.notes-counter{font-size:.7rem;color:var(--text-muted);margin-right:auto}.notes-list{list-style:none}.note-item{padding:.85rem 0;border-bottom:1px solid var(--border-color)}.note-item:last-child{border-bottom:none}.note-meta{font-size:.7rem;color:var(--text-muted);margin-bottom:.35rem;display:flex;gap:.5rem;flex-wrap:wrap}.note-author{color:var(--accent-teal);font-weight:600}.note-date{color:var(--text-muted)}.note-body{font-size:.875rem;white-space:pre-wrap;line-height:1.55}.note-actions{display:flex;gap:.75rem;margin-top:.4rem}.note-action-btn{background:none;border:none;padding:0;font-size:.75rem;color:var(--text-muted);cursor:pointer}.note-action-btn:hover{color:var(--accent-teal)}.note-action-danger:hover{color:var(--error)}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.25rem}.profile-group-title{font-size:.7rem;font-weight:700;color:var(--accent-teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.5rem}.profile-list{display:flex;flex-direction:column;gap:.4rem}.profile-row{display:grid;grid-template-columns:9rem 1fr;gap:.5rem;font-size:.8rem}.profile-row dt{color:var(--text-muted);font-weight:500}.profile-row dd{color:var(--text-primary);text-transform:capitalize}
