body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{background:#f5f7fb;color:#1f2937;font-family:Inter,Segoe UI,Tahoma,Geneva,Verdana,sans-serif}*,:after,:before{box-sizing:border-box}body{background:#f5f7fb;margin:0;overflow-x:hidden}button{font-family:inherit}@media (max-width:768px){button.chat-widget-toggle{width:55px}aside.sidebar.sidebar-mobile.sidebar-open{display:block!important}span.chat-widget-close-icon{display:none}button.chat-widget-toggle{margin-left:80vw}}.button{align-items:center;background:linear-gradient(120deg,#4f46e5,#6366f1);border:none;border-radius:14px;box-shadow:0 16px 32px #4f46e540;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:6px;justify-content:center;padding:10px 20px;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}.button.secondary{background:#eef2ff;border:1px solid #6366f126;box-shadow:none;color:#4338ca}.button:hover:not(:disabled){filter:brightness(1.02);transform:translateY(-1px)}.button:active:not(:disabled){filter:brightness(.98);transform:translateY(0)}.button:disabled{box-shadow:none;cursor:not-allowed;filter:none;opacity:.6;transform:none}.app-root{background:linear-gradient(180deg,#f5f7fb,#f0f2f8);display:flex;min-height:100vh;overflow:hidden;width:100%}.sidebar{background:#10172a;box-shadow:8px 0 25px #0c1e502e;color:#f8fafc;display:flex;flex-direction:column;gap:24px;padding:28px 20px;width:256px}.sidebar.sidebar-mobile{bottom:0;height:100vh;left:0;max-width:100%;overflow-y:auto;padding:26px 20px 32px;position:fixed;top:0;transform:translateX(-110%);transition:transform .28s ease;width:min(320px,86vw);z-index:1200}.sidebar.sidebar-open{box-shadow:16px 0 35px #0f172a59;transform:translateX(0)}.sidebar-header{gap:16px;justify-content:space-between;position:relative}.sidebar-brand,.sidebar-header{align-items:center;display:flex}.sidebar-brand{gap:12px}.brand-logo{align-items:center;background:linear-gradient(145deg,#6366f14d,#3b82f659);border-radius:14px;box-shadow:inset 0 0 0 1px #ffffff1f;display:inline-flex;height:44px;justify-content:center;width:44px}.brand-logo svg{height:26px;width:26px}.brand-text{color:#f8fafcbf;display:flex;flex-direction:column;font-size:14px}.brand-text strong{color:#fff;font-size:16px}.sidebar-nav{display:flex;flex-direction:column;gap:8px;margin-top:16px;width:100%}.sidebar-nav-mobile{gap:12px;margin-top:24px;width:100%}.sidebar-nav-mobile .sidebar-item{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f172a38;border:1px solid #94a3b82e;border-radius:16px;justify-content:flex-start;padding:14px 16px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;width:100%}.sidebar-nav-mobile .sidebar-item:hover{background:#3b82f638;box-shadow:0 16px 30px #0f172a40;color:#fff;transform:translateY(-1px)}.sidebar-nav-mobile .sidebar-item-active{background:linear-gradient(120deg,#4f46e5,#3b82f6);box-shadow:0 18px 34px #3b82f647;color:#fff}.sidebar-nav-mobile .sidebar-icon{align-items:center;background:#e2e8f026;border-radius:12px;color:#cbd5f5;display:inline-flex;font-size:18px;height:34px;justify-content:center;transition:background .2s ease,color .2s ease;width:34px}.sidebar-nav-mobile .sidebar-item-active .sidebar-icon,.sidebar-nav-mobile .sidebar-item:hover .sidebar-icon{background:#0f172a3d;color:#fff}.sidebar-item{background:#0000;color:#f8fafcbf;display:flex;font-weight:600;gap:10px;padding:12px 14px;transition:background .2s ease,color .2s ease}.sidebar-close,.sidebar-item{align-items:center;border:none;border-radius:12px;cursor:pointer}.sidebar-close{background:#f8fafc1f;color:#fff;display:inline-flex;font-size:22px;height:36px;justify-content:center;transition:background .2s ease,transform .2s ease;width:36px}.sidebar-close:hover{background:#f8fafc33;transform:translateY(-1px)}.sidebar.sidebar-mobile .sidebar-header{align-items:flex-start;flex-direction:column;gap:18px;padding-right:52px}.sidebar.sidebar-mobile .sidebar-brand{justify-content:flex-start;width:100%}.sidebar.sidebar-mobile .brand-text{align-items:flex-start}.sidebar.sidebar-mobile .sidebar-close{margin-left:0;position:absolute;right:12px;top:10px}.sidebar-icon{font-size:18px}.sidebar-item:hover{background:#ffffff14;color:#fff}.sidebar-item-active{background:linear-gradient(120deg,#4f46e5,#818cf8);box-shadow:0 10px 24px #4f46e559;color:#fff}.sidebar-footer{background:#1e293b59;border-radius:16px;color:#e2e8f0d1;font-size:12px;line-height:1.6;margin-top:auto;padding:16px 14px}.sidebar.sidebar-mobile .sidebar-footer{background:linear-gradient(120deg,#3b82f62e,#6366f11f);border-radius:18px;box-shadow:inset 0 0 0 1px #ffffff14;color:#f8fafce6;margin-top:32px;padding:18px}.sidebar-footer p{margin:0}.sidebar-backdrop{border:none;inset:0;position:fixed;z-index:1100}.main-panel{display:flex;flex:1 1;flex-direction:column;gap:24px;padding:32px 36px}.top-toolbar{align-items:center;display:flex;gap:16px;justify-content:space-between}.menu-button{align-items:center;background:#10172a;border:none;border-radius:14px;box-shadow:0 14px 30px #10172a59;color:#fff;cursor:pointer;display:inline-flex;height:46px;justify-content:center;transition:transform .2s ease,box-shadow .2s ease;width:46px}.menu-button:hover{box-shadow:0 18px 40px #10172a66;transform:translateY(-1px)}.menu-icon,.menu-icon:after,.menu-icon:before{background:currentColor;border-radius:999px;content:"";display:block;height:2px;position:relative;transition:background .2s ease;width:20px}.menu-icon:after,.menu-icon:before{left:0;position:absolute}.menu-icon:before{top:-6px}.menu-icon:after{top:6px}.sidebar-backdrop{background:#0f172a8c;cursor:pointer}.toolbar-left{align-items:center;display:flex;gap:16px}.back-button{align-items:center;background:#eef2ff;border:none;border-radius:999px;color:#4338ca;cursor:pointer;display:inline-flex;font-weight:600;gap:10px;padding:10px 18px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.back-button:hover{background:#e0e7ff;box-shadow:0 12px 24px #4f46e52e;transform:translateY(-1px)}.back-button:active{box-shadow:none;transform:translateY(0)}.back-icon{align-items:center;background:#4f46e51f;border-radius:50%;color:#4338ca;display:inline-flex;font-size:12px;height:20px;justify-content:center;width:20px}.back-label{font-size:14px}.toolbar-actions{align-items:center;display:flex;gap:12px}.grade-lock{background:#e2e8f0;border-radius:12px;color:#1f2937;font-weight:600;padding:8px 14px}.grade-lock span{color:#4338ca}.logout-button{background:#ef4444;border:none;border-radius:12px;box-shadow:0 12px 24px #ef444440;color:#fff;cursor:pointer;font-weight:700;padding:10px 18px;transition:all .2s ease}.logout-button:hover{background:#dc2626}.logout-button:active{transform:translateY(1px)}.logout-button.secondary{background:#e2e8f0;box-shadow:none;color:#1f2937}.logout-button.secondary:hover{background:#cbd5f5}.mode-switch{background:#e7e9f5;border-radius:999px;display:inline-flex;gap:6px;padding:6px}.mode-button{background:#0000;border:none;border-radius:999px;color:#475569;cursor:pointer;font-weight:600;padding:8px 18px;transition:all .2s ease}.mode-button-active{background:linear-gradient(120deg,#4f46e5,#6366f1);box-shadow:0 8px 18px #6366f147;color:#fff}.grade-switcher{display:flex;flex-wrap:wrap;gap:8px}.grade-pill{background:#eef1ff;border:1px solid #0000;border-radius:12px;color:#3b3fae;cursor:pointer;font-weight:600;padding:8px 14px;transition:all .2s ease}.grade-pill:hover:not(:disabled){border-color:#6366f1}.grade-pill:disabled{cursor:not-allowed;opacity:.5}.grade-pill-active{background:#3b3fae;box-shadow:0 8px 18px #3b3fae4d;color:#fff}.content-area{display:flex;flex-direction:column;gap:24px}.student-bar{background:#fff;border-radius:20px;box-shadow:0 22px 60px #0f172a14;padding:18px 20px}.student-chip-list{display:flex;flex-wrap:wrap;gap:12px}.student-chip{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;cursor:pointer;display:flex;gap:12px;min-width:160px;padding:10px 16px;transition:all .2s ease}.student-chip:hover{border-color:#818cf8}.student-chip-active{background:linear-gradient(120deg,#4f46e5,#6366f1);border-color:#4f46e5;box-shadow:0 16px 40px #4f46e559;color:#fff}.student-chip-active .student-grade{color:#ffffffd9}.student-avatar{align-items:center;border-radius:14px;display:inline-flex;font-size:20px;height:44px;justify-content:center;width:44px}.student-chip-text{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.student-name{font-size:15px;font-weight:700}.student-grade{color:#475569;font-size:13px;font-weight:500}.student-add-button{background:#0000;border:1px dashed #94a3b8;border-radius:16px;color:#3b82f6;cursor:pointer;font-weight:600;padding:10px 18px;transition:all .2s ease}.student-add-button:hover{background:#3b82f614}.student-home{display:flex;flex-direction:column;gap:28px}.hero-card{grid-gap:24px;background:linear-gradient(120deg,#4f46e5,#4338ca);border-radius:24px;box-shadow:0 30px 70px #3c409559;color:#fff;display:grid;gap:24px;grid-template-columns:minmax(0,1.3fr) minmax(0,1fr);padding:32px}.hero-eyebrow{font-weight:600;letter-spacing:.08em;margin:0 0 12px;opacity:.85;text-transform:uppercase}.hero-title{font-size:32px;font-weight:700;margin:0}.hero-subtitle{color:#fffc;line-height:1.6;margin:14px 0 24px}.hero-brief,.hero-insight{display:flex;flex-direction:column;gap:20px}.hero-insight{justify-content:space-between;position:relative}.hero-progress{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0f172a2e;border-radius:22px;box-shadow:inset 0 0 0 1px #ffffff0f;display:flex;gap:20px;padding:20px}.progress-ring{box-shadow:0 20px 45px #0f172a59;height:140px;position:relative;width:140px}.progress-inner,.progress-ring{align-items:center;border-radius:50%;display:flex;justify-content:center}.progress-inner{background:#0f172ad9;box-shadow:inset 0 0 0 1px #ffffff14;flex-direction:column;gap:6px;height:98px;width:98px}.progress-inner strong{font-size:26px;line-height:1}.progress-inner span{color:#ffffffb3;font-size:12px;letter-spacing:.12em;text-transform:uppercase}.progress-caption{display:flex;flex-direction:column;gap:4px}.progress-caption strong{font-size:24px;line-height:1.1}.progress-caption span{color:#ffffffb3;font-size:13px;letter-spacing:.05em;text-transform:uppercase}.hero-metrics{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.metric-card{background:#0f172a38;border-radius:18px;box-shadow:inset 0 0 0 1px #ffffff0d;display:flex;flex-direction:column;gap:6px;padding:16px}.metric-label{color:#ffffffa6;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.metric-value{font-size:20px}.hero-visual{background:linear-gradient(145deg,#818cf847,#3b82f659);border-radius:20px;box-shadow:inset 0 0 0 1px #ffffff14;min-height:150px;overflow:hidden;position:relative}.visual-shape{display:block;position:absolute}.visual-circle{background:#818cf873;border-radius:50%;height:140px;right:-18px;top:-40px;width:140px}.visual-triangle{border-bottom:90px solid #60a5fa99;border-left:50px solid #0000;border-right:50px solid #0000;bottom:24px;height:0;left:26px;transform:rotate(-12deg);width:0}.visual-dots{background-image:radial-gradient(#ffffff59 2px,#0000 0);background-size:12px 12px;bottom:-30px;height:120px;opacity:.8;right:48px;width:120px}.daily-focus{background:#ffffff1f;border-radius:18px;display:flex;flex-direction:column;gap:12px;padding:18px}.daily-label{color:#fffc;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.daily-focus h2{color:#fff;font-size:24px;margin:0}.daily-focus p{color:#ffffffd9;line-height:1.6;margin:0}.daily-actions{display:flex;flex-wrap:wrap;gap:12px}.daily-actions .button{flex:1 1 160px}.hero-actions{display:flex;flex-wrap:wrap;gap:12px}.hero-actions .button{flex:1 1 180px}@media (max-width:1024px){.hero-card{grid-template-columns:1fr;text-align:center}.hero-brief{align-items:center}.hero-actions{justify-content:center}.hero-insight{align-items:center}.hero-progress{justify-content:center}.progress-caption{align-items:center;text-align:center}.hero-metrics,.hero-visual{width:100%}}.learning-flow{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.flow-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;box-shadow:0 18px 40px #0f172a14;display:flex;flex-direction:column;gap:12px;min-height:200px;padding:20px}.flow-index{color:#4338ca;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.flow-card h3{color:#1f2937;font-size:20px;margin:0}.flow-card p{color:#475569;line-height:1.5;margin:0}.flow-footer{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:auto}.flow-status{background:#eef2ff;border-radius:999px;color:#6366f1;font-size:13px;font-weight:600;padding:6px 14px}.flow-footer .button{flex-shrink:0}@media (max-width:640px){.flow-footer{align-items:flex-start}.flow-footer,.hero-progress{flex-direction:column}.progress-caption{align-items:center;text-align:center}.toolbar-left{align-items:stretch;flex-direction:column}.back-button{justify-content:center;width:100%}}.home-section{background:#fff;border-radius:20px;box-shadow:0 16px 40px #0f172a14;display:flex;flex-direction:column;gap:18px;padding:24px 28px}.section-header{align-items:center;display:flex;gap:16px;justify-content:space-between}.section-header h2{font-size:22px;margin:0}.section-header p{color:#64748b;margin:6px 0 0}.section-header button{background:#0000;border:none;color:#3b82f6;cursor:pointer;font-weight:600}.chip-grid{display:flex;flex-wrap:wrap;gap:10px}.chip{align-items:center;background:#eef2ff;border-radius:999px;color:#3b3fae;display:inline-flex;font-weight:600;gap:8px;padding:10px 18px}.chip-active{background:linear-gradient(120deg,#4f46e5,#6366f1);box-shadow:0 12px 24px #6366f159;color:#fff}.chip-muted{background:#f1f5f9;color:#94a3b8}.quick-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.quick-card{background:#fff;border:2px solid #0000;border-radius:18px;box-shadow:0 18px 45px #0f172a14;display:flex;flex-direction:column;gap:12px;padding:20px}.quick-icon{font-size:26px}.quick-card h3{font-size:18px;margin:0}.quick-card p{color:#475569;line-height:1.4;margin:0}.quick-meta{color:#6366f1}.quick-meta,.quick-status{display:flex;font-size:13px;font-weight:600;justify-content:space-between}.quick-status{align-items:center;color:#475569;flex-wrap:wrap;gap:10px}.status-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;gap:6px;letter-spacing:.02em;padding:6px 12px;text-transform:uppercase}.status-complete{background:#dcfce7;color:#15803d}.status-progress{background:#fef3c7;color:#a16207}.status-reading{background:#e0f2fe;color:#0369a1}.status-ready{background:#f1f5f9;color:#475569}.quick-progress{color:#334155;display:flex;flex-wrap:wrap;font-size:12px;font-weight:600;gap:10px;justify-content:space-between}.quick-actions{display:flex;gap:10px;margin-top:4px}.quick-actions .button{flex:1 1}.quick-empty{background:#eef1ff;border-radius:16px;color:#3b3fae;font-weight:600;padding:24px}.staff-form,.staff-lessons,.staff-overview,.staff-plan,.student-chat,.student-profile,.student-quizzes,.student-reading,.student-subjects{background:#fff;border-radius:22px;box-shadow:0 24px 60px #0f172a1a;display:flex;flex-direction:column;gap:24px;padding:28px 32px}.staff-chat{grid-gap:24px;background:#fff;border-radius:22px;box-shadow:0 24px 60px #0f172a1a;display:grid;gap:24px;grid-template-columns:260px 1fr;padding:28px 32px}.profile-overview{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1.6fr 1fr}.profile-identity{background:linear-gradient(120deg,#eef2ff,#e0e7ff);border-radius:22px;box-shadow:inset 0 0 0 1px #4f46e50d;display:flex;flex-direction:column;gap:18px;padding:24px}.identity-main{align-items:center;display:flex;gap:16px}.identity-avatar{align-items:center;border-radius:20px;box-shadow:0 18px 35px #4f46e53d;display:inline-flex;font-size:34px;height:72px;justify-content:center;width:72px}.identity-main h3{color:#1f2937;font-size:22px;margin:0}.identity-main p{color:#475569;margin:2px 0}.identity-badges{display:flex;flex-direction:column;gap:12px}.badge-pill{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffb3;border-radius:16px;display:flex;gap:12px;padding:10px 14px}.badge-pill span:first-child{font-size:22px}.badge-pill strong{color:#111827;display:block}.badge-pill p{color:#475569;font-size:13px;margin:2px 0 0}.profile-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.stat-card{background:#fff;border-radius:18px;box-shadow:0 16px 35px #0f172a14;display:flex;flex-direction:column;gap:6px;padding:16px}.stat-label{color:#64748b;font-size:13px;font-weight:600}.stat-card strong{color:#312e81;font-size:24px}.stat-sub{color:#475569;font-size:12px}.progress-bars{background:#fff;border-radius:18px;box-shadow:inset 0 0 0 1px #6366f10d;gap:12px;padding:18px}.progress-bars,.progress-row{display:flex;flex-direction:column}.progress-row{gap:6px}.progress-label{color:#4338ca;display:flex;font-size:13px;font-weight:600;justify-content:space-between}.progress-track{background:#e0e7ff;border-radius:999px;height:10px;overflow:hidden;width:100%}.quiz-notes{background:#f8fafc;border-left:3px solid #6366f1;border-radius:12px;color:#475569;font-size:14px;margin-top:8px;padding:10px 12px}.student-reading{gap:24px}.reading-panel{display:flex;flex-direction:column;gap:18px}.reading-page{background:#f8fafc;border-radius:18px;box-shadow:inset 0 0 0 1px #94a3b826;color:#1f2937;font-size:16px;line-height:1.6;padding:24px}.reading-page p{margin:0;white-space:pre-line}.reading-page-title{color:#1f2937;font-size:20px;margin:0 0 12px}.reading-progress{color:#4338ca;display:flex;font-size:14px;font-weight:600;justify-content:flex-end;margin-bottom:16px}.reading-ready{color:#16a34a}.reading-actions{display:flex;gap:16px;justify-content:space-between}.reading-actions button{min-width:160px}.reading-complete-note{background:#dcfce7;border-radius:14px;color:#166534;font-weight:600;padding:14px 18px}.reading-activities{background:#fff;border-radius:16px;box-shadow:inset 0 0 0 1px #94a3b81f;padding:16px 18px}.reading-activities h3{color:#1f2937;font-size:16px;margin:0 0 10px}.reading-activities ul{color:#475569;line-height:1.5;margin:0;padding-left:20px}.staff-plan{gap:32px}.plan-summary h3{color:#1f2937;font-size:18px;margin:0 0 12px}.plan-week-list{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));list-style:none;margin:0;padding:0}.plan-week-list li{align-items:center;background:#f1f5f9;border-radius:14px;color:#1f2937;display:flex;font-weight:600;justify-content:space-between;padding:12px 16px}.plan-table-wrapper{background:#f8fafc99;border-radius:18px;box-shadow:inset 0 0 0 1px #94a3b81f;overflow-x:auto}.plan-table{border-collapse:collapse;min-width:720px;width:100%}.plan-table thead{background:#eef2ff;color:#3b3fae}.plan-table th{font-size:13px;letter-spacing:.05em;padding:14px 18px;text-align:left;text-transform:uppercase}.plan-table td{background:#fff;border-top:1px solid #e2e8f0;padding:16px 18px;vertical-align:top}.plan-table select,.plan-table textarea{background:#fff;border:1px solid #cbd5f5;border-radius:12px;box-shadow:inset 0 2px 6px #6366f114;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.plan-table textarea{min-height:96px;resize:vertical}.plan-table select:focus,.plan-table textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126;outline:none}.plan-module{display:flex;flex-direction:column;gap:4px}.plan-module strong{color:#1f2937;font-size:15px}.plan-module span{color:#64748b;font-size:13px}.plan-competency-grid{display:flex;flex-wrap:wrap;gap:8px}.plan-competency-toggle{background:#f8fafc;border:1px solid #cbd5f5;border-radius:999px;color:#475569;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease}.plan-competency-toggle:hover{border-color:#6366f1;color:#312e81}.plan-competency-toggle-active{background:linear-gradient(120deg,#4f46e5,#6366f1);border-color:#0000;box-shadow:0 10px 20px #6366f140;color:#fff}.quiz-builder{background:#f8fafc;border-radius:18px;box-shadow:inset 0 0 0 1px #94a3b81f;display:flex;flex-direction:column;gap:16px;padding:20px}.quiz-builder h3{color:#1f2937;font-size:18px;margin:0}.quiz-builder-hint{color:#64748b;font-size:13px;margin:0}.quiz-question-editor{background:#fff;border-radius:16px;box-shadow:inset 0 0 0 1px #6366f11a;display:flex;flex-direction:column;gap:12px;padding:16px}.question-editor-header{align-items:center;color:#4338ca;display:flex;font-weight:600;justify-content:space-between}.question-options-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.plan-empty{color:#94a3b8;font-size:13px;font-style:italic}.progress-fill{background:linear-gradient(120deg,#4f46e5,#6366f1);border-radius:999px;height:100%}.progress-fill-secondary{background:linear-gradient(120deg,#10b981,#34d399)}.progress-fill-tertiary{background:linear-gradient(120deg,#f59e0b,#f97316)}.profile-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1.1fr .9fr}.profile-column{gap:18px}.profile-card,.profile-column{display:flex;flex-direction:column}.profile-card{background:#fff;border-radius:18px;box-shadow:0 20px 45px #0f172a17;gap:16px;padding:20px}.profile-card h3{color:#1f2937;font-size:18px;margin:0}.activity-list,.recommended-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.activity-list li,.recommended-list li{background:#f8fafc;border-radius:14px;display:flex;flex-direction:column;gap:6px;padding:12px 14px}.activity-list strong,.recommended-list strong{color:#1f2937}.activity-list span,.recommended-list span{color:#475569;font-size:13px}.recommended-list p{color:#6366f1;font-size:13px;margin:0}.activity-meta{color:#4338ca;display:flex;font-size:12px;justify-content:space-between}.profile-form label textarea{min-height:80px}.request-info{background:#eef2ff;border-radius:14px;color:#312e81;display:flex;flex-direction:column;gap:6px;padding:14px}.request-reason{color:#4338ca;font-size:13px;margin:0}.request-hint{color:#475569;font-size:12px;margin:0}.name-request-form{display:flex;flex-direction:column;gap:12px}.subject-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.subject-card{border-radius:18px;box-shadow:0 16px 35px #0f172a14;color:#111827;display:flex;flex-direction:column;gap:10px;min-height:180px;padding:20px}.subject-icon{font-size:28px}.subject-card h3{font-size:20px;margin:0}.subject-card p{color:#374151;line-height:1.5;margin:0}.subject-meta{color:#1f2937;display:flex;font-size:13px;font-weight:600;justify-content:space-between;margin-top:auto}.student-subjects{display:flex;flex-direction:column;gap:24px}.subject-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:minmax(260px,1fr) 1.2fr}.student-subjects .subject-card{border:2px solid #0000;cursor:pointer;outline:none;transition:transform .2s ease,box-shadow .2s ease,border .2s ease}.student-subjects .subject-card:focus-visible{border-color:#312e81;transform:translateY(-2px)}.subject-card-active{border-color:#312e8159;box-shadow:0 18px 40px #1e293b40;transform:translateY(-2px)}.subject-card-disabled{cursor:not-allowed;filter:grayscale(.15);opacity:.65}.subject-detail{background:#fff;border-radius:18px;box-shadow:0 20px 45px #0f172a14;display:flex;flex-direction:column;gap:18px;min-height:260px;padding:20px}.subject-detail-header h3{align-items:center;display:flex;font-size:22px;gap:8px;margin:0 0 6px}.subject-detail-header p{color:#64748b;line-height:1.5;margin:0}.lesson-list{gap:16px;list-style:none;margin:0;padding:0}.lesson-item,.lesson-list{display:flex;flex-direction:column}.lesson-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;gap:14px;padding:16px}.lesson-body{display:flex;flex-direction:column;gap:8px}.lesson-meta{color:#475569;flex-wrap:wrap;gap:12px;letter-spacing:.04em;text-transform:uppercase}.lesson-status{background:#eef2ff;border-radius:999px;color:#312e81;font-weight:700;letter-spacing:.02em;padding:4px 10px}.lesson-body h4{color:#1f2937;font-size:18px;margin:0}.lesson-body p{color:#334155;line-height:1.6;margin:0}.lesson-reading{color:#4338ca;font-size:13px;font-weight:600}.lesson-actions{display:flex;flex-wrap:wrap;gap:12px}.lesson-actions .button{width:-webkit-fit-content;width:fit-content}@media (max-width:1024px){.subject-layout{grid-template-columns:1fr}.subject-detail{order:2}}.student-quizzes{display:flex;flex-direction:column;gap:24px}.quiz-overview{align-items:flex-start;background:#fff;border-radius:22px;box-shadow:0 24px 55px #0f172a14;display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;padding:26px 28px}.quiz-overview-text{display:flex;flex-direction:column;gap:12px;max-width:520px}.quiz-overview-eyebrow{color:#4f46e5;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.quiz-overview-text h2{color:#0f172a;font-size:26px;margin:0}.quiz-overview-text p{color:#475569;line-height:1.6;margin:0}.quiz-overview-stats{grid-gap:16px;display:grid;flex:1 1;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));min-width:260px}.quiz-overview-card{background:linear-gradient(140deg,#eef2ff,#e0e7ff);border-radius:18px;box-shadow:0 18px 40px #4f46e52e;display:flex;flex-direction:column;gap:6px;padding:18px 16px}.quiz-overview-label{color:#4338ca;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.quiz-overview-value{color:#1e1b4b;font-size:24px}.quiz-overview-hint{color:#475569;font-size:12px}.quiz-main{grid-gap:24px;align-items:flex-start;background:#fff;border-radius:22px;box-shadow:0 20px 45px #0f172a14;display:grid;gap:24px;grid-template-columns:minmax(0,320px) minmax(0,1fr);padding:24px}.quiz-roadmap{display:flex;flex-direction:column;gap:20px}.quiz-roadmap-header{display:flex;flex-direction:column;gap:10px}.quiz-roadmap-header h3{color:#0f172a;font-size:20px;margin:0}.quiz-roadmap-header p{color:#64748b;font-size:13px;line-height:1.5;margin:0}.quiz-roadmap-progress{align-items:center;align-self:flex-start;background:#eef2ff;border-radius:999px;color:#4338ca;display:inline-flex;font-size:12px;font-weight:600;gap:6px;padding:6px 12px}.quiz-timeline{flex-direction:column;list-style:none;margin:0;padding:0}.quiz-step,.quiz-timeline{display:flex;gap:16px;position:relative}.quiz-step{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;cursor:pointer;padding:16px;transition:transform .2s ease,box-shadow .2s ease,border .2s ease}.quiz-step:hover{border-color:#818cf8;box-shadow:0 16px 35px #0f172a1f;transform:translateY(-2px)}.quiz-step-marker{display:flex;flex-shrink:0;justify-content:center;position:relative;width:22px}.quiz-step-marker span{background:#4338ca;border:3px solid #e0e7ff;border-radius:50%;height:12px;margin-top:2px;width:12px}.quiz-step:after{background:linear-gradient(180deg,#94a3b84d,#94a3b800);content:"";height:calc(100% + 14px);left:11px;pointer-events:none;position:absolute;top:20px;width:2px}.quiz-step:last-child:after{display:none}.quiz-step-body{display:flex;flex-direction:column;gap:10px}.quiz-step-head{align-items:flex-start;display:flex;gap:12px;justify-content:space-between}.quiz-step-week{color:#4338ca;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.quiz-step-head h3{color:#111827;font-size:18px;margin:4px 0}.quiz-step-subject{color:#64748b;font-size:12px;font-weight:600}.quiz-step-overview{color:#4b5563;font-size:14px;line-height:1.5;margin:0}.quiz-step-meta{color:#475569;display:flex;flex-wrap:wrap;font-size:12px;font-weight:600;gap:12px}.quiz-step-actions{display:flex;flex-wrap:wrap;gap:10px}.quiz-step-actions .button{flex:1 1 140px}.quiz-step-active{background:#eef2ff;border-color:#4f46e5;box-shadow:0 16px 40px #4f46e538}.quiz-step-complete .quiz-step-marker span{background:#22c55e;border-color:#22c55e2e}.quiz-step-progress .quiz-step-marker span{background:#f59e0b;border-color:#f59e0b2e}.quiz-step-reading .quiz-step-marker span{background:#0ea5e9;border-color:#0ea5e92e}.quiz-step-ready .quiz-step-marker span{background:#cbd5f5}.quiz-step-recommended{background:linear-gradient(135deg,#4f46e51f,#38bdf824);border-color:#4f46e54d}.quiz-panel{gap:20px}.quiz-focus-card,.quiz-panel{display:flex;flex-direction:column}.quiz-focus-card{background:linear-gradient(130deg,#312e81,#4338ca);border-radius:20px;box-shadow:0 24px 60px #182f7659;color:#fff;gap:12px;overflow:hidden;padding:22px;position:relative}.quiz-focus-card:after{background:radial-gradient(circle at top right,#60a5fa59,#0000 55%);content:"";inset:0;pointer-events:none;position:absolute}.quiz-focus-card>*{position:relative;z-index:1}.quiz-focus-badge{align-items:center;background:#ffffff2e;border-radius:999px;display:inline-flex;font-weight:600;gap:6px;padding:6px 12px}.quiz-focus-badge,.quiz-focus-week{font-size:12px;letter-spacing:.08em;text-transform:uppercase}.quiz-focus-week{color:#ffffffd9}.quiz-focus-card h3{font-size:24px;margin:6px 0}.quiz-focus-subject{color:#e2e8f0cc;font-size:13px;font-weight:600}.quiz-focus-status{align-items:center;background:#ffffff2e;border-radius:999px;color:#ffffffe6;display:inline-flex;font-size:12px;font-weight:600;gap:6px;letter-spacing:.06em;padding:4px 10px;text-transform:uppercase}.quiz-focus-card p{color:#e2e8f0eb;line-height:1.6;margin:0}.quiz-focus-meta{color:#e2e8f0d9;display:flex;flex-wrap:wrap;font-size:13px;font-weight:600;gap:12px}.quiz-focus-actions{display:flex;flex-wrap:wrap;gap:10px}.quiz-focus-actions .button{flex:1 1 160px}.quiz-panel>.quiz-card{background:#f9fafc;border:1px solid #e2e8f0;box-shadow:none}.quiz-placeholder{align-items:center;color:#475569;display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:300px;text-align:center}.quiz-placeholder h3{color:#1f2937;font-size:22px;margin:0}@media (max-width:1100px){.quiz-main{gap:22px;grid-template-columns:1fr}}@media (min-width:961px){.menu-button{display:none}}@media (max-width:1024px){.main-panel{gap:20px;padding:28px 22px}.student-bar{padding:16px 18px}}@media (max-width:768px){.app-root{flex-direction:column}.main-panel{gap:18px;padding:22px 16px}.top-toolbar{align-items:stretch;flex-direction:column;gap:12px}.toolbar-actions{flex-wrap:wrap;justify-content:space-between}.sidebar.sidebar-mobile{padding:22px 18px 32px;width:min(360px,90vw)}.student-bar{padding:16px}.student-chip{flex-basis:calc(50% - 12px);flex-grow:1;flex-shrink:1;min-width:auto}.content-area{gap:18px}.staff-form,.staff-lessons,.staff-overview,.staff-plan,.student-chat,.student-profile,.student-quizzes,.student-reading,.student-subjects{border-radius:18px;padding:18px}.subject-layout{gap:18px}.home-section,.subject-detail{padding:18px}.hero-card{padding:26px 22px}.learning-flow{gap:16px;grid-template-columns:1fr}.daily-actions,.hero-actions{flex-wrap:wrap}.daily-actions .button,.hero-actions .button{flex:1 1 45%}.quiz-overview{align-items:stretch;flex-direction:column;gap:18px;padding:22px 20px}.quiz-overview-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));width:100%}.quiz-main{gap:20px;grid-template-columns:1fr;padding:20px}.quiz-step{padding:16px}.quiz-step-meta{align-items:flex-start;flex-direction:column;gap:8px}.quiz-focus-actions .button,.quiz-step-actions .button{flex:1 1 140px}.quiz-focus-card{padding:20px}.chat-widget{bottom:16px;right:16px}}@media (max-width:640px){.toolbar-actions{gap:10px}.sidebar.sidebar-mobile{width:min(340px,92vw)}.sidebar-nav-mobile{gap:10px}.sidebar-nav-mobile .sidebar-item{font-size:15px}.grade-lock{text-align:center;width:100%}.student-bar{padding:14px}.student-chip{flex:1 1 100%}.staff-form,.staff-lessons,.staff-overview,.staff-plan,.student-chat,.student-profile,.student-quizzes,.student-reading,.student-subjects{border-radius:16px;padding:16px}.home-section,.subject-detail{padding:16px}.subject-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.hero-card{padding:24px 18px}.daily-actions .button,.hero-actions .button{flex:1 1 100%}.quiz-overview{padding:20px 16px}.quiz-overview-stats{grid-template-columns:1fr}.quiz-main{gap:18px;padding:18px 16px}.quiz-step{padding:14px}.quiz-step-head{align-items:flex-start;flex-direction:column;gap:6px}.quiz-focus-actions .button,.quiz-step-actions .button{flex:1 1 100%}.quiz-focus-card,.quiz-panel>.quiz-card{padding:18px}.chat-widget{align-items:flex-end;bottom:16px;gap:10px;left:auto;right:16px}.chat-widget-toggle{border-radius:50%;height:56px;justify-content:center;padding:0;width:56px}.chat-widget-label{gap:0}.chat-widget-label span:last-child{display:none}.chat-widget-panel{align-self:flex-end;max-height:calc(100vh - 140px);width:min(360px,calc(100vw - 32px))}}@media (max-width:520px){.daily-actions .button,.hero-actions .button,.student-chip{flex:1 1 100%}.quiz-focus-meta{align-items:flex-start;flex-direction:column;gap:6px}.hero-card{padding:22px 18px;text-align:center}.hero-brief{align-items:center}.learning-flow{gap:14px}.flow-card{padding:18px}.quiz-overview{gap:14px;padding:18px 14px}.quiz-main{gap:16px;padding:16px 14px}.quiz-step-marker span{border-width:2px;height:9px;width:9px}.quiz-step:after{left:8px}.quiz-focus-card,.quiz-panel>.quiz-card{padding:16px}.chat-widget{bottom:12px;left:auto;right:12px}}.quiz-card{background:#f9fafc;border:1px solid #e2e8f0;border-radius:22px;display:flex;flex-direction:column;gap:18px;padding:24px}.quiz-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.quiz-header h3{font-size:22px;margin:0}.quiz-header p{color:#475569;margin:8px 0 0}.quiz-meta{color:#4338ca;display:flex;flex-direction:column;font-weight:600;gap:6px}.quiz-completed{background:#dcfce7;border-radius:999px;color:#166534;font-size:13px;padding:4px 10px}.quiz-questions{display:flex;flex-direction:column;gap:16px}.quiz-hint{background:#fef3c7;border-radius:12px;color:#92400e;font-size:13px;margin-bottom:10px;padding:10px 12px}.quiz-question{background:#fff;border-radius:18px;box-shadow:0 14px 32px #0f172a14;display:flex;flex-direction:column;gap:12px;padding:18px}.question-label{color:#6366f1;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.question-prompt{color:#1f2937;font-size:16px;margin:0}.question-options{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.question-option{background:#eef2ff;border:1px solid #cbd5f5;border-radius:14px;color:#1f2937;cursor:pointer;font-weight:600;padding:10px 14px;text-align:left;transition:all .2s ease}.question-option:hover:not(:disabled){border-color:#4f46e5}.question-option:disabled{cursor:not-allowed;opacity:.75}.option-selected{background:#4f46e5;border-color:#4f46e5;color:#fff}.option-correct{background:#dcfce7;border-color:#16a34a;color:#166534}.option-incorrect{background:#fee2e2;border-color:#dc2626;color:#991b1b}.question-feedback{background:#eef2ff;border-radius:12px;color:#1f2937;font-weight:600;margin:0;padding:10px 12px}.feedback-correct{background:#dcfce7;color:#166534}.feedback-incorrect{background:#fee2e2;color:#991b1b}.feedback-explanation{color:#1e293b;display:block;font-weight:500;margin-top:6px}.quiz-actions{display:flex;flex-wrap:wrap;gap:12px}.quiz-retry,.quiz-submit{border:none;border-radius:12px;cursor:pointer;font-weight:700;padding:12px 20px;transition:all .2s ease}.quiz-submit{background:linear-gradient(120deg,#4f46e5,#6366f1);box-shadow:0 14px 30px #6366f140;color:#fff}.quiz-submit:disabled{background:#cbd5f5;box-shadow:none;color:#64748b;cursor:not-allowed}.quiz-retry{background:#e2e8f0;color:#1f2937}.quiz-retry:hover{background:#cbd5e1}.quiz-summary{background:#eef2ff;border-radius:14px;color:#3730a3;font-weight:600;padding:12px 16px}.auth-shell{align-items:center;background:linear-gradient(180deg,#eef2ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh;padding:32px 16px}.auth-card{background:#fff;border-radius:28px;box-shadow:0 40px 90px #26387c47;gap:24px;max-width:540px;padding:36px;width:100%}.auth-brand,.auth-card{display:flex;flex-direction:column}.auth-brand{gap:12px;text-align:center}.auth-brand h1{color:#312e81;font-size:28px;margin:0}.auth-brand p{color:#475569;margin:0}.auth-switcher{background:#e0e7ff;border-radius:999px;display:flex;gap:6px;padding:6px}.auth-tab{background:#0000;border:none;border-radius:999px;color:#334155;cursor:pointer;flex:1 1;font-weight:700;padding:10px 16px;transition:all .2s ease}.auth-tab-active{background:linear-gradient(120deg,#4f46e5,#6366f1);box-shadow:0 12px 24px #6366f14d;color:#fff}.auth-form{grid-gap:18px;display:grid;gap:18px}.auth-form label{color:#1f2937;display:flex;flex-direction:column;font-weight:600;gap:8px}.auth-form input,.auth-form select{background:#f8fafc;border:1px solid #cbd5f5;border-radius:12px;font-size:15px;padding:12px 14px;transition:border .2s ease,box-shadow .2s ease}.auth-form input:focus,.auth-form select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f140;outline:none}.auth-form button{background:linear-gradient(120deg,#4f46e5,#6366f1);border:none;border-radius:12px;box-shadow:0 14px 30px #6366f147;color:#fff;cursor:pointer;font-weight:700;padding:12px 18px;transition:all .2s ease}.auth-error{color:#dc2626;font-weight:600;margin:0}.auth-success{color:#16a34a;font-weight:600;margin:0}.auth-hint{color:#475569;font-size:13px;line-height:1.6}.staff-form,.student-profile{gap:28px}.library-form,.modal-form,.profile-form{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.library-form label,.modal-form label,.profile-form label{color:#1f2937;display:flex;flex-direction:column;font-weight:600;gap:8px}.library-form input,.library-form select,.library-form textarea,.modal-form input,.modal-form select,.modal-form textarea,.profile-form input,.profile-form select,.profile-form textarea{background:#f8fafc;border:1px solid #cbd5f5;border-radius:14px;font-size:15px;padding:12px 14px;resize:vertical;transition:border .2s ease,box-shadow .2s ease}.lesson-section{background:#f8fafc;border-radius:20px;box-shadow:inset 0 0 0 1px #94a3b81f;display:flex;flex-direction:column;gap:14px;grid-column:1/-1;padding:20px 22px}.lesson-section h3{color:#1f2937;font-size:18px;margin:0}.lesson-segment{background:#fff;border-radius:16px;box-shadow:inset 0 0 0 1px #6366f11f;display:flex;flex-direction:column;gap:12px;padding:16px}.segment-header{align-items:center;display:flex;gap:12px;justify-content:space-between}.segment-header .secondary{min-width:140px}.field-medium{min-height:110px}.field-large{min-height:160px}.field-xl{min-height:240px}.library-form textarea{min-height:140px}.modal-form textarea{min-height:120px}.library-form input:focus,.library-form select:focus,.library-form textarea:focus,.modal-form input:focus,.modal-form select:focus,.modal-form textarea:focus,.profile-form input:focus,.profile-form select:focus,.profile-form textarea:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f140;outline:none}.avatar-picker{display:flex;flex-direction:column;gap:12px;grid-column:1/-1}.avatar-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.avatar-option{align-items:center;background:#f8fafc;border:2px solid #0000;border-radius:16px;cursor:pointer;display:flex;flex-direction:column;font-weight:600;gap:8px;padding:12px 14px;transition:all .2s ease}.avatar-option span{pointer-events:none}.avatar-option-active{border-color:#4f46e5;box-shadow:0 14px 28px #4f46e540}.avatar-emoji{font-size:28px}.modal-actions,.profile-actions{align-items:center;display:flex;gap:12px}.modal-actions button,.profile-actions button{background:linear-gradient(120deg,#4f46e5,#6366f1);border:none;border-radius:12px;box-shadow:0 12px 26px #6366f140;color:#fff;cursor:pointer;font-weight:700;padding:12px 18px;transition:all .2s ease}.modal-actions button.secondary,.profile-actions button.secondary{background:#e2e8f0;box-shadow:none;color:#1f2937}.profile-message{color:#16a34a;font-weight:600}.form-inline{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grade-selector{display:flex;flex-direction:column;gap:12px;grid-column:1/-1}.lesson-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.lesson-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;display:flex;flex-direction:column;gap:12px;padding:18px}.lesson-header{color:#475569;display:flex;font-size:13px;font-weight:600;justify-content:space-between}.lesson-grade{background:#6366f124;border-radius:999px;color:#4f46e5;padding:4px 10px}.lesson-time{color:#9333ea}.lesson-card h3{color:#1e293b;font-size:18px;margin:0}.lesson-card p{color:#475569;line-height:1.55;margin:0}.lesson-meta{color:#0369a1;display:flex;font-size:13px;font-weight:600;justify-content:space-between}.lesson-manage{background:linear-gradient(120deg,#4f46e5,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:600;padding:10px 14px;transition:transform .2s ease,box-shadow .2s ease}.lesson-manage:hover{box-shadow:0 12px 25px #6366f159}.lesson-hint{color:#94a3b8;font-size:12px;font-style:italic}.chat-header{align-items:center;border-radius:12px;display:flex;gap:8px;justify-content:space-between;min-height:56px;padding:8px 12px}.chat-header h2,.chat-header h3{font-size:18px;margin:0}.chat-header p{color:inherit;font-size:13px;margin:0;opacity:.7}.chat-header-messenger{background:linear-gradient(135deg,#0084ff,#0065ff);border:none;box-shadow:0 20px 40px #0084ff52;color:#fff}.chat-header-muted{background:#f8fafce6;border:1px solid #94a3b829;box-shadow:0 16px 30px #0f172a14;color:#1f2937}.chat-header-widget{align-items:stretch;background:linear-gradient(135deg,#0084ff,#0065ff);box-shadow:0 22px 44px #0084ff59;color:#f8fafc;flex-direction:column;gap:10px;padding:14px 16px}.chat-header-widget .chat-header-content{gap:10px}.chat-header-widget .chat-header-actions{justify-content:flex-end}.chat-header-widget>.chat-close{align-self:flex-end}.chat-student{align-items:center;background:#f8fafc;border-radius:16px;box-shadow:0 12px 24px #0f172a14;display:flex;gap:12px;padding:10px 14px}.chat-header-primary .chat-student{background:#f8fafc2e;box-shadow:none}.chat-header-primary .chat-student span,.chat-header-primary .chat-student strong{color:#f8fafc}.chat-header-title{display:flex;flex-direction:column;gap:4px}.chat-header-badges{flex-wrap:wrap;gap:8px}.chat-header-badges,.chat-status{align-items:center;display:inline-flex}.chat-status{background:#6366f11f;border-radius:999px;color:#4338ca;font-size:12px;font-weight:700;gap:6px;letter-spacing:.04em;padding:6px 12px;text-transform:uppercase}.chat-status-dot{background:#22c55e;border-radius:50%;box-shadow:0 0 0 4px #22c55e29;height:8px;width:8px}.chat-status-icon{font-size:14px}.chat-status-inline{font-size:11px;letter-spacing:.02em;padding:4px 10px}.chat-student strong{color:#1f2937;display:block}.chat-student span{color:#475569;display:block;font-size:13px}.chat-thread{background:#f0f2f5;border-radius:18px;display:flex;flex-direction:column;gap:10px;max-height:420px;overflow-y:auto;padding:18px}.chat-thread::-webkit-scrollbar{width:6px}.chat-thread::-webkit-scrollbar-thumb{background:#6366f147;border-radius:999px}.chat-thread::-webkit-scrollbar-track{background:#0000}.chat-row{align-items:flex-end;display:flex;gap:6px;max-width:80%}.chat-row-in{margin-right:auto}.chat-row-out{flex-direction:row-reverse;margin-left:auto}.chat-row-avatar,.chat-row-spacer{height:28px;width:28px}.chat-row-avatar{align-items:center;background:#0084ff;border-radius:50%;box-shadow:0 8px 16px #0884ff40;color:#fff;display:inline-flex;font-size:16px;justify-content:center}.chat-row-spacer{flex-shrink:0;width:8px}.chat-bubble{background:#e4e6eb;border-radius:18px;color:#050505;display:inline-flex;flex-direction:column;gap:4px;line-height:1.5;padding:10px 14px}.chat-row-out .chat-bubble{background:#0084ff;border-radius:18px 18px 4px 18px;box-shadow:0 12px 24px #0884ff40;color:#fff}.chat-row-in .chat-bubble{border-radius:18px 18px 18px 4px}.chat-bubble p{margin:0;white-space:pre-line}.chat-time{color:#0f172a73;font-size:11px;font-weight:600;text-align:right}.chat-row-out .chat-time{color:#ffffffbf}.chat-row-in .chat-time{color:#65676b;text-align:left}.chat-typing{align-items:center;background:#6366f11f;border-radius:14px;color:#4338ca;display:inline-flex;font-size:13px;font-weight:600;gap:10px;margin:12px 0;padding:10px 14px;width:-webkit-fit-content;width:fit-content}.chat-typing-dots{display:inline-flex;gap:4px}.chat-typing-dot{animation:typingBounce 1.2s ease-in-out infinite;background:#6366f1;border-radius:999px;height:8px;opacity:.6;width:8px}.chat-typing-dot:nth-child(2){animation-delay:.15s}.chat-typing-dot:nth-child(3){animation-delay:.3s}@keyframes typingBounce{0%,60%,to{opacity:.5;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.chat-empty{background:#e2e8f0;border-radius:16px;color:#475569;font-weight:600;padding:24px;text-align:center}.chat-input{background:#fff;border:1px solid #d0d5ddcc;border-radius:18px;display:flex;flex-direction:column;gap:10px;padding:14px}.chat-input-subject{align-items:center;color:#394150;display:flex;font-weight:600;gap:8px}.chat-input-subject select{background:#f5f6f7;border:1px solid #d0d5dde6;border-radius:12px;color:#1f2937;flex:1 1;font-family:inherit;font-weight:600;padding:8px 10px}.chat-input-main{align-items:center;background:#f5f6f7;border:1px solid #d0d5dde6;border-radius:999px;display:flex;gap:10px;padding:8px 12px}.chat-input-main textarea{background:#0000;border:none;color:#1f2937;flex:1 1;font-family:inherit;font-size:14px;line-height:1.4;min-height:20px;resize:none}.chat-input-main textarea:focus{outline:none}.chat-send{background:#0084ff;border:none;border-radius:999px;color:#fff;cursor:pointer;font-weight:700;padding:8px 18px;transition:background .2s ease,transform .2s ease}.chat-send:hover{background:#0073e6;transform:translateY(-1px)}.staff-chat-sidebar{display:flex;flex-direction:column;gap:18px}.staff-chat-list{display:flex;flex-direction:column;gap:10px;max-height:460px;overflow-y:auto}.staff-chat-list::-webkit-scrollbar{width:6px}.staff-chat-list::-webkit-scrollbar-thumb{background:#94a3b880;border-radius:999px}.staff-chat-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;cursor:pointer;display:flex;gap:12px;justify-content:space-between;padding:12px 14px;transition:all .2s ease}.staff-chat-item:hover{border-color:#818cf8}.staff-chat-item-active{background:linear-gradient(120deg,#4f46e5,#6366f1);border-color:#4f46e5;box-shadow:0 18px 40px #4f46e559;color:#fff}.staff-chat-item-active .staff-chat-item-grade{color:#ffffffd9}.staff-chat-item-info{align-items:center;display:flex;gap:12px}.staff-chat-item-text{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.staff-chat-item-text strong{font-size:15px}.staff-chat-item-grade{color:#475569;font-size:12px;font-weight:600}.staff-chat-badge{background:#ef4444;border-radius:999px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px}.staff-chat-pane{display:flex;flex-direction:column;gap:24px}.staff-chat-placeholder{background:#f8fafc;border-radius:18px;box-shadow:inset 0 0 0 1px #94a3b82e;color:#475569;padding:32px}.chat-header-content{align-items:center;display:flex;flex:1 1;gap:10px}.chat-header-actions{gap:6px}.chat-header-identity{align-items:center;display:flex;gap:10px}.chat-header-avatar{align-items:center;border-radius:50%;box-shadow:0 10px 20px #0f172a2e;color:#fff;display:inline-flex;font-size:18px;height:34px;justify-content:center;width:34px}.chat-header-nameplate{display:flex;flex-direction:column;gap:2px}.chat-header-nameplate strong{font-size:16px}.chat-header-nameplate span{font-size:12px;opacity:.75}.chat-header-actions{align-items:center;display:inline-flex;gap:8px}.chat-header-actions select{background:#fff;border:1px solid #cbd5f5;border-radius:12px;color:#1f2937;cursor:pointer;font-weight:600;padding:8px 12px;transition:border .2s ease,box-shadow .2s ease}.chat-header-actions select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f140;outline:none}.chat-close{align-items:center;background:#94a3b826;border:none;border-radius:999px;color:#0f172a;cursor:pointer;display:inline-flex;font-size:20px;height:32px;justify-content:center;line-height:1;transition:background .2s ease,transform .2s ease;width:32px}.chat-close:hover{background:#6366f11f;transform:translateY(-1px)}.chat-widget{align-items:flex-end;bottom:24px;display:flex;flex-direction:column-reverse;gap:12px;max-width:calc(100vw - 32px);position:fixed;right:28px;z-index:1200}.chat-widget-toggle{align-items:center;background:linear-gradient(135deg,#0084ff,#0065ff);border:none;border-radius:999px;box-shadow:0 18px 40px #0884ff47;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:12px;max-width:100%;padding:11px 18px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.chat-widget-toggle-open{background:#0065ff}.chat-widget-toggle:hover{box-shadow:0 22px 48px #0884ff59;transform:translateY(-1px)}.chat-widget-label{align-items:center;display:inline-flex;gap:6px}.chat-widget-close-icon{font-size:18px;font-weight:700;line-height:1}.chat-widget-badge{background:#ef4444;border-radius:999px;color:#fff;font-size:12px;font-weight:700;padding:4px 10px}.chat-widget-panel{background:#fff;border-radius:22px;box-shadow:0 40px 80px #0f172a47;display:flex;flex-direction:column;margin-bottom:6px;max-height:74vh;overflow:hidden;width:min(420px,calc(100vw - 40px))}.chat-widget-panel .staff-chat,.chat-widget-panel .student-chat{border-radius:0;box-shadow:none;padding:0}.student-chat-widget{gap:16px;padding:18px}.student-chat-widget .chat-thread{max-height:260px}.student-chat-widget .chat-input{background:#0000;border:none;gap:12px;padding:0}.student-chat-widget .chat-input-main,.student-chat-widget .chat-input-subject select{background:#fff}.staff-chat-widget{display:flex;flex-direction:column;gap:16px;padding:18px}.staff-chat-widget .chat-thread{max-height:260px}.staff-chat-widget .chat-input{background:#0000;border:none;gap:12px;padding:0}.staff-chat-widget .chat-input-main,.staff-chat-widget .chat-input-subject select{background:#fff}.modal-backdrop{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.modal-card{background:#fff;border-radius:24px;box-shadow:0 30px 70px #0f172a40;display:flex;flex-direction:column;gap:20px;max-width:640px;padding:32px;width:100%}.modal-card header h2{margin:0 0 6px}.modal-card header p{color:#475569;margin:0}.modal-card.modal-large{max-width:840px}.modal-actions button{min-width:140px}.app-empty{align-items:center;background:#f5f7fb;display:flex;justify-content:center;min-height:100vh}@media (max-width:1200px){.main-panel{padding:24px}.profile-grid,.profile-overview,.quiz-body{grid-template-columns:1fr}}@media (max-width:900px){.app-root{flex-direction:column}.sidebar{align-items:center;flex-direction:row;gap:16px;justify-content:space-between;padding:16px 20px;width:auto}.sidebar-nav{flex-direction:row;flex-wrap:wrap}.sidebar-item{padding:10px 12px}.hero-card,.staff-chat{grid-template-columns:1fr}.staff-chat-sidebar{order:2}.staff-chat-pane{order:1}}@media (max-width:640px){.main-panel{padding:18px}.top-toolbar{align-items:stretch;flex-direction:column}.grade-switcher{justify-content:center}.student-chip-list{align-items:stretch;flex-direction:column}.section-header{align-items:flex-start;flex-direction:column}.profile-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.chat-widget{align-items:stretch;bottom:18px;left:16px;right:16px}.chat-widget-toggle{justify-content:center;width:100%}.chat-widget-panel{width:100%}.chat-row{max-width:100%}}
/*# sourceMappingURL=main.66477661.css.map*/