@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";.teacher-page{gap:16px;min-height:calc(100vh - 80px);margin-top:80px;padding:16px;display:flex}.teacher-sidebar{background:#fff;border-radius:16px;width:260px;min-width:260px;padding:14px;box-shadow:0 6px 20px #00000014}.teacher-sidebar-header{border-bottom:1px solid #0000000f;margin-bottom:10px;padding:8px 10px 12px}.teacher-sidebar-title{font-size:16px;font-weight:700}.teacher-sidebar-sub{opacity:.7;margin-top:2px;font-size:12px}.teacher-side-section{opacity:.65;margin:10px 10px 6px;font-size:12px}.teacher-side-btn{cursor:pointer;background:#fff;border:1px solid #00000014;border-radius:12px;align-items:center;gap:10px;width:100%;margin:6px 0;padding:10px 12px;font-weight:600;transition:all .15s;display:flex}a.teacher-side-btn.tab-btn{color:inherit;box-sizing:border-box;text-decoration:none}.teacher-side-btn:hover{background:#4a90e20f;border-color:#4a90e240}.teacher-side-btn.active{background:#4a90e21a;border-color:#4a90e259}.teacher-content{flex:1;min-width:0;padding-right:4px;max-height:none!important;overflow:visible!important}.teacher-content-header{background:#fff;border-radius:16px;margin-bottom:14px;padding:14px 18px;box-shadow:0 6px 20px #00000014}.muted{opacity:.72}.tab-panel{display:none}.tab-panel.active{display:block}.tool-card{background:#fff;border-radius:16px;padding:16px 18px;box-shadow:0 6px 20px #00000014}.tool-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=768px){.tool-grid{grid-template-columns:1fr}.teacher-page{flex-direction:column}.teacher-sidebar{width:100%}}.tool-col{flex-direction:column;display:flex}.tool-label{margin:6px 0 8px;font-weight:700;display:block}.tool-textarea{resize:vertical;border:1px solid #0000001a;border-radius:12px;outline:none;width:100%;padding:12px;font-family:inherit;font-size:14px}.tool-input{border:1px solid #0000001f;border-radius:10px;width:min(520px,100%);height:38px;padding:0 12px;font-size:14px}.tool-select{background:#fff;border:1px solid #0000001f;border-radius:10px;outline:none;min-width:90px;height:38px;padding:0 10px;font-size:14px}.tool-actions{flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px;display:flex}.tool-primary,.tool-ghost{cursor:pointer;border:1px solid #0000001a;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:700;transition:all .15s}.tool-primary{color:#fff;background:#4a90e2;border-color:#4a90e259}.tool-primary:hover:not(:disabled){background:#3f83d8}.tool-primary:disabled{opacity:.6;cursor:not-allowed}.tool-ghost{background:#fff}.tool-ghost:hover:not(:disabled){background:#0000000a}.tool-ghost:disabled{opacity:.5;cursor:not-allowed}.tool-output{white-space:pre-wrap;word-break:break-word;background:#0000000a;border:1px solid #0000000f;border-radius:12px;min-height:90px;margin-top:6px;padding:12px;font-family:inherit;font-size:13px;overflow:auto}.upload-box{text-align:center;cursor:pointer;background:#00000005;border:2px dashed #0000001f;border-radius:12px;padding:24px;transition:all .15s}.upload-box:hover{background:#4a90e20a;border-color:#4a90e280}.upload-box.dragover{outline-offset:4px;outline:2px dashed #00000040}.upload-hint{font-size:14px}.back-btn{margin-bottom:12px;color:#fff!important;background:linear-gradient(135deg,#4a90e2,#5aa9ff)!important;border:none!important}.back-btn:hover{box-shadow:0 6px 14px #4a90e259;background:linear-gradient(135deg,#3f83d8,#4a90e2)!important}.mcq-wrap{margin-top:12px}.mcq-card{background:#fff;border:1px solid #0000000f;border-radius:16px;max-width:980px;padding:16px;box-shadow:0 8px 22px #0000001a}.mcq-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.mcq-question{color:#111;flex:1;font-size:18px;font-weight:800;line-height:1.35}.mcq-actions{flex-wrap:wrap;gap:8px;display:flex}.mcq-actions button{cursor:pointer;background:#f5f7ff;border:1px solid #0000001a;border-radius:10px;padding:8px 10px;font-size:13px;font-weight:700;transition:all .15s}.mcq-actions button:hover{background:#e8ecff}.mcq-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid!important}@media (width<=600px){.mcq-grid{grid-template-columns:1fr}}.mcq-option{cursor:pointer;-webkit-user-select:none;user-select:none;border:none;border-radius:14px;justify-content:flex-start;align-items:center;gap:10px;min-height:72px;padding:16px 14px;font-size:16px;font-weight:800;transition:transform .15s,filter .15s,opacity .15s;transform:translateZ(0);color:#fff!important;display:flex!important}.mcq-option:hover{filter:brightness(1.03);transform:scale(1.015)}.mcq-option.a{background:#4f46e5}.mcq-option.b{background:#059669}.mcq-option.c{background:#d97706}.mcq-option.d{background:#dc2626}.mcq-option.selected{outline:3px solid #ffffffd9}.mcq-option.correct{outline:4px solid #22c55ef2;box-shadow:0 0 0 3px #22c55e40}.mcq-option.wrong{filter:grayscale(.1);outline:3px solid #ef4444}.mcq-explain{color:#333;background:#0000000a;border:1px solid #0000000f;border-radius:12px;margin-top:12px;padding:12px;line-height:1.5;display:none}.mcq-explain.show{display:block}.tts-file-layout{grid-template-columns:minmax(0,1fr) minmax(280px,360px);align-items:start;gap:18px;display:grid}@media (width<=960px){.tts-file-layout{grid-template-columns:1fr}}.tts-file-main{min-width:0}.tts-file-aside{background:#4a90e20a;border:1px solid #00000014;border-radius:12px;min-height:120px;padding:12px 14px}.tts-ai-output-label{margin-bottom:8px;font-size:13px}.tts-stage-line{margin-bottom:10px;font-size:13px;line-height:1.5}.tts-output-block{margin-top:8px}.tts-section-title{opacity:.85;margin-bottom:6px;font-size:12px;font-weight:700}.tts-summary-pre,.tts-original-pre{white-space:pre-wrap;word-break:break-word;max-height:220px;margin:0;font-size:13px;overflow:auto}.tts-original-details{margin-top:10px;font-size:13px}.tts-original-summary{cursor:pointer;font-weight:600}.tts-aside-placeholder{margin:0;font-size:13px;line-height:1.45}.tts-file-actions{flex-wrap:wrap}.tts-file-actions button{min-width:120px}.tool-audio-wrap{margin-top:12px}.tool-image-wrap{margin-top:12px;overflow:visible}.tool-image-wrap img{border:1px solid #00000014;border-radius:14px;width:100%;max-width:560px;display:block}html,body{height:auto;overflow-y:auto}#testFileMeta,#ttsFileMeta,#ttiFileMeta{white-space:normal;word-break:break-word;line-height:1.4}.mcq-card+.mcq-card{margin-top:12px}#ttsPrompt{flex:1;min-width:220px}body:has(.il-page){background-color:#06060d}main:has(>.il-page){min-height:calc(100dvh - (var(--navbar-height,64px) - 18px));flex-direction:column;display:flex}.il-page{--il-body-pad-top:calc(var(--navbar-height,64px) - 18px);width:100%;min-height:calc(100dvh - var(--il-body-pad-top));box-sizing:border-box;color:#e8eef6;background-color:#06060d;background-image:radial-gradient(80% 50% at 50% 0,#0ea5e933,#0000 55%),radial-gradient(55% 45% at 100% 45%,#8b5cf629,#0000 50%),linear-gradient(165deg,#0a0a12 0%,#06060d 50%,#08081a 100%);flex-direction:column;flex:1 0 auto;justify-content:safe center;align-items:center;margin:0;padding:80px 24px 64px;display:flex;overflow:hidden auto}.il-page-inner{box-sizing:border-box;text-align:center;flex-direction:column;align-items:center;gap:clamp(1.75rem,4vw,2.75rem);width:100%;max-width:1000px;margin:auto 0;padding:0;display:flex}.il-page-hero{width:100%;max-width:42rem;margin:0 auto}.il-page-hero h1{letter-spacing:-.03em;background:linear-gradient(120deg,#7dd3fc 0%,#c4b5fd 45%,#f0abfc 100%);color:#0000;-webkit-background-clip:text;background-clip:text;margin:0 0 12px;font-size:clamp(1.75rem,4vw,2.35rem);font-weight:800}.il-page-hero .il-subtitle{color:#e0e7ffeb;letter-spacing:.06em;margin:0 0 16px;font-size:1.1rem;font-weight:600}.il-page-hero .il-desc{color:#cbd5e1eb;margin:0 auto;font-size:15px;line-height:1.75}.il-glass{-webkit-backdrop-filter:blur(16px);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 8px 40px #00000059}.il-hero-cta{margin-top:24px}.il-btn-primary{cursor:pointer;color:#0b1020;background:linear-gradient(135deg,#7dd3fc,#c4b5fd);border:none;border-radius:14px;justify-content:center;align-items:center;min-height:48px;padding:0 28px;font-size:16px;font-weight:700;transition:transform .2s,box-shadow .2s,filter .2s;display:inline-flex;box-shadow:0 4px 24px #8b5cf673}.il-btn-primary:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:0 8px 32px #0ea5e973}.il-btn-primary:focus-visible{outline-offset:3px;outline:2px solid #e0e7ff}.il-features-grid{text-align:left;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;margin:0;display:grid}@media (width<=900px){.il-features-grid{grid-template-columns:1fr;gap:16px}}.il-feature-card{height:100%;padding:22px 22px 24px}.il-feature-card h2{color:#f1f5f9;margin:0 0 14px;font-size:1.05rem;font-weight:700;line-height:1.35}.il-feature-card ul{color:#cbd5e1f2;margin:0;padding-left:1.15rem;font-size:14px;line-height:1.65}.il-feature-card li{margin-bottom:8px}.il-bottom-cta{text-align:center;width:100%;max-width:36rem;margin:0 auto;padding:28px 24px 32px}.il-bottom-cta p{color:#e2e8f0f2;letter-spacing:.02em;margin:0 0 18px;font-size:1.12rem;font-weight:600}@media (height<=720px){.il-page{justify-content:flex-start;padding-top:72px;padding-bottom:48px}}.admin-container{max-width:1400px;margin:100px auto 40px;padding:0 24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.admin-header{justify-content:space-between;align-items:center;margin-bottom:25px;display:flex}.admin-header h1{color:#1a1a1a;margin-bottom:5px;font-size:2rem}.admin-header p{color:#666;margin:0}#userSearch{border:1px solid #ddd;border-radius:8px;width:100%;max-width:400px;padding:12px 16px;font-size:1rem;transition:border-color .2s}#userSearch:focus{border-color:#4a90e2;outline:none}.table-responsive{background:#fff;border-radius:12px;width:100%;overflow-x:auto;box-shadow:0 4px 15px #0000000d}.data-table{border-collapse:collapse;white-space:nowrap;width:100%}.data-table th{color:#444;text-transform:uppercase;letter-spacing:.5px;background:#f8f9fa;font-size:.85rem;font-weight:600}.data-table tbody tr:hover{background-color:#fcfcfc}.data-table tbody tr:last-child td{border-bottom:none}.role-select{cursor:pointer;background-color:#fff;border:1px solid #ddd;border-radius:6px;padding:6px 10px;font-size:.95rem}.role-select:hover{border-color:#aaa}.action-btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.9rem;font-weight:500;transition:background-color .2s}.manage-btn{color:#1565c0;background-color:#e3f2fd}.manage-btn:hover{background-color:#bbdefb}.delete-btn{color:#c62828;background-color:#ffebee;padding:4px 10px;font-size:.85rem}.delete-btn:hover{background-color:#ffcdd2}.add-btn{color:#fff;background-color:#4a90e2}.add-btn:hover{background-color:#357abd}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:2000;opacity:0;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;transition:opacity .3s;display:none;position:fixed;top:0;left:0}.modal-overlay.show{opacity:1;display:flex}.modal-box{background:#fff;border-radius:12px;width:650px;max-width:90%;max-height:90vh;padding:30px;transition:transform .3s;overflow-y:auto;transform:translateY(20px);box-shadow:0 10px 40px #0003}.modal-overlay.show .modal-box{transform:translateY(0)}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-title{font-size:1.4rem;font-weight:700}.close-btn{cursor:pointer;color:#888;background:0 0;border:none;font-size:2rem;line-height:1}.close-btn:hover{color:#333}.form-group{flex:1;min-width:120px}.form-group.grow-2{flex:2;min-width:200px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:6px;width:100%;padding:10px;font-size:.95rem}.form-group input:focus,.form-group select:focus{border-color:#4a90e2;outline:none}.form-group input[type=checkbox]{width:auto;margin-right:6px}.small-table th,.small-table td{padding:10px 12px;font-size:.9rem}.reset-container{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:400px;padding:40px;box-shadow:0 4px 20px #0000001a}.reset-container h2{color:#333;margin-top:0;margin-bottom:20px}.form-group{text-align:left;margin-bottom:20px}.form-group label{color:#666;margin-bottom:8px;font-size:.9rem;display:block}.form-group input{box-sizing:border-box;border:1px solid #ddd;border-radius:6px;width:100%;padding:12px;font-size:1rem}.form-group input:focus{border-color:#4a90e2;outline:none}.submit-btn{color:#fff;cursor:pointer;background-color:#4a90e2;border:none;border-radius:6px;width:100%;padding:12px;font-size:1rem;font-weight:500;transition:background-color .2s}.submit-btn:hover:not(:disabled){background-color:#357abd}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.message{margin-top:15px;font-size:.9rem}.message.error{color:#d32f2f}.message.success{color:#2e7d32}:root{--bg-main:#f5f7fb;--bg-pane:#fff;--border-color:#e5e7eb;--text-primary:#1f2933;--text-secondary:#4b5563;--accent-color:#4a90e2;--accent-hover:#357abd;--badge-bg:#eff6ff;--badge-text:#1d4ed8;--radius:18px;--shadow:0 10px 30px #1f293314}html,body,#root{min-height:100vh;margin:0;padding:0}body{background:var(--bg-main);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.5}button{font-family:inherit}.text-center{text-align:center}.modal{z-index:2000;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px #0003}.modal-header h3{margin:0}.modal-header .close{cursor:pointer;color:#666;font-size:24px}.form-group label{color:var(--text-primary);margin-bottom:5px;font-weight:500;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-color);border-radius:6px;width:100%;padding:10px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-color);outline:none}.btn{cursor:pointer;background:var(--bg-pane);color:var(--text-primary);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;padding:10px 16px;font-weight:600;transition:all .2s;display:inline-flex}.btn.primary{background:var(--accent-color);color:#fff}.btn.ghost{border-color:var(--border-color);background:0 0}.btn.btn-sm{padding:6px 12px;font-size:13px}.card{background:var(--bg-pane);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.chip{background:var(--badge-bg);color:var(--badge-text);border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.pill{border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.pill.faint{color:var(--text-secondary);background:#0000000d}.pill.good{color:#166534;background:#dcfce7}.table-responsive{overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border-color);padding:12px}.data-table th{color:var(--text-secondary);font-weight:600}.admin-container{max-width:1400px;margin:calc(var(--navbar-height) + 24px) auto;padding:0 24px}.admin-header{margin-bottom:24px}.admin-header h1{margin:0;font-size:28px}.search-bar-container{margin-bottom:20px}.search-bar-container input{border:1px solid var(--border-color);border-radius:8px;width:100%;max-width:400px;padding:12px 16px;font-size:14px}.role-badge{text-transform:capitalize;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.role-badge.role-admin{color:#92400e;background:#fef3c7}.role-badge.role-teacher{color:#1e40af;background:#dbeafe}.role-badge.role-student{color:#065f46;background:#d1fae5}.action-btn{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 12px;font-size:13px}.action-btn.delete{background:#ef4444}.modal-box{background:#fff;border-radius:12px;width:90%;max-height:90vh;overflow-y:auto}.modal-divider{border:0;border-top:1px solid var(--border-color);margin:20px 0}.form-row{flex-wrap:wrap;gap:12px;display:flex}.form-row .form-group{flex:1;min-width:150px}.form-row .form-group.grow-2{flex:2}@media print{body>*{display:none!important}.modal{background:0 0!important;width:100%!important;height:auto!important;display:block!important;position:static!important;overflow:visible!important}.modal *{visibility:visible!important}.modal-content{width:100%!important;max-width:none!important;box-shadow:none!important;border:none!important;margin:0!important;padding:0!important}}:root{--navbar-height:64px;--nav-bg:#f8fafcf2;--nav-border:#e2e8f0e6;--nav-text:#333;--nav-accent:#4a90e2;--nav-pill-bg:#fffc;--nav-radius:999px;--nav-item-radius:10px;--shadow-sm:0 2px 6px #0000000f;--sidebar-collapsed:0px;--sidebar-expanded:240px;--sidebar-current:var(--sidebar-collapsed);--nav-main-pill-gap:10px;--nav-right-cluster-gap:10px;--nav-top-pad-inline:20px;--nav-main-min-px:480px}body{padding-left:var(--sidebar-current);padding-top:calc(var(--navbar-height) - 18px);transition:padding-left .25s,padding-top .25s}.top-navbar{inset-inline:0;min-height:var(--navbar-height);box-sizing:border-box;background-color:var(--nav-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-bottom:1px solid var(--nav-border);padding-inline:var(--nav-top-pad-inline);z-index:1000;box-shadow:var(--shadow-sm);justify-content:flex-start;align-items:center;gap:0;min-width:0;display:flex;position:fixed;top:0}.navbar-left{align-items:center;gap:var(--nav-right-cluster-gap);min-height:var(--navbar-height);flex:none;min-width:min-content;margin-inline-end:20px;display:flex}.navbar-brand-link{flex-shrink:0}.subject-sidebar{width:var(--sidebar-expanded);border-right:1px solid var(--nav-border);z-index:900;opacity:0;pointer-events:none;background:#f8fafc;flex-direction:column;align-items:center;padding:12px 8px;transition:width .25s,box-shadow .25s;display:flex;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:2px 0 12px #0000000f}.subject-sidebar.open{opacity:1;pointer-events:auto;transform:translate(0)}.subject-toggle-nav{border:1px solid var(--nav-border);cursor:pointer;background:#fff;border-radius:12px;place-items:center;width:40px;height:40px;font-size:18px;line-height:1;transition:all .2s;display:grid}.top-navbar .subject-toggle-nav.nav-top-control{border-radius:10px;flex-shrink:0;width:40px;min-width:40px;height:40px;min-height:40px;font-size:18px}.subject-toggle-nav:hover{color:var(--nav-accent);border-color:var(--nav-accent);box-shadow:0 4px 10px #4a90e22e}.subject-drawer{width:100%;height:calc(100vh - var(--navbar-height) - 12px);border:1px solid var(--nav-border);opacity:0;pointer-events:none;margin-top:calc(var(--navbar-height) - 8px);background:#fff;border-radius:12px;padding:12px;transition:opacity .2s,transform .2s;overflow-y:auto;transform:translate(-8px)}.subject-sidebar.open .subject-drawer{opacity:1;pointer-events:auto;transform:translate(0)}.drawer-title{margin:0;font-weight:700}.drawer-header{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.subject-close{border:1px solid var(--nav-border);cursor:pointer;background:#fff;border-radius:8px;place-items:center;width:28px;height:28px;font-size:16px;line-height:1;transition:all .2s;display:grid}.subject-close:hover{color:var(--nav-accent);border-color:var(--nav-accent);box-shadow:0 4px 10px #4a90e22e}.subject-list{margin:0;padding:0;list-style:none}.subject-list li{margin-bottom:6px}.subject-link{color:var(--nav-text);border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-size:16px;font-weight:600;transition:background-color .2s,color .2s;display:flex}.subject-link:hover{color:var(--nav-accent);background:#eef2f7}.sidebar-section{margin-bottom:12px}.drawer-subtitle{color:#64748b;margin:8px 4px;font-size:13px;font-weight:700}.sidebar-nav{margin:0;padding:0;list-style:none}.sidebar-nav li{margin-bottom:6px}.sidebar-nav-link{width:100%;color:var(--nav-text);border-radius:10px;align-items:center;gap:8px;padding:8px 10px;font-size:16px;font-weight:600;text-decoration:none;transition:background-color .2s,color .2s;display:flex}.sidebar-nav-link:hover,.sidebar-nav-link.active{color:var(--nav-accent);background:#eef2f7}.sidebar-nav-link.nav-teacher-accent-inline.active,.sidebar-nav-link.nav-teacher-accent-inline:hover{color:#4a90e2}.sidebar-nav-link.nav-tools-accent-inline.active,.sidebar-nav-link.nav-tools-accent-inline:hover{color:#7b61ff}.sidebar-nav-link.nav-admin-accent-inline.active,.sidebar-nav-link.nav-admin-accent-inline:hover{color:#ef4444}.sidebar-section-header{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:6px 4px;display:flex}.sidebar-section-header:hover{background:#f1f5f9}.sidebar-section-header .drawer-subtitle{margin:0}.section-chevron{color:#64748b;font-size:14px;transition:transform .2s}.sidebar-section-content{margin-top:4px}.sidebar-section.collapsed .sidebar-section-content{display:none}.sidebar-section.collapsed .section-chevron{transform:rotate(-90deg)}.navbar-icon{justify-content:center;align-items:center;width:28px;min-width:28px;height:28px;min-height:28px;display:flex}.navbar-icon img{object-fit:contain;max-width:100%;max-height:100%;display:block}.navbar-title{color:var(--nav-text);white-space:nowrap;text-overflow:ellipsis;align-items:center;max-width:300px;font-size:24px;font-weight:600;line-height:1.15;display:flex;overflow:hidden}.navbar-title-input{color:inherit;font-size:inherit;font-weight:inherit;background:0 0;border:1px solid #0000;border-radius:4px;outline:none;width:100%;max-width:100%;padding:4px 8px;transition:all .2s}.navbar-title-input:hover{border-color:var(--nav-border)}.navbar-title-input:focus{border-color:var(--nav-accent);background:#fff;box-shadow:0 0 0 2px #4a90e233}.navbar-center{flex:auto;justify-content:center;align-items:center;min-width:0;margin-inline-end:24px;display:flex;overflow:hidden}.navbar-center-measure{justify-content:center;align-items:center;width:100%;min-width:0;max-width:100%;display:flex}.navbar-nav{gap:var(--nav-main-pill-gap);border-radius:var(--nav-radius);background-color:var(--nav-pill-bg);border:1px solid var(--nav-border);white-space:nowrap;flex-wrap:nowrap;flex-shrink:1;align-items:center;max-width:100%;padding:6px 10px;display:flex;overflow:hidden}html.nav-main-center-compact .navbar-center .main-nav{display:none!important}.nav-item{color:var(--nav-text);white-space:nowrap;box-sizing:border-box;flex-shrink:0;text-decoration:none;transition:background-color .2s,color .2s}.top-navbar .main-nav .nav-btn{white-space:nowrap;box-sizing:border-box;border-radius:12px;justify-content:center;align-items:center;min-width:96px;height:40px;min-height:40px;padding:0 18px;font-size:15px;font-weight:500;line-height:1.2;display:inline-flex}.top-navbar .main-nav .nav-item-homework.nav-btn{min-width:max(96px, min-content)}.top-navbar .navbar-right-account .account-btn.action-btn{text-overflow:ellipsis;max-width:min(240px,32vw);overflow:hidden}.nav-item:hover,.nav-item.active{color:var(--nav-accent);background-color:#eef2f7}.nav-item-homework{align-items:center;gap:var(--nav-main-pill-gap);white-space:nowrap;display:inline-flex}.nav-item-homework .nav-badge{color:#fff;letter-spacing:.04em;white-space:nowrap;background:#4a90e2;border-radius:999px;flex-shrink:0;padding:3px 9px;font-size:12px;font-weight:700;line-height:1.2}.nav-item-homework .nav-label{white-space:nowrap;font-weight:500}.navbar-right{align-items:center;gap:var(--nav-right-cluster-gap);flex:none;min-width:0;margin-left:auto;display:flex}.navbar-join-account-cluster{align-items:center;gap:var(--nav-right-cluster-gap);flex-shrink:0;display:flex}.navbar-right-account{flex-shrink:0;align-items:center;display:flex}.navbar-advanced-actions{align-items:center;gap:var(--nav-right-cluster-gap);flex-shrink:0;display:flex}a.il-nav-instant-learn{cursor:pointer;background:linear-gradient(135deg,#0ea5e9,#8b5cf6);border:1px solid #ffffff38;border-radius:50%;flex-shrink:0;justify-content:center;align-self:center;align-items:center;width:40px;min-width:40px;height:40px;min-height:40px;text-decoration:none;transition:transform .2s,box-shadow .2s,filter .2s;display:inline-flex;box-shadow:0 0 12px #8b5cf699}a.il-nav-instant-learn:hover{filter:brightness(1.05);transform:scale(1.1);box-shadow:0 0 18px #8b5cf6d9,0 0 10px #0ea5e959}a.il-nav-instant-learn:focus-visible{outline-offset:2px;outline:2px solid #c4b5fd}a.il-nav-instant-learn.is-active{box-shadow:0 0 14px #0ea5e98c,0 0 12px #8b5cf6a6}a.il-nav-instant-learn .il-nav-sparkles{color:#fff;pointer-events:none;filter:drop-shadow(0 1px 1px #00000040);flex-shrink:0;width:22px;height:22px;display:block}.account-dropdown{position:relative}.account-btn{border:1px solid var(--nav-border);color:var(--nav-text);cursor:pointer;background-color:#0000;border-radius:12px;padding:10px 16px;font-weight:600;transition:all .2s}.top-navbar .navbar-advanced-actions .account-btn.action-btn{text-align:center;text-decoration:none}.account-btn:hover{border-color:var(--nav-accent);color:var(--nav-accent);box-shadow:0 4px 10px #4a90e22e}.account-menu{border:1px solid var(--nav-border);z-index:1001;background-color:#fff;border-radius:12px;flex-direction:column;min-width:150px;display:none;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 10px 30px #0000001a}.account-menu.show{display:flex}.account-menu-item{color:var(--nav-text);text-align:left;cursor:pointer;background-color:#0000;border:none;padding:12px 16px;font-size:14px;transition:background-color .2s}.account-menu-item:hover{background-color:#eef2f7}.account-menu-item:first-child{border-top-left-radius:12px;border-top-right-radius:12px}.account-menu-item:last-child{border-bottom-right-radius:12px;border-bottom-left-radius:12px}.modal{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.modal-content{border:1px solid var(--nav-border);background-color:#fff;border-radius:16px;flex-direction:column;width:400px;max-width:90%;max-height:90vh;margin:5vh auto;padding:0;display:flex;overflow:hidden;box-shadow:0 20px 40px #0003}.modal-header{border-bottom:1px solid var(--nav-border);background:#f8fafc;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.close{color:#64748b;cursor:pointer;font-size:24px;font-weight:700;line-height:1;transition:color .2s}.modal-body{flex:1;min-height:0;padding:24px;overflow-y:auto}.form-group input{border:1px solid var(--nav-border);width:100%;color:var(--nav-text);box-sizing:border-box;background-color:#fff;border-radius:10px;padding:12px;font-size:14px;transition:border-color .2s}.forgot-password,.login-footer a,.register-footer a{color:var(--nav-accent);font-size:13px;font-weight:600;text-decoration:none}.forgot-password:hover,.login-footer a:hover,.register-footer a:hover{text-decoration:underline}.login-submit-btn,.register-submit-btn{background-color:var(--nav-accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;padding:12px;font-size:14px;font-weight:600;transition:background-color .2s,transform .1s}.login-submit-btn:hover,.register-submit-btn:hover{background-color:#357abd;transform:translateY(-1px)}.drawer-title-mobile{display:none}.join-session-container{align-items:center;gap:var(--nav-right-cluster-gap);flex-shrink:0;display:flex}.join-session-container .nav-join-code.action-btn{border:1px solid var(--nav-border);text-align:center;box-sizing:border-box;width:auto;min-width:84px;height:40px;min-height:40px;color:var(--nav-text);background:#fff;border-radius:10px;flex-shrink:0;padding:0 16px;font-size:15px;font-weight:500}.join-session-container .nav-join-btn.action-btn{color:#fff;cursor:pointer;box-sizing:border-box;background:#4f46e5;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;min-width:84px;height:40px;min-height:40px;padding:0 16px;font-size:15px;font-weight:500;display:inline-flex}.navbar-advanced-actions .account-btn.action-btn{box-sizing:border-box;border-radius:12px;justify-content:center;align-items:center;min-width:110px;height:40px;min-height:40px;padding:0 18px;font-size:15px;font-weight:500;display:inline-flex}.navbar-right-account>.account-dropdown>.account-btn.action-btn{box-sizing:border-box;border-radius:10px;justify-content:center;align-items:center;min-width:84px;height:40px;min-height:40px;padding:0 16px;font-size:15px;font-weight:500;display:inline-flex}.account-btn.nav-teacher-accent{color:#4a90e2;border-color:#4a90e2}.account-btn.nav-teacher-accent.is-active{background:#4a90e214;box-shadow:0 0 0 2px #4a90e24d}.account-btn.nav-tools-accent{color:#7b61ff;border-color:#7b61ff}.account-btn.nav-tools-accent.is-active{background:#7b61ff14;box-shadow:0 0 0 2px #7b61ff47}.account-btn.nav-admin-accent{color:#ef4444;border-color:#ef4444}.account-btn.nav-admin-accent.is-active{box-shadow:0 0 0 2px #ef444459}body.workspace-history-open{overflow:hidden}.subject-sidebar .sidebar-section[data-section=main],.subject-sidebar .sidebar-section[data-section=advanced]{display:none}@media (width<=800px){.subject-sidebar .sidebar-section[data-section=main]{display:block}}html.nav-main-center-compact .subject-sidebar .sidebar-section[data-section=main]{display:block!important}@media (width<=1100px){.subject-sidebar .sidebar-section[data-section=advanced]{display:block}.navbar-advanced-actions{display:none!important}}@media (width<=800px){.navbar-center{display:none!important}.navbar-title{text-overflow:ellipsis;white-space:nowrap;max-width:min(42vw,160px);font-size:16px;overflow:hidden}.navbar-icon{width:28px;height:28px}.drawer-title-desktop{display:none}.drawer-title-mobile{display:inline}.top-navbar{padding-inline:max(8px, env(safe-area-inset-left,0px)) max(8px, env(safe-area-inset-right,0px));flex-wrap:nowrap;align-items:center;gap:6px}.navbar-left{flex:auto;min-width:0;margin-inline-end:6px}.navbar-left .navbar-brand-link{flex-shrink:1;min-width:0}.navbar-left .navbar-title{min-width:0}.nav-topbar-right{flex-wrap:nowrap;flex:none;align-items:center;gap:6px;min-width:0;margin-left:auto;display:flex}.nav-topbar-right>a.il-nav-instant-learn{flex-shrink:0;width:44px;min-width:44px;height:44px;min-height:44px}.nav-topbar-right>a.il-nav-instant-learn .il-nav-sparkles{width:20px;height:20px}.nav-join-account-row{flex:auto;align-items:center;gap:6px;min-width:0;display:flex}.join-session-container.nav-code-join-block{flex-shrink:1;min-width:0}.nav-code-join-block{flex:auto;align-items:center;gap:6px;min-width:0;display:flex}.nav-code-join-block .nav-join-code.action-btn{box-sizing:border-box;flex:auto;width:auto;min-width:72px;max-width:88px;height:40px;min-height:40px;padding:0 8px;font-size:14px}.nav-code-join-block .nav-join-btn.action-btn{box-sizing:border-box;flex-shrink:0;min-width:52px;height:40px;min-height:40px;padding:0 10px;font-size:13px}.nav-join-account-row .navbar-right-account{flex-shrink:0;min-width:0;margin-left:auto}.top-navbar .nav-join-account-row .navbar-right-account .account-btn.action-btn{box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap;min-width:44px;max-width:min(132px,36vw);height:40px;min-height:40px;padding:8px 10px;overflow:hidden}}@media (width<=360px){.nav-code-join-block .nav-join-code.action-btn{min-width:56px;max-width:72px;padding:0 6px;font-size:13px}}@media (width>=1440px){:root{--navbar-height:68px;--nav-top-pad-inline:24px}.top-navbar{min-height:68px;padding-left:24px;padding-right:24px}.navbar-left{min-height:68px}.top-navbar .nav-btn,.top-navbar .action-btn,.top-navbar .navbar-right-account .account-btn{height:42px;min-height:42px;font-size:15px}.top-navbar .main-nav .nav-btn,.join-session-container .nav-join-code.action-btn,.join-session-container .nav-join-btn.action-btn,.navbar-advanced-actions .account-btn.action-btn{height:42px;min-height:42px}a.il-nav-instant-learn{width:42px;min-width:42px;height:42px;min-height:42px}a.il-nav-instant-learn .il-nav-sparkles{width:24px;height:24px}.top-navbar .subject-toggle-nav.nav-top-control{width:42px;min-width:42px;height:42px;min-height:42px}}:root{--bg-main:#f5f7fb;--bg-pane:#fff;--border-color:#e5e7eb;--text-primary:#1f2933;--text-secondary:#4b5563;--accent-color:#4a90e2;--accent-hover:#357abd;--badge-bg:#eff6ff;--badge-text:#1d4ed8;--radius:18px;--shadow:0 10px 30px #1f293314;--app-content-max:1400px;--font-body:15px;--font-muted:14px}body{background:var(--bg-main);color:var(--text-primary);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:var(--font-body);min-height:100vh;margin:0;line-height:1.55}.hero{padding-top:calc(var(--navbar-height) + 28px);max-width:var(--app-content-max);z-index:1;margin:0 auto;padding-bottom:20px;padding-left:24px;padding-right:24px;position:relative}.hero-grid{grid-template-columns:1.22fr .92fr;align-items:stretch;gap:32px;margin-top:22px;display:grid}.hero-copy{border:1px solid var(--border-color);background:var(--bg-pane);box-shadow:var(--shadow);border-radius:22px;padding:24px}.eyebrow{color:var(--accent-color);letter-spacing:.08em;text-transform:uppercase;font-weight:700;font-size:var(--font-muted);margin:0 0 10px}h1,h2,h3{color:var(--text-primary);margin:0}h1{font-size:clamp(31px,5.2vw,49px);line-height:1.1}h2{font-size:clamp(24px,2.4vw,32px);line-height:1.2}h3{font-size:clamp(18px,1.6vw,22px);line-height:1.25}.hero-actions{flex-wrap:wrap;gap:14px;margin-bottom:26px;display:flex}.cta,.ghost{border:1px solid #0000;border-radius:14px;justify-content:center;align-items:center;gap:10px;min-height:48px;padding:14px 24px;font-size:15px;font-weight:600;transition:transform .2s,box-shadow .2s,border-color .2s,background .2s;display:inline-flex}.cta{color:#fff;background:linear-gradient(135deg,#4a90e2,#6cb1ff);box-shadow:0 16px 30px #4a90e240}.cta:hover{transform:translateY(-1px)}.ghost{border-color:var(--border-color);color:var(--text-primary);background:#fffc}.ghost:hover{border-color:#4a90e280;transform:translateY(-1px)}.hero-meta{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:18px;display:grid}.meta-card{border:1px solid var(--border-color);background:#f9fbff;border-radius:14px;padding:16px 18px}.meta-label{color:var(--text-secondary);font-size:var(--font-muted);margin-bottom:6px}.meta-value{font-weight:700}.hero-panel{border:1px solid var(--border-color);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:var(--shadow);background:#ffffffeb;border-radius:22px;flex-direction:column;padding:24px;display:flex}.panel-header{justify-content:space-between;align-items:center;margin:0;padding:0 0 16px;display:flex}.chip{background:var(--badge-bg);color:var(--badge-text);font-weight:600;font-size:var(--font-muted);border-radius:12px;padding:9px 14px}.panel-body{flex-direction:column;gap:18px;padding:0;display:flex}.panel-row{border:1px solid var(--border-color);background:#f9fbff;border-radius:14px;padding:18px 20px}.panel-label{color:var(--text-secondary);font-size:var(--font-muted);margin:0}.panel-value{font-weight:700;font-size:var(--font-body);margin:6px 0 0}.panel-list{color:var(--text-secondary);font-size:var(--font-body);margin:10px 0 0 18px;padding:0;line-height:1.65}.panel-row.badges{background:#fff;flex-wrap:wrap;gap:8px;display:flex}.badge{border:1px solid var(--border-color);font-size:var(--font-muted);background:#eef2f7;border-radius:10px;padding:9px 12px}.tiny-link{color:var(--accent-color);font-weight:600}.content{max-width:var(--app-content-max);z-index:1;margin:0 auto 80px;padding-left:24px;padding-right:24px;position:relative}.section{border:1px solid var(--border-color);background:var(--bg-pane);box-shadow:var(--shadow);border-radius:22px;margin-top:56px;padding:32px}.section.alt{background:#f9fbff}.section-heading{margin-bottom:20px}.section-desc{color:var(--text-secondary);font-size:var(--font-muted);margin:10px 0 0;line-height:1.6}.card-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;display:grid}.card{border:1px solid var(--border-color);background:#fff;border-radius:16px;flex-direction:column;gap:14px;padding:24px;display:flex;box-shadow:0 8px 20px #1f29330a}.card-top{justify-content:space-between;align-items:center;display:flex}.card-desc{color:var(--text-secondary);font-size:var(--font-muted);margin:0;line-height:1.6}.card-list{color:var(--text-secondary);font-size:var(--font-body);margin:0 0 10px 18px;line-height:1.65}.card .full{justify-content:center;width:100%}.feature-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.feature{border:1px solid var(--border-color);background:#fff;border-radius:16px;padding:18px;box-shadow:0 8px 20px #1f29330a}.feature-icon{margin-bottom:8px;font-size:22px}.feature p{color:var(--text-secondary);font-size:var(--font-muted);margin:8px 0 0}.cta-section{background:linear-gradient(135deg,#4a90e21f,#6cb1ff29)}.cta-card{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.cta-actions{gap:12px;display:flex}.footer{max-width:var(--app-content-max);color:var(--text-secondary);font-size:var(--font-muted);border-top:1px solid var(--border-color);align-items:center;gap:12px;margin:24px auto 40px;padding:18px 24px;display:flex}.footer-text{margin:0}@media (width<=900px){.hero-grid{grid-template-columns:1fr}}@media (width<=640px){.hero{padding-top:calc(var(--navbar-height) + 16px);padding-left:16px;padding-right:16px}.content{padding-left:16px;padding-right:16px}.section{padding:22px}}@media (width>=1440px){body{font-size:15px}.app-container,.page-container,.main-container,.hero,.content,.footer{max-width:1400px}}:root{--bg-main:#f5f5f5;--bg-pane:#fff;--bg-header:#f0f0f0;--border-color:#e0e0e0;--text-primary:#333;--text-secondary:#666;--accent-color:#4a90e2;--accent-hover:#357abd;--border-radius:8px;--border-radius-lg:12px;--border-subtle:#e5e5e5;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 2px 8px #0000001a;--transition-fast:.15s ease;--grid-col-left:1fr;--grid-col-center:1.15fr;--grid-col-right:1fr;--grid-min-left:200px;--grid-min-center:260px;--grid-min-right:220px;--header-height:50px;--shadow:0 2px 4px #0000001a;--shadow-hover:0 4px 8px #00000026}body.ai-workspace-page{padding-top:0!important}@media (width>=769px){body.ai-workspace-page{height:100vh;overflow:hidden}.main-grid-container{height:calc(100vh - var(--navbar-height) - 16px - 14px);margin-bottom:14px;padding:10px 16px 20px}}@media (width>=1440px){.app-container,.page-container,.main-container{box-sizing:border-box;max-width:1400px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}.main-grid-container{box-sizing:border-box;max-width:1400px;margin-left:auto;margin-right:auto;padding:10px 24px 20px}body.ai-workspace-page{font-size:15px}}body{background-color:var(--bg-main);color:var(--text-primary);min-height:100vh;margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji;font-size:15px;line-height:1.5;overflow-y:auto}.main-grid-container{grid-template-columns:minmax(var(--grid-min-left), var(--grid-col-left)) minmax(var(--grid-min-center), var(--grid-col-center)) minmax(var(--grid-min-right), var(--grid-col-right));height:calc(100vh - var(--navbar-height) - 16px);margin-top:calc(var(--navbar-height) + 8px);box-sizing:border-box;grid-template-rows:repeat(2,minmax(0,1fr));grid-template-areas:"analysis homework chat""guidelines homework chat";align-items:stretch;gap:clamp(8px,1vw,12px);width:100%;max-width:100%;padding:10px 16px 16px;display:grid;position:relative;overflow:hidden}.pane-1{grid-area:homework}.pane-2{grid-area:analysis}.pane-3{grid-area:guidelines}.pane-4{grid-area:chat}.grid-pane{background-color:var(--bg-pane);border-radius:var(--border-radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);box-sizing:border-box;resize:none;flex-direction:column;width:100%;min-width:220px;height:100%;min-height:160px;display:flex;position:relative;overflow:hidden}.grid-pane::-webkit-resizer{display:none}.pane-content{min-width:0;min-height:0;overflow:auto}.main-grid-container>.grid-pane{min-width:0;min-height:0}.grid-resizer{cursor:col-resize;z-index:5;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;width:12px;margin-left:-6px;display:flex;position:absolute;top:0;bottom:0}.grid-resizer:before{content:"";background:var(--border-color);border-radius:2px;width:2px;height:40px;transition:background-color .15s,box-shadow .15s;box-shadow:0 0 0 1px #00000008}.grid-resizer:hover:before{background:var(--accent-color);box-shadow:0 0 0 1px #4a90e233}@media (width<=1100px){.main-grid-container{grid-template-columns:minmax(180px,1fr) minmax(220px,1.1fr) minmax(180px,1fr)}}.pane-header{background-color:var(--bg-header);border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.pane-header h3{color:var(--text-primary);margin:0;font-size:20px;font-weight:700}.pane-content{flex:1;min-height:0;padding:16px;overflow:auto}.pane-content::-webkit-scrollbar{width:8px;height:8px}.pane-content::-webkit-scrollbar-track{background:var(--bg-header)}.pane-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.pane-content::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.homework-upload-area{flex-direction:column;justify-content:center;align-items:center;height:100%;min-height:200px;display:flex}.upload-btn{background-color:var(--accent-color);color:#fff;border-radius:var(--border-radius);cursor:pointer;border:none;margin-bottom:16px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s}.upload-btn:hover{background-color:var(--accent-hover);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.homework-image-container{flex:1;justify-content:center;align-items:center;width:100%;max-width:100%;display:flex;overflow:auto}.homework-image-container img{object-fit:contain;border-radius:var(--border-radius);max-width:100%;max-height:100%;box-shadow:var(--shadow)}.analysis-content{color:var(--text-primary);font-size:14px;line-height:1.6}.analysis-content p{margin:0}.guidelines-content{color:var(--text-primary);font-size:14px;line-height:1.8}.guidelines-content ol{margin:0;padding-left:20px}.guidelines-content li{margin-bottom:8px}.chat-pane-content{flex-direction:column;height:100%;padding:0;display:flex}.chat-messages{flex-direction:column;flex:1;gap:12px;min-height:0;padding:12px 16px 10px;display:flex;overflow-y:auto}.chat-assistant-helper{border-top:1px solid var(--border-color);background:linear-gradient(180deg, #f8fafcf2 0%, var(--bg-pane) 100%);flex-shrink:0}.chat-assistant-helper__toggle{cursor:pointer;width:100%;font:inherit;color:var(--text-primary);text-align:left;background:0 0;border:0;align-items:center;gap:10px;margin:0;padding:10px 14px;font-size:13px;font-weight:600;display:flex}.chat-assistant-helper__toggle:hover{background:#4a90e20f}.chat-assistant-helper__chevron{width:1.25em;color:var(--text-secondary);flex-shrink:0;justify-content:center;font-size:12px;transition:transform .2s;display:inline-flex}.chat-assistant-helper--collapsed .chat-assistant-helper__chevron{transform:rotate(-90deg)}.chat-assistant-helper__toggle-label{flex:1;min-width:0}.chat-assistant-helper__body{border-top:1px solid #e2e8f0d9;padding:0 14px 12px}.chat-assistant-helper__hint{color:var(--text-secondary);margin:10px 0 8px;font-size:11px;line-height:1.4}.chat-assistant-helper__suggestions{flex-direction:column;gap:6px;margin:0 0 12px;padding:0;list-style:none;display:flex}.chat-assistant-helper__line{border:1px solid var(--border-subtle);width:100%;font:inherit;color:var(--text-primary);text-align:left;cursor:pointer;background:#fff;border-radius:10px;margin:0;padding:8px 10px;font-size:13px;line-height:1.45;transition:border-color .15s,box-shadow .15s}.chat-assistant-helper__line:hover{border-color:var(--accent-color);box-shadow:0 1px #4a90e21f}.chat-assistant-helper__chips{flex-wrap:wrap;gap:8px;display:flex}.chat-assistant-helper__chip{border:1px solid var(--border-color);font:inherit;color:var(--accent-color);cursor:pointer;background:#fff;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:600;transition:background-color .15s,border-color .15s}.chat-assistant-helper__chip:hover{background:#4a90e214;border-color:#4a90e273}.pane-4 .chat-input-area{border-top:1px solid var(--border-color)}.message{align-items:flex-start;gap:8px;max-width:85%;display:flex}.message.user{flex-direction:row-reverse;align-self:flex-end}.message.ai{align-self:flex-start}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.message.user .message-avatar{background-color:var(--accent-color);color:#fff}.message.ai .message-avatar{background-color:var(--bg-header);color:var(--text-primary)}.message-content{background-color:var(--bg-header);word-wrap:break-word;border-radius:12px;max-width:100%;padding:12px 16px;position:relative}.message.user .message-content{color:var(--text-primary);background-color:#e3f2fd}.message.ai .message-content{background-color:var(--bg-header);color:var(--text-primary)}.message-text{font-size:14px;line-height:1.5}.message-time{color:var(--text-secondary);text-align:right;margin-top:4px;font-size:11px}.message.ai .message-time{text-align:left}.chat-input-area{background-color:var(--bg-pane);flex-direction:column;flex-shrink:0;gap:8px;padding:10px 16px 12px;display:flex}.icon-toolbar{border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:8px;margin-bottom:8px;padding:8px 0;display:flex}.icon-toolbar-item{border-radius:var(--border-radius);cursor:pointer;background-color:#fff;border:2px solid;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:all .2s;display:flex}.icon-toolbar-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.icon-toolbar-item:active{transform:translateY(0)}.chat-input-area textarea{resize:vertical;background-color:var(--bg-pane);border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;min-height:60px;max-height:120px;color:var(--text-primary);box-sizing:border-box;outline:none;padding:12px;font-family:inherit;font-size:14px;line-height:1.4;transition:border-color .2s}.chat-input-area textarea:focus{border-color:var(--accent-color);box-shadow:0 0 0 2px #4a90e21a}.chat-actions{justify-content:space-between;align-items:center;display:flex}.status{color:var(--text-secondary);font-size:12px}.status.error{color:#d32f2f}.status.success{color:#2e7d32}.input-buttons{align-items:center;gap:8px;display:flex}.chat-actions button{background-color:var(--accent-color);color:#fff;cursor:pointer;transition:background-color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);border:none;border-radius:999px;padding:7px 16px;font-size:13px;font-weight:600}.chat-actions .send-btn{color:#111827;border:1px solid var(--border-color);background-color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:40px;padding:7px 12px;display:flex}.chat-actions .send-btn svg path{stroke-width:1px;fill:#111827!important;stroke:#111827!important}.chat-actions .send-btn svg{fill:currentColor;width:18px;height:18px;display:block}.chat-actions .send-btn:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px);background-color:#f3f4f6!important}.chat-actions button:hover{background-color:var(--accent-hover);box-shadow:var(--shadow);transform:translateY(-1px)}.chat-actions button:active{transform:translateY(0)}.voice-btn{color:#fff;border-radius:var(--border-radius);cursor:pointer;background-color:#ff6b6b;border:none;min-width:40px;padding:8px 12px;font-size:16px;transition:all .2s}.voice-btn:hover{box-shadow:var(--shadow);background-color:#ff5252;transform:translateY(-1px)}.chat-icon-btn{color:var(--text-primary);border:1px solid var(--border-color);background-color:#fff;border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;padding:0;font-size:18px;display:flex}.chat-icon-btn:hover{box-shadow:var(--shadow-sm);background-color:#f3f4f6}.send-btn{color:#111827;border:1px solid var(--border-color);background-color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:40px;padding:7px 12px;display:flex}.send-btn svg{fill:currentColor;width:18px;height:18px;display:block}.send-btn:hover{box-shadow:var(--shadow-sm);background-color:#f3f4f6}.voice-btn.recording{background-color:#4caf50;animation:1.5s infinite pulse}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.modal{z-index:2000;background-color:#00000080;width:100%;height:100%;display:none;position:fixed;top:0;left:0}.modal-content{background-color:var(--bg-pane);border:1px solid var(--border-color);border-radius:var(--border-radius);width:400px;max-width:90%;box-shadow:var(--shadow-hover);margin:10% auto;padding:0}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{color:var(--text-primary);margin:0;font-size:1.1em}.close{color:var(--text-secondary);cursor:pointer;font-size:24px;font-weight:700;transition:color .2s}.close:hover{color:var(--text-primary)}.modal-body{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-primary);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.form-group input{background-color:var(--bg-pane);border:1px solid var(--border-color);border-radius:var(--border-radius);width:100%;color:var(--text-primary);box-sizing:border-box;padding:12px;font-size:14px;transition:border-color .2s}.form-group input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #4a90e21a}.form-options{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.remember-me,.agree-terms{color:var(--text-secondary);cursor:pointer;align-items:center;font-size:13px;display:flex}.remember-me input,.agree-terms input{width:auto;margin-right:8px}.forgot-password{color:var(--accent-color);font-size:13px;text-decoration:none;transition:color .2s}.forgot-password:hover{color:var(--accent-hover);text-decoration:underline}.login-submit-btn,.register-submit-btn{background-color:var(--accent-color);border-radius:var(--border-radius);color:#fff;cursor:pointer;border:none;width:100%;padding:12px;font-size:14px;font-weight:500;transition:background-color .2s}.login-submit-btn:hover,.register-submit-btn:hover{background-color:var(--accent-hover)}.login-footer,.register-footer{text-align:center;border-top:1px solid var(--border-color);margin-top:20px;padding-top:20px}.login-footer p,.register-footer p{color:var(--text-secondary);margin:0;font-size:13px}.login-footer a,.register-footer a{color:var(--accent-color);text-decoration:none;transition:color .2s}.login-footer a:hover,.register-footer a:hover{color:var(--accent-hover);text-decoration:underline}@media (width<=768px){.main-grid-container{height:auto;min-height:calc(100vh - var(--navbar-height));flex-direction:column;grid-template:none;gap:12px;margin-bottom:12px;padding-bottom:40px;display:flex;overflow-y:auto}.grid-resizer{display:none}.pane-1,.pane-2,.pane-3{flex:none;height:auto!important;min-height:0!important}.pane-1{order:1}.pane-1 .homework-upload-area{min-height:120px;padding:10px}.pane-2{order:2}.pane-3{order:3}.pane-4{flex-shrink:0;order:4;height:500px}.navbar-center{display:none}.navbar-title{font-size:16px}}.sources-list-hidden,.explore-page-hidden,.request-preview-area-hidden{display:none!important}.history-modal-content{flex-direction:column;max-width:600px;max-height:80vh;display:flex}.history-modal-body{flex:1;min-height:300px;max-height:calc(80vh - 100px);padding:20px;overflow-y:auto}.chat-history{padding:0}.history-open{cursor:pointer;flex:1;min-width:0}.history-item{background-color:var(--bg-header);border-radius:var(--border-radius);cursor:pointer;border:1px solid var(--border-color);margin-bottom:8px;padding:12px;transition:all .2s}.history-item:hover{box-shadow:var(--shadow);background-color:#f5f5f5;transform:translateY(-1px)}.history-item.active{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.history-item.active .history-title,.history-item.active .history-preview,.history-item.active .history-time{color:#fff}.history-title-row{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.history-title{color:var(--text-primary);flex:1;margin-bottom:4px;font-size:14px;font-weight:600}.history-delete-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:all .2s}.history-delete-btn:hover{color:#d32f2f;background-color:#d32f2f1a}.history-preview{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;margin-bottom:4px;font-size:12px;overflow:hidden}.history-time{color:var(--text-secondary);font-size:11px}.no-history{text-align:center;color:var(--text-secondary);margin-top:40px;padding:20px;font-style:italic}.icon-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.icon-option{background-color:var(--bg-header);border:2px solid var(--border-color);border-radius:var(--border-radius);cursor:pointer;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto;font-size:24px;transition:all .2s;display:flex}.icon-option:hover{background-color:var(--bg-pane);border-color:var(--accent-color);transform:scale(1.05)}.message-text p{margin:0 0 8px}.message-text p:last-child{margin-bottom:0}.message-text ul,.message-text ol{margin:4px 0;padding-left:24px}.message-text li{margin-bottom:4px}.message-text code{background:#0000001a;border-radius:4px;padding:2px 4px;font-family:monospace}.message-text pre{background:#f0f0f0;border-radius:8px;padding:8px;overflow-x:auto}.message-text{word-break:break-word}.history-item{justify-content:space-between;align-items:center;display:flex;position:relative}.history-del-btn{cursor:pointer;opacity:.4;z-index:10;background:0 0;border:none;padding:8px;font-size:16px;transition:opacity .2s,transform .2s}.history-del-btn:hover{opacity:1;color:#ff4d4f;transform:scale(1.2)}:root{--bg-main:#f5f7fb;--bg-pane:#fff;--border-color:#e5e7eb;--text-primary:#1f2933;--text-secondary:#4b5563;--accent-color:#4a90e2;--accent-hover:#357abd;--badge-bg:#eff6ff;--badge-text:#1d4ed8;--radius:18px;--shadow:0 10px 30px #1f293314;--muted-bg:#f9fbff;--muted-bg-2:#eef2f7;--good-bg:#ecfdf3;--good-text:#047857;--warn-bg:#fffbeb;--warn-text:#92400e;--bad-bg:#fef2f2;--bad-text:#991b1b}body{background:var(--bg-main);color:var(--text-primary);min-height:100vh;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}a{color:inherit;text-decoration:none}.bg-blob{filter:blur(110px);opacity:.25;z-index:0;pointer-events:none;border-radius:50%;position:fixed}#globalNav{z-index:5;position:relative}.topbar{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.title-block{max-width:1400px}.lede{color:var(--text-secondary);margin:12px 0 0;font-size:16px;line-height:1.6}.actions{flex-wrap:wrap;justify-content:flex-end;gap:12px;margin-top:4px;display:flex}.btn.primary{color:#fff;background:linear-gradient(135deg,#4a90e2,#6cb1ff);box-shadow:0 16px 30px #4a90e240}.btn.primary:hover{background:linear-gradient(135deg, var(--accent-hover), #5aa6ff)}.btn.ghost:hover{border-color:#4a90e273}.btn-sm{padding:8px 12px;font-size:13px}.grid{grid-template-columns:minmax(0,1.65fr) minmax(300px,1fr);align-items:start;gap:20px;display:grid}@media (width>=1200px){.grid{grid-template-columns:minmax(880px,1.65fr) minmax(360px,1fr)}}@media (width<=1320px){.grid{grid-template-columns:minmax(0,1.55fr) minmax(280px,1fr)}}@media (width<=980px){.grid{grid-template-columns:1fr}.actions{justify-content:flex-start}.side-stack{min-width:0;max-width:none}}.card{border:1px solid var(--border-color);background:var(--bg-pane);box-shadow:var(--shadow);border-radius:22px;overflow:hidden}body.modal-open{overflow:hidden}#studentModal{background:#0000008c;display:none;position:fixed;inset:0}#studentModal.open{justify-content:center;align-items:center;display:flex}.pill.faint{background:#f9fbff}.pill.good{background:var(--good-bg);color:var(--good-text);border-color:#0478572e}.pill.warn{background:var(--warn-bg);color:var(--warn-text);border-color:#92400e2e}.pill.bad{background:var(--bad-bg);color:var(--bad-text);border-color:#991b1b2e}.kpi-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=980px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=560px){.kpi-grid{grid-template-columns:1fr}}.kpi{border:1px solid var(--border-color);background:var(--muted-bg);border-radius:16px;padding:14px}.kpi-label{color:var(--text-secondary);margin:0 0 8px;font-size:13px;font-weight:600}.kpi-value{letter-spacing:-.02em;margin:0 0 6px;font-size:24px;line-height:1.1}.kpi-sub{color:var(--text-secondary);margin:0;font-size:12px}.kpi-grid>.mini-card{flex-direction:column;justify-content:flex-start;align-items:flex-start;min-height:150px;padding:14px 14px 12px;display:flex}.kpi-grid>.mini-card .mini-title{align-items:center;gap:6px;min-height:40px;margin:0;line-height:1.3;display:flex}.kpi-grid>.mini-card .stat-number{font-variant-numeric:tabular-nums;margin:8px 0 0;font-size:clamp(25px,2vw,30px);line-height:1.05}.kpi-grid>.mini-card .kpi-sub{align-items:flex-end;min-height:34px;margin-top:auto;line-height:1.35;display:flex}.filters{grid-template-columns:1fr 1fr 1fr auto;align-items:end;gap:12px;margin-top:16px;display:grid}@media (width<=980px){.filters{grid-template-columns:1fr 1fr}}@media (width<=560px){.filters{grid-template-columns:1fr}}label{color:var(--text-secondary);margin:0 0 8px;font-size:12px;font-weight:600;display:block}select,input{border:1px solid var(--border-color);width:100%;color:var(--text-primary);background:#fffffff2;border-radius:12px;outline:none;padding:12px;box-shadow:0 8px 18px #1f293308}select:focus,input:focus{border-color:#4a90e28c;box-shadow:0 12px 24px #4a90e21f}.spacer{height:14px}.table-wrap{border:1px solid var(--border-color);background:#fff;border-radius:16px;overflow:hidden}table{border-collapse:collapse;width:100%;font-size:14px}thead th{text-align:left;color:var(--text-primary);border-bottom:1px solid var(--border-color);white-space:nowrap;background:#f9fbff;padding:12px 14px;font-weight:700}tbody td{color:var(--text-primary);vertical-align:middle;border-bottom:1px solid #eef2f7;padding:12px 14px}tbody tr:hover{background:#f9fbff}.empty{color:var(--text-secondary);padding:14px}.link,.tiny-link{color:var(--accent-color);font-weight:700}.link:hover,.tiny-link:hover{color:var(--accent-hover);text-decoration:underline}.row-actions{flex-wrap:wrap;gap:10px;display:flex}.side-stack{gap:18px;width:100%;min-width:0;display:grid}.insight{gap:14px;display:grid}.mono{color:var(--text-primary);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:12px}.bar{border:1px solid var(--border-color);background:#eef2f7;border-radius:999px;width:100%;height:12px;overflow:hidden}.bar>span{background:linear-gradient(135deg,#4a90e2,#6cb1ff);width:0%;height:100%;transition:width .25s;display:block}.note{color:var(--text-secondary);background:#eff6ffcc;border:1px dashed #4a90e259;border-radius:16px;padding:14px;line-height:1.6}.note-title{color:var(--text-primary)}.toast{color:#fff;z-index:99;background:#1f2933eb;border-radius:14px;padding:10px 12px;font-size:13px;display:none;position:fixed;bottom:18px;right:18px;box-shadow:0 18px 40px #1f29332e}.toast.show{display:block}.mt-6{margin-top:6px}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.ml-10{margin-left:10px}.mini-title{color:var(--text-primary);margin-bottom:10px;font-weight:800}.topic-bars{gap:10px;margin-bottom:14px;display:grid}.topic-row{grid-template-columns:1fr;gap:6px;display:grid}.topic-head{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:13px;font-weight:600;display:flex}.topic-track{border:1px solid var(--border-color);background:#eef2f7;border-radius:999px;height:10px;overflow:hidden}.topic-fill{background:linear-gradient(135deg,#4a90e2,#6cb1ff);border-radius:999px;width:0%;height:100%;transition:width .25s}.split{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=980px){.split{grid-template-columns:1fr}}.mini-card{border:1px solid var(--border-color);background:var(--muted-bg);border-radius:16px;padding:12px}.donut{background:conic-gradient(#4a90e2 0 65%, #93c5fd 65% 85%, #e5e7eb 85% 100%);border-radius:50%;width:120px;height:120px;margin:10px auto 8px;position:relative}.donut:after{content:"";background:var(--muted-bg);border:1px solid var(--border-color);border-radius:50%;position:absolute;inset:18px}.donut-center{z-index:2;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-value{font-size:18px;font-weight:900}.donut-label{color:var(--text-secondary);font-size:12px}.legend{color:var(--text-secondary);justify-content:space-between;gap:8px;font-size:12px;display:flex}.dot{border-radius:50%;width:10px;height:10px;margin-right:6px;display:inline-block}.d1{background:#4a90e2}.d2{background:#93c5fd}.d3{background:#e5e7eb}.spark{border:1px solid var(--border-color);background:#f1f5f9;border-radius:14px;align-items:flex-end;gap:1.5px;height:120px;margin-top:10px;padding:10px 12px;display:flex}.spark-bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.spark-bar-pill{background:#a5c8ff;border-radius:12px;width:14px;min-height:8px;display:block}.spark-bar-value{color:var(--text-secondary);font-size:11px}.modal-backdrop{z-index:200;background:#0000008c;position:fixed;inset:0}.modal{z-index:210;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal[aria-hidden=true]{pointer-events:none;opacity:0}.modal-card{background:#fff;border:1px solid #00000014;border-radius:16px;flex-direction:column;width:min(980px,94vw);height:min(78vh,720px);display:flex;overflow:hidden;box-shadow:0 30px 90px #00000059}.modal-head{min-height:unset;background:#ffffffe6;border-bottom:1px solid #00000014;justify-content:flex-end;align-items:center;padding:10px 12px;display:flex}.modal-title{margin-top:2px;font-size:18px;font-weight:700;display:none}.modal-body{background:#f7f8fb;flex:1}.modal-body iframe{background:0 0;border:0;width:100%;height:100%}.recent-card{border:1px solid var(--border-color);background:#f8fafc;border-radius:16px;margin-top:18px}.recent-card-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:12px 14px;display:flex}.recent-card-header h3{margin:4px 0 0}.recent-card-body{gap:10px;padding:12px 14px;display:grid}.recent-item{background:#fff;border:1px solid #0000000a;border-radius:12px;gap:4px;padding:10px;transition:transform .12s,box-shadow .12s;display:grid;box-shadow:0 6px 18px #0000000a}.recent-item:hover{transform:translateY(-1px);box-shadow:0 8px 22px #00000014}.recent-meta{color:var(--text-secondary);align-items:center;gap:8px;font-size:12px;display:flex}.activity-list{gap:8px;display:grid}.activity-item{border:1px solid var(--border-color);cursor:pointer;background:#f8fafc;border-radius:12px;justify-content:space-between;align-items:center;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.activity-item:hover{background:#eef5ff;border-color:#4a90e266}.activity-badge{color:#075985;background:#e0f2fe;border:1px solid #07598526;border-radius:12px;padding:6px 10px;font-size:12px}.recent-subcard{border:1px solid var(--border-color);background:#f8fafc;border-radius:12px;margin-top:12px;padding:12px}.modal-left,.modal-right{border:1px solid var(--border-color);background:#f8fafc;border-radius:12px;padding:12px}.modal-right{min-height:240px}.stat-number{color:var(--accent-color);font-size:24px;font-weight:800}.modal-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin:0;font-size:12px}.close-btn{cursor:pointer;background:0 0;border:none;font-size:24px}.muted{color:var(--text-secondary)}@media (width<=900px){.modal-columns{grid-template-columns:1fr}.quick-drawer{top:auto;bottom:18px}}.tool-grid{grid-template-columns:1.2fr 1fr;align-items:start;gap:16px;display:grid}.tool-col{min-width:0}.tool-file{width:100%}.upload-box{background:#00000005;border:1px dashed #00000040;border-radius:14px;padding:18px;position:relative}.upload-box input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-hint{pointer-events:none;text-align:center}.upload-box.dragover{background:#0000000d;border-color:#0000008c}@media (width<=980px){.tool-grid{grid-template-columns:1fr}}.card-body.insight{max-height:none;padding:24px;overflow-y:visible}.card-body.insight::-webkit-scrollbar{width:6px}.card-body.insight::-webkit-scrollbar-thumb{background-color:#0000001a;border-radius:10px}.sparkline{flex-direction:column;align-items:center;display:flex}.spark-bars{justify-content:center;align-items:flex-end;gap:4px;height:60px;display:flex}.spark-bar-wrapper{align-items:flex-end;height:100%;display:flex}.spark-bar-pill{background:#4a90e2;border-radius:4px 4px 0 0;width:8px;min-height:4px}.spark-hint{color:#666;text-align:center;margin-top:4px;font-size:.85em;font-weight:600}.advanced-charts{flex-direction:column;gap:24px;display:flex}.chart-container{background:#f8fafc;border-radius:12px;padding:16px}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:700px;max-height:80vh;padding:20px;overflow-y:auto}.modal-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;display:flex}.modal-eyebrow{color:#666;margin:0;font-size:.85em}.modal-actions{align-items:center;gap:10px;display:flex}.close-btn{cursor:pointer;background:0 0;border:none;padding:0 5px;font-size:24px}.modal-columns{grid-template-columns:1fr 1fr;gap:20px;display:grid}.stat-grid{grid-template-columns:1fr 1fr;gap:10px;margin:15px 0;display:grid}.stat-card{text-align:center;background:#f8fafc;border-radius:8px;padding:15px}.stat-card h4{color:#666;margin:0 0 8px;font-size:.9em}.recent-subcard{background:#f8fafc;border-radius:8px;margin-top:10px;padding:12px}.subcard-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.subcard-header h4{margin:0}.activity-list{max-height:200px;overflow-y:auto}.activity-item{border-bottom:1px solid #eee;padding:8px}.activity-item:last-child{border-bottom:none}.activity-title{font-weight:500}.toast{color:#fff;opacity:0;z-index:2000;background:#333;border-radius:8px;padding:12px 24px;transition:opacity .3s;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}.toast.show{opacity:1}.loading{text-align:center;color:#666;padding:20px}.empty{text-align:center;color:#999;padding:20px}.topic-row{margin-bottom:12px}.topic-head{justify-content:space-between;margin-bottom:4px;display:flex}.topic-name{text-overflow:ellipsis;white-space:nowrap;max-width:70%;font-weight:500;overflow:hidden}.topic-count{color:#666;font-size:.85em}.topic-track{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.topic-fill{background:#4a90e2;border-radius:4px;height:100%;transition:width .3s}.legend{justify-content:center;gap:12px;margin-top:10px;font-size:.85em;display:flex}.legend span{align-items:center;gap:4px;display:flex}.dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.d1{background:#4a90e2}.dot.d2{background:#93c5fd}.dot.d3{background:#e5e7eb}@media (width<=768px){.modal-columns{grid-template-columns:1fr}}.page .grid>section.card:first-of-type{width:100%;min-width:0;max-width:100%;overflow:visible}.page .grid>section.card:first-of-type .card-body{min-width:0}.page .grid>section.card:first-of-type .table-wrap.table-responsive{-webkit-overflow-scrolling:touch;min-height:260px;overflow:auto visible}.page .grid>section.card:first-of-type table.student-table{table-layout:fixed;width:100%;min-width:720px;max-width:100%}.page .grid>section.card:first-of-type table.student-table th,.page .grid>section.card:first-of-type table.student-table td{box-sizing:border-box;overflow-wrap:anywhere;word-wrap:break-word}.page .grid>section.card:first-of-type table.student-table thead th{white-space:normal;vertical-align:bottom;-webkit-hyphens:auto;hyphens:auto;line-height:1.25}.page .grid>section.card:first-of-type table.student-table .col-student{text-align:left;width:26%;min-width:0}.page .grid>section.card:first-of-type table.student-table .col-student .mini{white-space:normal}.page .grid>section.card:first-of-type table.student-table .col-uploads{text-align:center;white-space:nowrap;width:10%;min-width:0}.page .grid>section.card:first-of-type table.student-table .col-last-upload{font-variant-numeric:tabular-nums;white-space:normal;text-align:left;width:20%;min-width:0}.page .grid>section.card:first-of-type table.student-table .col-chat-threads{text-align:center;white-space:nowrap;width:13%;min-width:0;line-height:1.3}.page .grid>section.card:first-of-type table.student-table .col-activity{text-align:center;white-space:nowrap;width:14%;min-width:0}.page .grid>section.card:first-of-type table.student-table .col-actions{text-align:center;white-space:nowrap;width:17%;min-width:0}.page .grid>section.card:first-of-type table.student-table tbody tr:hover td{background:#f9fbff}:root{--bg-main:#f5f7fb;--bg-pane:#ffffffeb;--muted-bg:#f9fbff;--border-color:#e5e7eb;--text-primary:#1f2933;--text-secondary:#4b5563;--accent-color:#4a90e2;--accent-hover:#357abd;--badge-bg:#eff6ff;--badge-text:#1d4ed8;--radius:18px;--shadow:0 10px 30px #1f293314;--shadow-soft:0 8px 18px #1f29330d}*{box-sizing:border-box}body{background:var(--bg-main);color:var(--text-primary);min-height:100vh;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;overflow-y:auto}.bg-blob{filter:blur(110px);opacity:.22;z-index:0;border-radius:50%;position:fixed}.blob-1{background:#b9ddff;width:320px;height:320px;top:-120px;left:-80px}.blob-2{background:#d8cbff;width:360px;height:360px;top:40px;right:-140px}.blob-3{background:#c0d3ff;width:260px;height:260px;bottom:-120px;left:28%}.page{z-index:1;max-width:1400px;padding:calc(var(--navbar-height) + 24px) 24px 70px;margin:0 auto;position:relative}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.student-title{max-width:720px}.eyebrow{color:var(--accent-color);letter-spacing:.08em;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:700}h1{margin:0;font-size:clamp(26px,4.5vw,40px);line-height:1.12}.student-sub{color:var(--text-secondary);margin:8px 0 0;font-size:14px}.header-actions{align-items:center;gap:12px;display:flex}.btn{cursor:pointer;color:var(--text-primary);background:#fffc;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:12px 18px;font-weight:600;transition:transform .2s,box-shadow .2s,border-color .2s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn.ghost{border:1px solid var(--border-color);background:#ffffffd9}.pill{border:1px solid var(--border-color);color:var(--text-secondary);background:#ffffffe6;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600}.tabs{gap:8px;margin-bottom:18px;display:flex}.tab{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:#ffffffb3;border-radius:12px;padding:10px 16px;font-weight:600;transition:background .15s,color .15s}.tab.active{color:var(--text-primary);background:#fff;border-color:#4a90e28c;box-shadow:0 8px 18px #4a90e21f}.student-grid{grid-template-columns:1fr 420px;gap:20px;display:grid}@media (width<=1020px){.student-grid{grid-template-columns:1fr}}.card{border:1px solid var(--border-color);background:var(--bg-pane);box-shadow:var(--shadow);border-radius:22px}.card-header{border-bottom:1px solid var(--border-color);background:#ffffffeb;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.card-body{padding:18px}.chip{background:var(--badge-bg);color:var(--badge-text);border:1px solid #1d4ed81a;border-radius:12px;align-items:center;gap:8px;padding:8px 12px;font-weight:600;display:inline-flex}.panel{display:none}.panel.active{display:block}.kpi-row{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:22px;display:grid}.kpi-mini{border:1px solid var(--border-color);background:var(--muted-bg);border-radius:16px;padding:14px}.kpi-mini .label{color:var(--text-secondary);margin:0 0 8px;font-size:13px;font-weight:600}.kpi-mini .value{color:var(--text-primary);margin:0 0 6px;font-size:22px;font-weight:800}.kpi-mini .hint{color:var(--text-secondary);margin:0;font-size:12px}.section-title{margin:18px 0 10px;font-size:16px;font-weight:700}.timeline{gap:10px;display:grid}.t-item{border:1px solid var(--border-color);background:#f8fafc;border-radius:14px;align-items:flex-start;gap:12px;padding:12px;display:flex}.t-dot{background:var(--accent-color);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:6px}.t-top{justify-content:space-between;align-items:center;gap:8px;display:flex}.t-title{margin:0;font-weight:700}.t-time{color:var(--text-secondary);font-size:12px}.t-desc{color:var(--text-secondary);margin:4px 0 0;font-size:13px}.table-compact table{border-collapse:collapse;width:100%;font-size:13px}.table-compact thead th{text-align:left;border-bottom:1px solid var(--border-color);background:#f9fbff;padding:12px 14px;font-weight:700}.table-compact tbody td{border-bottom:1px solid #eef2f7;padding:12px 14px}.topic-chips{flex-wrap:wrap;gap:8px;display:flex}.topic-chip{border:1px solid var(--border-color);background:#eef2f7;border-radius:999px;padding:8px 12px;font-size:13px}.topic-chip.weak{color:#991b1b;background:#fef2f2;border-color:#fecaca}.notes-box textarea{border:1px solid var(--border-color);resize:vertical;width:100%;min-height:180px;font:inherit;background:#fff;border-radius:14px;padding:14px}.mini{color:var(--text-secondary);margin:0;font-size:12px}.insight-bars{gap:10px;margin-top:12px;display:grid}.ib-head{justify-content:space-between;margin-bottom:6px;font-size:13px;font-weight:600;display:flex}.ib-track{border:1px solid var(--border-color);background:#eef2f7;border-radius:999px;height:10px;overflow:hidden}.ib-fill{background:linear-gradient(135deg,#4a90e2,#6cb1ff);border-radius:999px;height:100%}.toast{color:#fff;z-index:99;opacity:0;background:#1f2933eb;border-radius:14px;padding:10px 12px;font-size:13px;transition:opacity .2s,transform .2s;position:fixed;bottom:18px;right:18px;transform:translateY(8px);box-shadow:0 18px 40px #1f29332e}.toast.show{opacity:1;transform:translateY(0)}.risk-high{font-weight:700;color:#d32f2f!important}.risk-low{font-weight:700;color:#047857!important}.loading{text-align:center;color:var(--text-secondary);padding:50px;font-size:16px}.error{text-align:center;color:#d32f2f;padding:50px;font-size:16px}@media (width<=640px){.page{padding:calc(var(--navbar-height) + 16px) 16px 48px}}
