:root{color:#1e293b;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;margin:0}button,input,textarea{letter-spacing:0}#root{min-height:100svh}:root{--ink:#172033;--muted:#667085;--line:#d9e2f1;--panel:#fffffff0;--teal:#0f766e;--blue:#2563eb;--violet:#7c3aed;--rose:#e11d48;--amber:#f59e0b;--green:#059669}.login-page.modern-login{color:#f8fafc;background:linear-gradient(115deg,#14b8a62e,#0000 28%),linear-gradient(245deg,#f43f5e24,#0000 30%),linear-gradient(#070b12,#101827 52%,#111827);grid-template-columns:minmax(0,1fr) minmax(360px,460px);position:relative;overflow:hidden}.login-ambient{min-height:100svh;position:relative;overflow:hidden}.login-ambient:before{content:"";background-image:linear-gradient(#94a3b814 1px,#0000 1px),linear-gradient(90deg,#94a3b814 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(90deg,#0000,#000 18% 82%,#0000);mask-image:linear-gradient(90deg,#0000,#000 18% 82%,#0000)}.login-orbit{filter:blur(.1px);border:1px solid #94a3b82e;border-radius:999px;position:absolute}.orbit-a{background:#14b8a62e;width:320px;height:320px;animation:14s ease-in-out infinite orbitFloat;top:14%;left:12%}.orbit-b{background:#f59e0b29;width:220px;height:220px;animation:18s ease-in-out infinite reverse orbitFloat;top:18%;right:14%}.orbit-c{background:#f43f5e24;width:260px;height:260px;animation:16s ease-in-out infinite orbitFloat;bottom:12%;left:28%}@keyframes orbitFloat{0%,to{transform:translate(0,0)scale(1)}50%{transform:translate(18px,-24px)scale(1.04)}}.login-preview-shell{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0f172a8f;border:1px solid #ffffff24;border-radius:18px;max-width:min(660px,100vw - 56px);padding:16px;position:absolute;top:50%;left:clamp(28px,10vw,140px);right:clamp(24px,12vw,180px);transform:translateY(-50%);box-shadow:0 34px 80px #00000057}.login-preview-topbar{gap:8px;padding:0 0 14px;display:flex}.login-preview-topbar span{background:#e2e8f07a;border-radius:999px;width:9px;height:9px}.login-preview-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.login-preview-tile{aspect-ratio:1;background:linear-gradient(135deg,#60a5fa52,#14b8a633);border:1px solid #ffffff21;border-radius:10px}.login-preview-tile.large{aspect-ratio:auto;grid-row:span 2}.login-preview-tile.warning{background:linear-gradient(135deg,#f59e0b57,#f43f5e24)}.login-preview-tile.success{background:linear-gradient(135deg,#10b98161,#3b82f61f)}.login-preview-tile.wide{aspect-ratio:2;grid-column:span 2}.login-glass-panel{-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);z-index:1;background:#ffffff1a;border:1px solid #ffffff29;border-radius:18px;align-self:center;gap:24px;margin:32px;padding:clamp(24px,4vw,38px);display:grid;position:relative;box-shadow:0 28px 70px #00000047}.login-wordmark{color:#f8fafc;align-items:center;gap:12px;font-weight:900;display:flex}.login-wordmark .login-logo-mark{border-radius:10px;width:42px;height:42px}.modern-login .login-form-header{gap:8px;display:grid}.modern-login .login-form-header h1{color:#fff;letter-spacing:0;margin:0;font-size:clamp(30px,5vw,46px);line-height:1.05}.modern-login .login-form-header span,.modern-login .login-form-footer{color:#cbd5e1;margin:0;font-weight:650;line-height:1.55}.modern-login .login-form{gap:14px;display:grid}.modern-login label{color:#e2e8f0}.modern-login input{color:#fff;background:#0206178a;border-color:#94a3b857}.modern-login input::placeholder{color:#94a3b8}.modern-login input:focus{background:#020617b8;border-color:#2dd4bf;box-shadow:0 0 0 3px #2dd4bf29}.login-inline-error{color:#fecdd3;background:#f43f5e24;border:1px solid #fb718557;border-radius:10px;padding:12px 14px;font-size:14px;font-weight:750}.login-submit{gap:10px}.login-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:999px;width:16px;height:16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.meet-video-tile{transition:border-color .16s,box-shadow .16s,transform .16s;box-shadow:inset 0 0 0 1px #ffffff05}.meet-video-tile.is-speaking{border-color:#2dd4bfd6;box-shadow:0 0 0 3px #2dd4bf2e,inset 0 0 0 1px #2dd4bf24}.meet-video-avatar{color:#f8fafc;background:linear-gradient(135deg,#155e75,#7c2d12);border:1px solid #ffffff29;border-radius:999px;justify-content:center;align-items:center;width:clamp(86px,18vw,148px);height:clamp(86px,18vw,148px);font-size:clamp(28px,6vw,58px);font-weight:900;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.meet-video-label{justify-content:space-between;align-items:flex-end;gap:8px;display:flex}.meet-video-label span{color:#cbd5e1;font-size:12px;font-weight:800}.meet-video-grid--solo .meet-video-tile{max-height:min(72svh,720px)}.meet-video-grid--compact{grid-template-columns:repeat(2,minmax(0,1fr))}.meet-video-grid--many{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.meet-sidebar .meet-member-item{grid-template-columns:auto minmax(0,1fr) auto;gap:8px;display:grid}.meet-member-item.is-speaking{background:#14b8a62e}.meet-member-avatar{color:#f8fafc;background:#334155;border-radius:999px;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:900;display:inline-flex}.meet-member-avatar.speaking{background:#0f766e;box-shadow:0 0 0 3px #2dd4bf2e}.meet-chat-error{color:#fecdd3;background:#f43f5e1f;border:1px solid #fb718547;border-radius:8px;margin:0;padding:10px;font-size:13px;font-weight:750}.meet-control-icon{background:#ffffff1f;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;font-size:12px;font-weight:900;display:inline-flex}.room-management-panel{background:#ffffff12;border:1px solid #94a3b838;border-radius:12px;gap:14px;margin:0 20px 18px;padding:16px;display:grid}.room-management-head,.room-assignment-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.room-management-head h3{color:#f8fafc;margin:0}.room-management-form{gap:12px;display:grid}.room-management-form input,.room-management-form textarea,.room-management-form select{color:#f8fafc;background:#020617a3;border-color:#94a3b847}.room-management-actions{flex-wrap:wrap;gap:8px;display:flex}.room-management-body{grid-template-columns:minmax(220px,.75fr) minmax(0,1.25fr);gap:14px;display:grid}.room-management-list,.room-student-list{gap:8px;max-height:280px;display:grid;overflow:auto}.room-management-list button,.room-student-option{color:#e2e8f0;background:#ffffff0f;border:1px solid #94a3b82e;border-radius:8px}.room-management-list button{cursor:pointer;text-align:left;gap:4px;padding:10px 12px;display:grid}.room-management-list button.active{border-color:#2dd4bf94;box-shadow:0 0 0 3px #2dd4bf1f}.room-management-list span,.room-assignment-head span{color:#94a3b8;font-size:12px;font-weight:800}.room-assignment-panel{gap:10px;display:grid}.room-assignment-head strong{color:#f8fafc}.room-student-option{cursor:pointer;align-items:center;gap:10px;margin:0;padding:10px 12px;display:flex}.room-student-option input{accent-color:#14b8a6;width:16px;height:16px}.room-management-alert{color:#ccfbf1;background:#14b8a621;border:1px solid #2dd4bf47;border-radius:8px;margin:0;padding:10px 12px;font-weight:750}.room-management-alert.danger{color:#fecdd3;background:#f43f5e21;border-color:#fb71854d}.room-management-empty{color:#94a3b8;text-align:center;margin:0;padding:12px;font-weight:750}@media (width<=980px){.login-page.modern-login{grid-template-columns:1fr}.login-ambient{min-height:280px}.login-preview-shell{left:18px;right:18px}.login-glass-panel{margin:0 16px 24px}.room-management-body,.meet-video-grid--compact{grid-template-columns:1fr}}.app-shell{color:var(--ink);background:linear-gradient(135deg,#2563eb21,#0000 34%),linear-gradient(225deg,#e11d4821,#0000 32%),linear-gradient(315deg,#f59e0b24,#0000 34%),#f6f8fd;min-height:100svh;padding:28px}.role-admin{background:linear-gradient(135deg,#7c3aed26,#0000 35%),linear-gradient(225deg,#0ea5e921,#0000 34%),linear-gradient(315deg,#f59e0b24,#0000 36%),#f7f8ff}.role-student{background:linear-gradient(135deg,#10b98126,#0000 35%),linear-gradient(225deg,#3b82f621,#0000 34%),linear-gradient(315deg,#f43f5e1f,#0000 36%),#f5fbff}.topbar{background:#ffffffdb;border:1px solid #ffffffd1;border-radius:8px;justify-content:space-between;align-items:center;gap:24px;max-width:1320px;margin:0 auto 22px;padding:20px;display:flex;box-shadow:0 22px 50px #1f29371f}.brand-block{gap:6px;display:grid}.eyebrow{color:var(--teal);letter-spacing:0;text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.topbar h1,.exam-heading h2,.panel-title h2,.empty-state h2{color:#111827;margin:0}.topbar h1{font-size:clamp(28px,4vw,42px);font-weight:900;line-height:1.1}.subtitle{color:var(--muted);margin:0;font-size:15px}.session-card{background:linear-gradient(135deg,#fff,#f5f7ff);border:1px solid #dbe4f3;border-radius:8px;align-items:center;gap:12px;padding:10px;display:flex;box-shadow:0 12px 24px #0f172a14}.session-card div{min-width:118px;display:grid}.session-card strong{color:#111827;font-size:14px}.session-card small{color:var(--muted);font-size:12px;font-weight:700}.role-chip{color:#fff;white-space:nowrap;border-radius:999px;padding:8px 10px;font-size:12px;font-weight:900}.role-chip.admin{background:linear-gradient(135deg, var(--violet), var(--blue))}.role-chip.student{background:linear-gradient(135deg, var(--teal), var(--green))}.logout-button{min-height:36px}.alert{color:#be123c;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;max-width:1320px;margin:0 auto 18px;padding:12px 14px;font-weight:700}.content-grid{grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:20px;max-width:1320px;margin:0 auto;display:grid}.side-panel,.work-panel{background:var(--panel);border:1px solid #d8e2f1eb;border-radius:8px;box-shadow:0 18px 38px #0f172a14}.side-panel{align-self:start;gap:22px;padding:20px;display:grid;position:sticky;top:24px}.work-panel{min-height:680px;padding:26px}.panel-section,.create-test{gap:12px;display:grid}.panel-title,.exam-heading,.action-row,.question-head,.row-actions,.button-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.panel-title h2{font-size:20px;font-weight:900}.exam-heading{background:linear-gradient(135deg,#2563eb14,#10b98117);border:1px solid #dce7f8;border-radius:8px;margin-bottom:22px;padding:18px}.exam-heading h2{font-size:26px;font-weight:900;line-height:1.25}.stats{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.badge,.badge-count,.timer-pill,.score-badge,.status-chip{white-space:nowrap;border-radius:999px;padding:8px 10px;font-size:13px;font-weight:800;line-height:1;display:inline-flex}.badge{color:#334155;background:#eef2ff}.badge.highlight{color:#c2410c;background:#fff7ed}.badge-count{color:#0369a1;background:#e0f2fe}.timer-pill{color:var(--green);background:#ecfdf5;justify-content:center;min-width:74px}.timer-pill.danger,.status-chip.warning,.result-badge.warning{color:#b91c1c;background:#fef2f2}.status-chip.danger{color:#be123c;background:#fff1f2}.score-badge{color:var(--violet);background:#eef2ff}.status-chip{color:#047857;background:#ecfdf5}.primary-button,.ghost-button,.delete-button,.delete-button-icon{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;min-height:42px;padding:0 15px;font-family:inherit;font-weight:800;transition:background .16s,border-color .16s,color .16s,transform .16s;display:inline-flex}.primary-button{background:linear-gradient(135deg, var(--blue), var(--violet));color:#fff;border:1px solid #0000;box-shadow:0 12px 22px #2563eb38}.primary-button:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#6d28d9);transform:translateY(-1px)}.ghost-button{color:#334155;background:#fff;border:1px solid #cbd5e1}.ghost-button:hover:not(:disabled){background:#f8fafc;border-color:#94a3b8}.full-width{width:100%}button:disabled,input:disabled{cursor:not-allowed;opacity:.58}label{color:#243042;margin-bottom:6px;font-size:14px;font-weight:800;display:block}input,textarea{color:#111827;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;width:100%;padding:11px 12px;font-family:inherit;font-size:15px}input:focus,textarea:focus{border-color:var(--blue);background:#fff;outline:none;box-shadow:0 0 0 3px #2563eb24}.field-hint{color:#64748b;margin:4px 0 0;font-size:13px}.monitor-status{background:#f8fafc;border:1px solid #dfe5ee;border-radius:8px;gap:5px;padding:12px;display:grid}.monitor-status span{color:#64748b;text-transform:uppercase;font-size:12px;font-weight:900}.monitor-status strong{color:#475569;font-size:15px}.monitor-status p{color:#64748b;margin:0;font-size:13px}.monitor-status.active{background:#ecfdf5;border-color:#99f6e4}.monitor-status.active strong{color:#047857}.monitor-status.stopped{background:#fef2f2;border-color:#fecaca}.monitor-status.stopped strong{color:#b91c1c}.test-list{gap:10px;display:grid}.test-row{background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid #dfe5ee;border-radius:8px;align-items:stretch;display:flex;overflow:hidden}.test-row.selected{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb24}.test-row>button:first-child{color:#111827;cursor:pointer;text-align:left;background:0 0;border:0;flex-direction:column;flex:1;gap:5px;min-width:0;padding:13px;display:flex}.test-row strong{font-size:15px;line-height:1.3}.test-meta{color:#64748b;font-size:13px;line-height:1.35}.delete-button-icon{color:var(--rose);background:#fff1f2;border:0;border-left:1px solid #fecdd3;min-height:100%}.delete-button.outline{color:#dc2626;background:#fff;border:1px solid #fecaca;min-height:34px}.empty-list{color:#64748b;text-align:center;background:linear-gradient(135deg,#f8fafc,#eef6ff);border:1px dashed #aab9ce;border-radius:8px;padding:18px;font-weight:700}.empty-state{color:#64748b;text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:420px;display:flex}.empty-icon{color:#0f4f8f;background:linear-gradient(135deg,#dbeafe,#ccfbf1);border:1px solid #bae6fd;border-radius:8px;justify-content:center;align-items:center;width:58px;height:58px;margin-bottom:16px;font-size:18px;font-weight:900;display:flex}.empty-state h2{font-size:24px;font-weight:900}.empty-state p{max-width:460px;margin:8px 0 0}.question-stack{gap:16px;display:grid}.question-block{background:linear-gradient(135deg,#fff,#fbfdff);border:1px solid #dfe5ee;border-radius:8px;padding:20px}.question-head h3{color:#111827;margin:0;font-size:18px;font-weight:900}.question-content{color:#243042;margin:14px 0 16px;font-size:16px;line-height:1.65}.answer-grid{gap:10px;display:grid}.answer-option{cursor:pointer;background:#f8fafc;border:1px solid #dbe2ea;border-radius:8px;align-items:center;gap:12px;margin:0;padding:13px 14px;display:flex}.answer-option:hover{border-color:var(--blue)}.answer-option.selected{border-color:var(--green);background:linear-gradient(135deg,#ecfdf5,#eff6ff)}.answer-option input[type=radio]{accent-color:var(--green);width:18px;height:18px;margin:0}.answer-text{color:#172033;font-size:15px;font-weight:650}.result-panel{color:#065f46;background:linear-gradient(135deg,#ecfdf5,#fff7ed);border:1px solid #a7f3d0;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;margin-top:22px;padding:18px;display:flex}.result-score-info strong{color:#047857;margin:4px 0;font-size:30px;font-weight:900;line-height:1.2;display:block}.result-score-info span{color:#166534;font-weight:700}.result-badge{color:#047857;white-space:nowrap;background:#fff;border-radius:999px;padding:9px 12px;font-size:13px;font-weight:900}.action-row{border-top:1px solid #e6ebf2;margin-top:22px;padding-top:18px}.progress-text{color:#64748b;font-weight:700}.progress-text strong{color:#111827}.settings-form{background:linear-gradient(135deg,#f8fafc,#f5f3ff);border:1px solid #dfe5ee;border-radius:8px;grid-template-columns:minmax(0,1fr) 170px auto;align-items:end;gap:12px;margin-bottom:20px;padding:16px;display:grid}.form-row{gap:6px;display:grid}.form-row.compact{max-width:190px}.history-panel,.monitor-panel{border-bottom:1px solid #e6ebf2;margin-bottom:22px;padding-bottom:22px}.monitor-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;display:grid}.monitor-card{border:1px solid #dfe5ee;border-radius:8px;gap:12px;padding:12px;display:grid}.monitor-card.selected{border-color:var(--violet);box-shadow:0 0 0 3px #7c3aed1f}.monitor-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.monitor-card-head div{gap:2px;display:grid}.monitor-card-head strong{color:#172033;font-size:15px}.monitor-card-head span{color:#64748b;font-size:12px;font-weight:700}.monitor-preview{aspect-ratio:16/9;color:#cbd5e1;background:#111827;border-radius:6px;justify-content:center;align-items:center;font-size:13px;font-weight:800;display:flex;overflow:hidden}.monitor-preview img{object-fit:cover;width:100%;height:100%;display:block}.monitor-events{gap:6px;display:grid}.monitor-event{justify-content:space-between;align-items:center;gap:8px;display:flex}.monitor-event span,.monitor-event time{color:#64748b;font-size:12px;font-weight:800}.monitor-event.warning span,.monitor-event.warning time{color:#be123c}.monitor-live-panel{color:#e5e7eb;background:#0f172a;border-radius:8px;gap:12px;margin-top:16px;padding:14px;display:grid}.monitor-live-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.monitor-live-head h3{color:#f8fafc;margin:0 0 4px}.monitor-live-head span{color:#94a3b8;font-size:13px;font-weight:700}.monitor-live-alert,.monitor-live-empty{color:#cbd5e1;background:#ffffff0f;border:1px solid #94a3b83d;border-radius:8px;gap:4px;margin:0;padding:12px;display:grid}.monitor-live-alert{color:#fecdd3;border-color:#fb718573}.monitor-live-grid{grid-template-columns:minmax(0,1fr);gap:12px;display:grid}.monitor-live-video{aspect-ratio:16/9;background:#020617;border:1px solid #94a3b833;border-radius:8px;position:relative;overflow:hidden}.monitor-live-video video{object-fit:contain;width:100%;height:100%}.monitor-live-video span{color:#f8fafc;background:linear-gradient(#0000,#0f172ae6);padding:10px 12px;font-size:13px;font-weight:800;position:absolute;bottom:0;left:0;right:0}.history-table-wrap{border:1px solid #dfe5ee;border-radius:8px;overflow-x:auto}.history-table{border-collapse:collapse;width:100%;min-width:760px}.history-table th,.history-table td{text-align:left;vertical-align:middle;border-bottom:1px solid #e6ebf2;padding:12px 14px}.history-table th{color:#475569;text-transform:uppercase;background:#f8fafc;font-size:12px;font-weight:900}.history-table td{color:#243042;font-size:14px;font-weight:650}.history-table tbody tr:last-child td{border-bottom:0}.import-tabs{border-bottom:1px solid #dfe5ee;gap:8px;margin-bottom:16px;padding-bottom:10px;display:flex}.import-tabs button{color:#64748b;cursor:pointer;background:0 0;border:0;border-radius:8px;min-height:38px;padding:0 14px;font-family:inherit;font-weight:900}.import-tabs button.active{color:var(--violet);background:#ede9fe}.question-form{background:linear-gradient(135deg,#fff,#fffbeb);border:1px solid #dfe5ee;border-radius:8px;gap:16px;margin-bottom:22px;padding:18px;display:grid}.json-form{background:#f8fafc}.code-textarea{color:#e5e7eb;background:#101828;border-color:#101828;font-family:Consolas,Monaco,monospace;font-size:14px;line-height:1.5}.code-textarea:focus{background:#101828}.answer-editor{gap:10px;display:grid}.answer-edit-row{background:#f8fafc;border:1px solid #dfe5ee;border-radius:8px;grid-template-columns:minmax(0,1fr) 96px auto;align-items:center;gap:12px;padding:10px;display:grid}.correct-toggle{cursor:pointer;align-items:center;gap:8px;margin:0;display:flex}.correct-toggle input{accent-color:#0f766e;width:18px;height:18px}.icon-only{min-height:38px;padding:0 12px}.answer-review{gap:8px;margin:0;padding:0;list-style:none;display:grid}.answer-review li{color:#334155;background:#f8fafc;border:1px solid #dfe5ee;border-radius:8px;align-items:center;gap:10px;padding:11px 12px;display:flex}.answer-review li.correct{color:#065f46;background:#ecfdf5;border-color:#99f6e4}.status-tag{border-radius:999px;padding:5px 8px;font-size:12px;font-weight:900}.status-tag.true{background:var(--green);color:#fff}.status-tag.false{color:#475569;background:#e2e8f0}.auth-shell{justify-content:center;align-items:stretch;min-height:100svh;padding:0;display:flex}.login-page{grid-template-columns:minmax(0,1.1fr) minmax(360px,480px);width:100%;min-height:100svh;display:grid}.login-brand{color:#fff;background:radial-gradient(circle at 12% 18%,#f59e0b47,#0000 32%),radial-gradient(circle at 88% 12%,#34d39938,#0000 28%),linear-gradient(145deg,#1e3a8a 0%,#312e81 48%,#1e40af 100%);padding:clamp(28px,5vw,56px);display:flex;position:relative;overflow:hidden}.login-brand:after{content:"";pointer-events:none;background:linear-gradient(#0000,#0f172a2e);position:absolute;inset:0}.login-brand-inner{z-index:1;gap:18px;max-width:560px;display:grid;position:relative}.login-logo-mark{background:linear-gradient(135deg,#ffffff38,#ffffff14);border:1px solid #ffffff47;border-radius:14px;justify-content:center;align-items:center;width:52px;height:52px;display:inline-flex}.login-logo-mark span{font-size:26px;font-weight:900;line-height:1}.login-brand-eyebrow{color:#bfdbfe;letter-spacing:.04em;text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.login-brand-title{max-width:14ch;margin:0;font-size:clamp(32px,5vw,52px);font-weight:900;line-height:1.08}.login-brand-lead{color:#dbeafe;max-width:42ch;margin:0;font-size:clamp(15px,2vw,18px);font-weight:600;line-height:1.6}.login-illustration{width:min(100%,420px);max-width:100%;margin:8px 0 4px;display:block}.login-feature-list{gap:10px;margin:8px 0 0;padding:0;list-style:none;display:grid}.login-feature-list li{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:10px;gap:4px;padding:12px 14px;display:grid}.login-feature-list strong{font-size:15px}.login-feature-list span{color:#dbeafe;font-size:13px;font-weight:600;line-height:1.45}.login-form-panel{background:#f6f8fd;justify-content:center;align-items:center;padding:clamp(24px,4vw,48px);display:flex}.login-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;width:100%;max-width:420px;padding:clamp(28px,4vw,36px);box-shadow:0 24px 48px #0f172a14}.login-form-header{gap:8px;margin-bottom:24px;display:grid}.login-form-header h2{color:#111827;margin:0;font-size:clamp(26px,4vw,32px);font-weight:900;line-height:1.15}.login-form-header p{color:var(--muted);margin:0;font-size:15px;font-weight:600;line-height:1.5}.login-password-row{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.login-password-row label{margin-bottom:0}.login-forgot-link{color:var(--blue);white-space:nowrap;font-size:13px;font-weight:800;text-decoration:none}.login-forgot-link:hover{color:var(--violet);text-decoration:underline}.login-alert{max-width:none;margin:0 0 16px}.login-form{gap:18px;display:grid}.login-submit{min-height:48px;margin-top:4px}.login-form-footer{color:var(--muted);text-align:center;border-top:1px solid #e2e8f0;margin:22px 0 0;padding-top:18px;font-size:13px;font-weight:600;line-height:1.5}.theme-dark .login-form-panel{background:#0b1120}.theme-dark .login-form-card{background:#0f172af0;border-color:#94a3b83d}.theme-dark .login-form-header h2{color:#f8fafc}.theme-dark .login-form-footer{border-color:#94a3b83d}.student-profile-card{background:#0f766e14;border:1px solid #0f766e26;border-radius:12px;gap:4px;padding:14px 16px;display:grid}.student-profile-card strong{font-size:1.05rem}.student-profile-card small{opacity:.75}.student-management,.student-assignment,.student-create-form{gap:10px;display:grid}.student-create-form .field-hint{margin:-2px 0 2px}.student-list,.assignment-list{gap:8px;display:grid}.student-row{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.student-row>div:first-child{gap:2px;display:grid}.student-row .student-row-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.student-row span,.student-row small{opacity:.8;font-size:.88rem}.student-password-button{align-items:center;gap:8px;min-height:34px;display:inline-flex}.student-password-button svg{width:18px;height:18px}.student-toast{color:#047857;background:#ecfdf5;border:1px solid #99f6e4;border-radius:8px;padding:10px 12px;font-size:14px;font-weight:800}.account-modal{gap:12px;display:grid}.modal-copy{color:#64748b;margin:-6px 0 0;font-size:14px;font-weight:700}.generated-account-summary{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:10px;padding:14px;display:grid}.generated-account-summary div{gap:4px;display:grid}.generated-account-summary span{color:#64748b;text-transform:uppercase;font-size:12px;font-weight:900}.generated-account-summary strong,.generated-account-summary code{color:#111827;font-size:15px}.generated-account-summary code{color:#075985;overflow-wrap:anywhere;background:#e0f2fe;border-radius:6px;padding:8px 10px;font-family:Consolas,Monaco,monospace}.change-password-form{gap:14px;display:grid}.assignment-option{cursor:pointer;background:#ffffff08;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.assignment-option input{width:auto}.admin-dashboard{background:#eef2ff;grid-template-columns:260px minmax(0,1fr);min-height:100svh;display:grid}.admin-sidebar{color:#fff;background:linear-gradient(#1e1b4b 0%,#312e81 100%);grid-template-rows:auto 1fr auto;gap:24px;padding:24px 16px;display:grid}.admin-brand{gap:4px;padding:0 8px;display:grid}.admin-brand .eyebrow{color:#c4b5fd}.admin-brand strong{font-size:18px}.admin-nav{align-content:start;gap:6px;display:grid}.admin-nav-item{color:#e0e7ff;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;padding:12px 14px;font-size:14px;font-weight:700;display:flex}.admin-nav-item:hover,.admin-nav-item.active{color:#fff;background:#ffffff1f}.admin-nav-item.active{box-shadow:inset 3px 0 #a78bfa}.admin-sidebar-user{border-top:1px solid #ffffff1f;gap:8px;padding-top:16px;display:grid}.admin-sidebar-user small{color:#c4b5fd}.admin-main{grid-template-rows:auto 1fr;min-width:0;display:grid}.admin-topbar{background:#ffffffeb;border-bottom:1px solid #dbe4f3;justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.admin-topbar-actions{align-items:center;gap:10px;display:flex}.admin-topbar h1{margin:0;font-size:24px}.admin-content{padding:24px 28px 40px;overflow:auto}.admin-alert{max-width:none;margin:0 28px}.admin-panel,.student-management.admin-panel{background:#fff;border:1px solid #dbe4f3;border-radius:12px;padding:20px;box-shadow:0 8px 24px #0f172a0f}.admin-tests-layout{grid-template-columns:minmax(280px,380px) minmax(0,1fr);gap:20px;display:grid}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #dbe4f3;border-radius:12px;gap:8px;padding:18px;display:grid;box-shadow:0 8px 24px #0f172a0f}.stat-card span{color:var(--muted);font-size:13px;font-weight:700}.stat-card strong{font-size:28px}.admin-tab-bar{flex-wrap:wrap;gap:8px;margin-bottom:20px;display:flex}.admin-tab-bar button{cursor:pointer;background:#fff;border:1px solid #dbe4f3;border-radius:999px;padding:8px 14px;font-weight:700}.admin-tab-bar button.active{background:var(--violet);border-color:var(--violet);color:#fff}.admin-test-edit{gap:20px;display:grid}.exam-fullscreen-shell{z-index:50;background:#f8fafc;grid-template-rows:auto auto 1fr auto;min-height:100svh;display:grid;position:fixed;inset:0}:-webkit-any(.exam-fullscreen-shell:fullscreen,.exam-fullscreen-shell:-webkit-full-screen){background:#f8fafc}:is(.exam-fullscreen-shell:fullscreen,.exam-fullscreen-shell:fullscreen){background:#f8fafc}.exam-fullscreen-topbar{background:#fff;border-bottom:1px solid #dbe4f3;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.exam-fullscreen-topbar div:first-child{gap:2px;display:grid}.exam-fullscreen-meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.monitor-pill{color:#047857;background:#ecfdf5;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:800}.monitor-pill.stopped{color:#be123c;background:#fff1f2}.monitor-pill.starting{color:#1d4ed8;background:#eff6ff}.fullscreen-warning{color:#9a3412;background:#fff7ed;border-bottom:1px solid #fed7aa;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 20px;display:flex}.exam-fullscreen-body{padding:20px;overflow:auto}.exam-fullscreen-footer{background:#fff;border-top:1px solid #dbe4f3;justify-content:space-between;align-items:center;gap:16px;padding:14px 20px;display:flex}.exam-alert{max-width:none;margin:12px 20px 0}.exam-monitor-blocker{color:#1e3a8a;background:#eff6ff;border-bottom:1px solid #bfdbfe;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 20px;display:flex}.exam-monitor-blocker strong{font-size:14px}.exam-monitor-blocker span{font-size:13px;font-weight:700}.monitor-note{color:var(--muted);font-size:13px}.modal-overlay{z-index:100;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border-radius:16px;width:100%;max-width:480px;padding:24px;box-shadow:0 24px 60px #0f172a40}.modal-card h2{margin:0 0 12px}.modal-badge{color:#6d28d9;background:#ede9fe;border-radius:999px;margin-bottom:10px;padding:6px 10px;font-size:12px;font-weight:800;display:inline-block}.modal-checklist{color:var(--muted);margin:0 0 20px;padding-left:18px}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.document-admin-layout{grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:20px;display:grid}.document-upload-form{align-self:start;gap:12px;display:grid}.material-library{gap:16px;min-width:0;display:grid}.material-layout{grid-template-columns:minmax(230px,300px) minmax(0,1fr);gap:16px;display:grid}.material-list{gap:10px;max-height:620px;display:grid;overflow:auto}.material-item{color:#172033;cursor:pointer;text-align:left;background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:4px;padding:12px;display:grid}.material-item.active{background:#ecfdf5;border-color:#14b8a6;box-shadow:0 0 0 3px #14b8a624}.material-item strong{font-size:15px}.material-item span,.material-item small,.material-preview p,.online-class-head p,.online-class-head small,.whiteboard-toolbar span,.snapshot-card span,.chat-message span{color:#64748b;font-size:13px;font-weight:700}.material-preview{gap:12px;min-width:0;display:grid}.material-preview-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.material-preview h3{color:#111827;margin:0 0 4px;font-size:20px}.material-preview p{margin:0}.material-preview .row-actions{flex-wrap:wrap;justify-content:flex-end}.pdf-viewer{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;width:100%;height:min(72svh,760px);min-height:440px;overflow:hidden}.pdf-viewer-frame{border:0;width:100%;height:100%}.pdf-viewer-state{color:#64748b;text-align:center;justify-content:center;align-items:center;height:100%;padding:20px;font-weight:800;display:flex}.learning-hub,.online-class-panel,.online-main-column{gap:18px;display:grid}.online-class-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.online-class-head h2{color:#111827;margin:0 0 6px;font-size:24px}.online-notice{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:10px 12px;font-weight:800}.online-settings-form{grid-template-columns:minmax(180px,.8fr) minmax(260px,1.2fr) auto;align-items:end;gap:14px;display:grid}.online-room-grid{grid-template-columns:minmax(0,1fr);align-items:start;gap:18px;display:grid}.meeting-panel,.whiteboard-panel,.snapshot-panel,.class-chat-panel{gap:14px;display:grid}.meeting-room-head>div{gap:4px;display:grid}.meeting-room-head span:not(.status-chip){color:#64748b;font-size:13px;font-weight:800}.meeting-lobby{background:linear-gradient(135deg,#f8fafc,#eef6ff);border:1px solid #dbe4f3;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex}.meeting-lobby div{gap:4px;display:grid}.meeting-lobby strong{color:#111827;font-size:18px}.meeting-lobby p{color:#64748b;margin:0;font-size:14px;font-weight:700}.meeting-panel.in-room{box-shadow:none;color:#e5e7eb;z-index:140;background:#08111f;border:0;border-radius:0;grid-template-rows:auto minmax(0,1fr) auto;padding:18px;display:grid;position:fixed;inset:0;overflow:hidden}:-webkit-any(.meeting-panel.in-room:fullscreen,.meeting-panel.in-room:-webkit-full-screen){background:#08111f}:is(.meeting-panel.in-room:fullscreen,.meeting-panel.in-room:fullscreen){background:#08111f}.meeting-panel.in-room .meeting-room-head h2,.meeting-panel.in-room .meeting-room-head span:not(.status-chip){color:#fff}.meeting-panel.in-room .status-chip{color:#a7f3d0;background:#10b9812e}.meeting-panel.in-room .video-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-content:center;min-height:0;overflow:auto}.meeting-panel.in-room .video-tile{min-height:220px}.meeting-panel.in-room .media-controls{background:#0f172ab8;border:1px solid #94a3b83d;border-radius:8px;justify-content:center;align-items:center;padding:10px}.classroom-room-shell{grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:16px;min-height:0;display:grid}.classroom-main-area{grid-template-rows:auto minmax(0,1fr) auto;gap:12px;min-width:0;display:grid}.classroom-toolbar{flex-wrap:wrap;gap:10px;display:flex}.classroom-stage{background:radial-gradient(circle at 20% 10%,#3b82f62e,#0000 28%),#0f172a;border:1px solid #94a3b83d;border-radius:8px;min-height:0;padding:12px;overflow:auto}.classroom-side-rail{grid-template-rows:auto minmax(0,1fr);gap:12px;min-height:0;display:grid}.classroom-side-rail .class-chat-panel,.class-members-panel{box-shadow:none;color:#e5e7eb;background:#0f172acc;border:1px solid #94a3b838;border-radius:8px;padding:14px}.classroom-side-rail .class-chat-panel{position:static}.classroom-side-rail .panel-title h2,.class-members-panel .panel-title h2{color:#fff}.classroom-side-rail textarea{color:#fff;background:#0f172ad6;border-color:#94a3b852}.member-list{gap:8px;display:grid}.member-row{background:#ffffff0f;border:1px solid #ffffff14;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.member-row span{color:#f8fafc;font-weight:800}.member-row small{color:#cbd5e1;font-weight:700}.member-row.active{background:#14b8a62e;border-color:#2dd4bf52}.screen-share-stage,.classroom-empty-stage{aspect-ratio:16/9;color:#e5e7eb;background:#020617;border-radius:8px;justify-content:center;align-items:center;min-height:360px;display:flex;overflow:hidden}.screen-share-stage video{object-fit:contain;width:100%;height:100%}.screen-share-empty,.classroom-empty-stage{text-align:center;justify-items:center;gap:12px;display:grid}.classroom-slides-panel{grid-template-columns:minmax(180px,260px) minmax(0,1fr);gap:12px;min-height:0;display:grid}.classroom-slide-list{gap:8px;max-height:72svh;display:grid;overflow:auto}.classroom-slide-list button{color:#e5e7eb;cursor:pointer;text-align:left;background:#ffffff14;border:1px solid #94a3b838;border-radius:8px;gap:4px;padding:10px;display:grid}.classroom-slide-list button.active{background:#2563eb47;border-color:#60a5fa94}.classroom-slide-list span{color:#cbd5e1;font-size:12px;font-weight:700}.classroom-slide-preview .pdf-viewer{height:calc(100svh - 188px);min-height:520px}.classroom-whiteboard-stage{gap:12px;display:grid}.meeting-panel.in-room .whiteboard-panel,.meeting-panel.in-room .snapshot-panel{box-shadow:none;background:#fffffff5}.student-hub-tabs{flex-wrap:wrap;gap:8px;display:flex}.student-hub-tabs button{color:#334155;cursor:pointer;background:#fff;border:1px solid #dbe4f3;border-radius:999px;padding:10px 14px;font-weight:800}.student-hub-tabs button.active{background:var(--teal);border-color:var(--teal);color:#fff}.schedule-admin,.schedule-user{gap:18px;display:grid}.schedule-hero{justify-content:space-between;align-items:center;gap:18px;display:flex}.schedule-hero h2{margin:0 0 6px;font-size:24px}.schedule-hero p:not(.eyebrow){color:#64748b;max-width:720px;margin:0;font-weight:650;line-height:1.55}.schedule-stat-strip{grid-template-columns:repeat(4,minmax(88px,1fr));gap:10px;min-width:min(520px,100%);display:grid}.schedule-stat-strip.compact{grid-template-columns:repeat(2,minmax(98px,1fr));min-width:min(280px,100%)}.schedule-stat{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:4px;padding:12px;display:grid}.schedule-stat span,.schedule-info-tile span{color:#64748b;text-transform:uppercase;font-size:12px;font-weight:900}.schedule-stat strong{color:#172033;font-size:24px;font-weight:900}.schedule-admin-layout,.schedule-user-layout{grid-template-columns:minmax(300px,390px) minmax(0,1fr);gap:18px;display:grid}.schedule-admin-layout.lower{grid-template-columns:minmax(300px,.9fr) minmax(0,1.2fr)}.schedule-form-panel,.schedule-list-panel,.schedule-detail-panel,.attendance-requests-panel,.schedule-student-detail{align-self:start;gap:16px;display:grid}.schedule-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.schedule-list,.attendance-request-list{gap:12px;display:grid}.schedule-card{background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid #dbe4f3;border-radius:8px;overflow:hidden}.schedule-card.selected,.student-schedule-row.selected{border-color:var(--blue);box-shadow:0 0 0 3px #2563eb24}.schedule-card-main{color:#172033;cursor:pointer;text-align:left;background:0 0;border:0;justify-content:space-between;align-items:flex-start;gap:12px;width:100%;padding:14px;display:flex}.schedule-card-main div,.student-schedule-row div:first-child,.attendance-request-row div,.student-attendance-current div{gap:4px;min-width:0;display:grid}.schedule-card-main strong,.student-schedule-row strong,.attendance-request-row strong{color:#172033;font-size:15px;font-weight:900;line-height:1.35}.schedule-card-main span,.student-schedule-row span,.attendance-request-row span{color:#475569;font-size:13px;font-weight:800}.schedule-card-main small,.student-schedule-row small,.attendance-request-row small,.student-attendance-current small{color:#64748b;font-size:12px;font-weight:750}.schedule-card-footer{border-top:1px solid #e6ebf2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.schedule-card-footer>span{color:#64748b;background:#f8fafc;border-radius:999px;padding:6px 8px;font-size:12px;font-weight:900}.schedule-status-chip{white-space:nowrap;border-radius:999px;flex:none;justify-content:center;align-items:center;min-height:28px;padding:0 10px;font-size:12px;font-weight:900;line-height:1;display:inline-flex}.schedule-status-chip.upcoming,.schedule-status-chip.late{color:#c2410c;background:#fff7ed}.schedule-status-chip.live,.schedule-status-chip.present{color:#047857;background:#ecfdf5}.schedule-status-chip.past,.schedule-status-chip.muted{color:#64748b;background:#f1f5f9}.schedule-status-chip.absent{color:#be123c;background:#fff1f2}.schedule-detail{gap:14px;display:grid}.schedule-detail h3{margin:0;font-size:20px}.schedule-detail p{color:#475569;margin:0;font-weight:650;line-height:1.6}.schedule-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.schedule-info-tile{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:5px;padding:12px;display:grid}.schedule-info-tile strong{color:#172033;font-size:15px;font-weight:900}.schedule-filter-row{flex-wrap:wrap;gap:8px;display:flex}.schedule-filter-row button{color:#334155;cursor:pointer;background:#fff;border:1px solid #dbe4f3;border-radius:999px;min-height:36px;padding:0 12px;font-family:inherit;font-weight:850}.schedule-filter-row button.active{color:#fff;background:#0f766e;border-color:#0f766e}.attendance-request-row{background:#fff;border:1px solid #dbe4f3;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:14px;display:grid}.attendance-request-row p{color:#334155;background:#f8fafc;border-radius:8px;grid-column:1/-1;margin:0;padding:10px 12px;font-size:14px;font-weight:700;line-height:1.5}.student-schedule-row{color:#172033;cursor:pointer;text-align:left;background:linear-gradient(135deg,#fff,#f8fbff);border:1px solid #dbe4f3;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;width:100%;padding:14px;display:flex}.student-schedule-statuses{flex-direction:column;align-items:flex-end;gap:7px;display:flex}.student-attendance-current{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:14px;display:flex}.student-attendance-current span{color:#64748b;text-transform:uppercase;font-size:12px;font-weight:900}.student-attendance-current strong{color:#172033;font-size:15px;font-weight:900}.student-attendance-form{border-top:1px solid #e6ebf2;gap:14px;padding-top:16px;display:grid}.student-attendance-form h3{margin:0;font-size:18px}.schedule-choice-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.schedule-choice-row label{cursor:pointer;background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;align-items:center;gap:8px;margin:0;padding:12px;display:flex}.schedule-choice-row label.selected{color:#0f766e;background:#ecfdf5;border-color:#14b8a6}.schedule-choice-row input{accent-color:#0f766e;width:16px;height:16px;margin:0}.schedule-alert{max-width:none;margin-bottom:0}.schedule-notice{margin:0}.admin-panel,.stat-card,.question-block,.test-row,.material-item{transform-style:preserve-3d;transition:box-shadow .18s,transform .18s,border-color .18s}.admin-panel:hover,.stat-card:hover,.material-item:hover{transform:perspective(900px)translateY(-2px)rotateX(.4deg);box-shadow:0 18px 42px #0f172a1f}.theme-dark.app-shell,.theme-dark.admin-dashboard{color:#e5e7eb;background:linear-gradient(135deg,#14b8a61f,#0000 34%),linear-gradient(225deg,#60a5fa1f,#0000 34%),#0b1120}.theme-dark .topbar,.theme-dark .side-panel,.theme-dark .work-panel,.theme-dark .admin-panel,.theme-dark .login-form-card,.theme-dark .session-card,.theme-dark .stat-card,.theme-dark .question-block,.theme-dark .exam-heading,.theme-dark .student-profile-card{color:#e5e7eb;background:#0f172ae6;border-color:#94a3b83d}.theme-dark .admin-main,.theme-dark .admin-content{background:0 0}.theme-dark .admin-topbar{background:#0f172aeb;border-color:#94a3b838}.theme-dark h1,.theme-dark h2,.theme-dark h3,.theme-dark .topbar h1,.theme-dark .panel-title h2,.theme-dark .exam-heading h2,.theme-dark .online-class-head h2,.theme-dark .material-preview h3,.theme-dark .question-head h3,.theme-dark .empty-state h2{color:#f8fafc}.theme-dark .subtitle,.theme-dark .field-hint,.theme-dark .material-item span,.theme-dark .material-item small,.theme-dark .material-preview p,.theme-dark .online-class-head p,.theme-dark .online-class-head small,.theme-dark .whiteboard-toolbar span,.theme-dark .snapshot-card span,.theme-dark .chat-message span,.theme-dark .progress-text{color:#cbd5e1}.theme-dark input,.theme-dark textarea,.theme-dark .material-item,.theme-dark .test-row,.theme-dark .chat-message,.theme-dark .empty-list{color:#e5e7eb;background:#0f172ab8;border-color:#94a3b83d}.theme-dark .ghost-button,.theme-dark .student-hub-tabs button{color:#e5e7eb;background:#0f172ae0;border-color:#94a3b852}.video-stage{aspect-ratio:16/9;color:#cbd5e1;background:#111827;border-radius:8px;justify-content:center;align-items:center;font-weight:900;display:flex;position:relative;overflow:hidden}.video-stage video{object-fit:cover;width:100%;height:100%}.video-stage span{position:absolute}.meeting-status-row{color:#64748b;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;font-size:13px;font-weight:800;display:flex}.video-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.video-tile{aspect-ratio:16/9;color:#cbd5e1;background:#111827;border-radius:8px;justify-content:center;align-items:center;font-weight:900;display:flex;position:relative;overflow:hidden}.video-tile video{object-fit:cover;width:100%;height:100%}.video-tile span{position:absolute}.video-tile strong,.video-tile small{color:#fff;text-overflow:ellipsis;white-space:nowrap;background:#0f172ac7;border-radius:999px;max-width:calc(100% - 20px);padding:6px 9px;font-size:12px;position:absolute;left:10px;overflow:hidden}.video-tile strong{bottom:10px}.video-tile small{top:10px;left:auto;right:10px}.media-controls,.whiteboard-actions,.whiteboard-tools{flex-wrap:wrap;gap:10px;display:flex}.danger-text{color:#be123c;font-weight:800}.whiteboard-toolbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.whiteboard-toolbar h2{color:#111827;margin:0 0 3px;font-size:22px}.whiteboard-tools{justify-content:flex-end;align-items:center}.color-control,.range-control,.smooth-toggle{white-space:nowrap;background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;align-items:center;gap:8px;min-height:42px;margin:0;padding:0 10px;display:inline-flex}.color-control input{width:42px;height:28px;padding:0}.range-control input{width:120px;padding:0}.smooth-toggle input{accent-color:var(--teal);width:18px;height:18px}.whiteboard-canvas-wrap{background-color:#fff;background-image:linear-gradient(90deg,#94a3b81f 1px,#0000 1px),linear-gradient(#94a3b81f 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:32px 32px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden}.whiteboard-canvas{aspect-ratio:16/9;cursor:crosshair;touch-action:none;width:100%;height:auto;display:block}.hidden-file{display:none}.snapshot-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.snapshot-card{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:10px;padding:10px;display:grid}.snapshot-card img{aspect-ratio:16/9;object-fit:cover;background:#fff;border:1px solid #e2e8f0;border-radius:6px;width:100%}.snapshot-card div:not(.row-actions){gap:2px;display:grid}.snapshot-card .row-actions{justify-content:flex-start}.class-chat-panel{position:sticky;top:24px}.chat-list{gap:10px;max-height:560px;display:grid;overflow:auto}.chat-message{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;gap:6px;padding:10px 12px;display:grid}.chat-message div{gap:1px;display:grid}.chat-message p{color:#172033;overflow-wrap:anywhere;margin:0;font-size:14px;font-weight:650;line-height:1.45}.chat-message-image,.meet-chat-image{object-fit:contain;border-radius:8px;width:min(100%,420px);max-height:260px;display:block}.chat-form{gap:10px;display:grid}.chat-image-picker,.meet-chat-upload{color:#334155;cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;justify-content:center;align-items:center;min-height:42px;padding:0 14px;font-size:14px;font-weight:800;display:inline-flex}.chat-image-picker.disabled,.meet-chat-upload.disabled{cursor:not-allowed;opacity:.58}.chat-image-picker input,.meet-chat-upload input{display:none}.chat-image-preview,.meet-chat-preview{background:#f8fafc;border:1px solid #dbe4f3;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px;display:flex}.chat-image-preview img,.meet-chat-preview img{object-fit:cover;border-radius:6px;width:108px;height:76px}.chat-form-alert{color:#be123c;margin:0;font-size:13px;font-weight:800}.meet-room-shell{color:#e5e7eb;background:#0f172a;border:1px solid #94a3b833;border-radius:12px;grid-template-rows:auto 1fr auto;min-height:min(78svh,820px);display:grid;overflow:hidden}.meet-room-shell--active{min-height:min(92svh,960px)}:-webkit-any(.meet-room-shell--active:fullscreen,.meet-room-shell--active:-webkit-full-screen){border-radius:0;min-height:100svh}:is(.meet-room-shell--active:fullscreen,.meet-room-shell--active:fullscreen){border-radius:0;min-height:100svh}.meet-room-shell--lobby{background:linear-gradient(160deg,#0f172a 0%,#1e293b 55%,#0f172a 100%);min-height:auto;padding:20px}.meet-room-header{border-bottom:1px solid #94a3b82e;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 20px;display:flex}.meet-room-eyebrow{color:#93c5fd;text-transform:uppercase;margin:0 0 4px;font-size:12px;font-weight:800}.meet-room-header h2{color:#f8fafc;margin:0 0 6px;font-size:clamp(20px,3vw,28px)}.meet-room-meta,.meet-room-lead,.meet-room-status{color:#94a3b8;margin:0;font-size:14px;font-weight:600}.meet-room-body{grid-template-columns:minmax(0,1fr);min-height:0;display:grid}.meet-room-body--sidebar{grid-template-columns:minmax(0,1fr) minmax(280px,340px)}.meet-room-stage{gap:10px;min-height:0;padding:14px;display:grid}.meet-room-alert{color:#fecdd3;background:#be123c26;border:1px solid #fb718559;border-radius:8px;margin:0;padding:10px 12px;font-size:14px;font-weight:700}.meet-room-empty,.meet-room-picker{gap:16px;padding:8px 20px 20px;display:grid}.meet-room-card{background:#ffffff0f;border:1px solid #94a3b838;border-radius:12px;gap:12px;padding:16px;display:grid}.meet-room-card h3{color:#f8fafc;margin:0}.meet-room-card p{color:#cbd5e1;margin:0}.meet-room-card-meta{flex-wrap:wrap;gap:8px;display:flex}.meet-video-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-content:center;gap:10px;height:100%;min-height:360px;display:grid}.meet-video-grid[data-participants="1"]{grid-template-columns:1fr}.meet-video-grid[data-participants="2"]{grid-template-columns:repeat(2,minmax(0,1fr))}.meet-video-grid--screen{grid-template-columns:minmax(0,1fr);min-height:420px}.meet-video-grid--thumbs{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));min-height:120px}.meet-video-tile{aspect-ratio:16/10;background:#020617;border:1px solid #94a3b833;border-radius:10px;position:relative;overflow:hidden}.meet-video-tile--featured{aspect-ratio:16/9;min-height:320px}.meet-video-tile video{object-fit:cover;width:100%;height:100%}.meet-video-tile--featured video{object-fit:contain}.meet-video-placeholder{color:#94a3b8;place-items:center;font-size:13px;font-weight:800;display:grid;position:absolute;inset:0}.meet-video-label{background:linear-gradient(#0000,#0f172ae0);padding:10px 12px;position:absolute;bottom:0;left:0;right:0}.meet-video-label strong{color:#f8fafc;font-size:13px}.meet-room-controls{background:#0f172aeb;border-top:1px solid #94a3b82e;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:14px 16px;display:flex}.meet-control-btn{color:#e5e7eb;cursor:pointer;background:#ffffff14;border:1px solid #94a3b847;border-radius:999px;align-items:center;gap:8px;min-height:44px;padding:0 16px;font-family:inherit;font-size:13px;font-weight:800;display:inline-flex}.meet-control-btn--active{background:#2563eb59;border-color:#60a5fa8c}.meet-control-btn--share-active{background:#10b98147;border-color:#34d39980}.meet-control-btn--leave{color:#fff;background:#be123c;border-color:#be123c}.meet-control-icon{font-size:16px;line-height:1}.meet-sidebar{background:#0f172ab8;border-left:1px solid #94a3b82e;grid-template-rows:auto 1fr;min-height:0;display:grid}.meet-sidebar-tabs{border-bottom:1px solid #94a3b82e;gap:6px;padding:10px;display:flex}.meet-sidebar-tabs button{color:#94a3b8;cursor:pointer;background:0 0;border:0;border-radius:8px;flex:1;min-height:38px;padding:0 10px;font-family:inherit;font-weight:800}.meet-sidebar-tabs button.active{color:#dbeafe;background:#2563eb47}.meet-sidebar-panel{min-height:0;padding:12px;overflow:auto}.meet-sidebar-panel--chat{grid-template-rows:1fr auto;display:grid}.meet-member-list{gap:8px;margin:0;padding:0;list-style:none;display:grid}.meet-member-item{background:#ffffff0f;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.meet-member-item--self{background:#14b8a62e}.meet-member-item span{color:#f8fafc;font-weight:800}.meet-member-item small{color:#94a3b8;font-size:12px;font-weight:700}.meet-chat-list{gap:8px;max-height:100%;display:grid;overflow:auto}.meet-chat-empty{color:#94a3b8;text-align:center;margin:0;font-weight:700}.meet-chat-message{background:#ffffff0f;border-radius:8px;gap:6px;padding:10px;display:grid}.meet-chat-message header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:8px;display:flex}.meet-chat-message strong{color:#f8fafc;font-size:13px}.meet-chat-message time{color:#94a3b8;font-size:11px;font-weight:700}.meet-chat-message p{color:#e2e8f0;overflow-wrap:anywhere;margin:0;font-size:14px}.meet-chat-form{border-top:1px solid #94a3b82e;gap:8px;padding-top:10px;display:grid}.meet-chat-form textarea{color:#f8fafc;background:#020617cc;border-color:#94a3b847}.meet-chat-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.meet-chat-image{width:100%;max-height:220px}.meet-chat-upload{color:#e5e7eb;background:#0f172acc;border-color:#94a3b847;min-height:38px}.meet-chat-preview{background:#ffffff0f;border-color:#94a3b838}.meet-chat-preview img{width:86px;height:58px}@media (width<=980px){.app-shell{padding:16px}.topbar{flex-direction:column;align-items:stretch}.session-card{flex-wrap:wrap;align-items:stretch;width:100%}.session-card div{flex:1}.logout-button{width:100%}.content-grid{grid-template-columns:1fr}.side-panel{position:static}.settings-form{grid-template-columns:1fr;align-items:stretch}.form-row.compact{max-width:none}.answer-edit-row{grid-template-columns:1fr}.exam-heading,.action-row,.result-panel{flex-direction:column;align-items:flex-start}.stats{justify-content:flex-start}.login-page{grid-template-columns:1fr}.login-brand{min-height:auto;padding:28px 24px 32px}.login-illustration{display:none}.login-feature-list{gap:8px}.login-form-panel{padding:24px 16px 32px}.admin-dashboard{grid-template-columns:1fr}.admin-sidebar{grid-template-rows:auto auto auto}.admin-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-tests-layout,.document-admin-layout,.material-layout,.online-settings-form,.online-room-grid,.classroom-room-shell,.classroom-slides-panel,.schedule-admin-layout,.schedule-admin-layout.lower,.schedule-user-layout{grid-template-columns:1fr}.online-class-head,.whiteboard-toolbar,.material-preview-head,.meeting-lobby,.schedule-hero,.student-attendance-current{flex-direction:column;align-items:stretch}.schedule-stat-strip,.schedule-stat-strip.compact,.schedule-form-grid,.schedule-detail-grid,.schedule-choice-row{grid-template-columns:1fr;min-width:0}.student-schedule-row,.schedule-card-main{flex-direction:column}.student-schedule-statuses{flex-flow:wrap;align-items:flex-start}.whiteboard-tools{justify-content:flex-start}.class-chat-panel{position:static}.exam-fullscreen-footer{flex-direction:column;align-items:stretch}.meet-room-body--sidebar{grid-template-columns:1fr}.meet-sidebar{border-top:1px solid #94a3b82e;border-left:0;max-height:360px}.meet-room-controls{justify-content:stretch}.meet-control-btn{flex:calc(50% - 8px);justify-content:center}.meet-control-btn--leave{flex-basis:100%}}
