.app-root{min-height:100vh;display:flex;align-items:stretch;justify-content:center;padding:16px}.chat-shell{width:100%;max-width:1024px;height:90vh;background:#0f1929f7;border-radius:18px;border:1px solid rgba(148,163,184,.3);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px #0f1929e6}.chat-header{padding:12px 16px;border-bottom:1px solid rgba(148,163,184,.25);display:flex;align-items:center;justify-content:space-between;background:#0f1929fa}.chat-header-left{display:flex;align-items:center;gap:10px}.chat-logo{width:32px;height:32px;border-radius:999px;background:#0f1929d9;display:flex;align-items:center;justify-content:center;font-size:18px}.chat-logo img{width:24px;height:24px}.chat-title{font-weight:600;letter-spacing:.02em}.chat-subtitle{font-size:12px;color:#cbd5f5;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-right{display:flex;align-items:center;gap:8px;font-size:12px}.status-dot{width:8px;height:8px;border-radius:999px;background:#4b5563}.status-dot.online{background:#88c5ab}.chat-home-btn{background:none;border:1px solid rgba(148,163,184,.3);border-radius:8px;color:#94a3b8;font-size:16px;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.chat-home-btn:hover{background:#94a3b81a;color:#e5e7eb;border-color:#88c5ab}.level-picker-wrapper{position:relative}.level-picker-btn{padding:5px 12px;border:1px solid rgba(148,163,184,.4);border-radius:8px;background:#0000004d;color:#88c5ab;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.level-picker-btn:hover{border-color:#88c5ab;background:#88c5ab1a}.level-picker-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:#0f1929fa;border:1px solid rgba(148,163,184,.3);border-radius:10px;padding:4px;z-index:50;min-width:150px;box-shadow:0 8px 24px #00000080}.level-option{display:block;width:100%;padding:8px 12px;border:none;border-radius:6px;background:transparent;color:#cbd5e1;font-size:13px;cursor:pointer;text-align:left;transition:all .1s}.level-option:hover{background:#88c5ab26;color:#e5e7eb}.level-option.active{color:#88c5ab;font-weight:600}.action-btn{padding:5px 12px;border:1px solid rgba(148,163,184,.4);border-radius:8px;background:transparent;color:#cbd5e1;font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.action-btn:hover:not(:disabled){background:#88c5ab26;border-color:#88c5ab;color:#fff}.action-btn:disabled{opacity:.4;cursor:not-allowed}.chat-main{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.chat-error-banner{padding:8px 16px;font-size:13px;background:#dc26262e;color:#fecaca}.chat-messages{flex:1;padding:16px 18px 12px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.chat-welcome{text-align:center;padding:40px 20px;color:#94a3b8}.chat-welcome h2{color:#e5e7eb;margin-bottom:12px}.chat-welcome p{max-width:500px;margin:8px auto;line-height:1.6}.chat-welcome-doc{color:#88c5ab}.chat-message-row{display:flex;align-items:flex-end;gap:8px}.row-student{justify-content:flex-end}.row-tutor{justify-content:flex-start}.chat-avatar{width:30px;height:30px;border-radius:999px;background:#0f1929;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.chat-avatar-img{width:20px;height:20px}.chat-message-body{max-width:70%;display:flex;flex-direction:column;gap:4px}.chat-message-meta{font-size:11px;color:#9ca3af}.chat-bubble{padding:10px 14px;border-radius:16px;font-size:var(--app-font-size, 14px);line-height:1.6}.chat-bubble p{margin:0 0 8px}.chat-bubble p:last-child{margin-bottom:0}.bubble-student{background:#88c5ab;color:#1a1a1a;border-bottom-right-radius:4px}.bubble-tutor{background:#0f1929;border:1px solid rgba(255,255,255,.07);color:#f0f4f8a6;border-bottom-left-radius:4px}.bubble-tutor.streaming{border-color:#5ba49f;animation:fadeInUp .2s ease-out}.bubble-tutor.streaming p,.bubble-tutor.streaming li,.bubble-tutor.streaming pre{animation:fadeIn .3s ease-out}.bubble-tutor h1,.bubble-tutor h2,.bubble-tutor h3,.bubble-tutor h4{color:#f0f4f8;font-weight:600;line-height:1.3;margin:16px 0 8px}.bubble-tutor>:first-child{margin-top:0}.bubble-tutor h1{font-size:1.3em}.bubble-tutor h2{font-size:1.15em}.bubble-tutor h3{font-size:1.05em}.bubble-tutor h4{font-size:1em}.bubble-tutor p,.bubble-tutor li{color:#f0f4f8a6}.bubble-tutor strong{color:#f0f4f8;font-weight:600}.bubble-tutor ul,.bubble-tutor ol{margin:8px 0;padding-left:20px}.bubble-tutor li{margin:4px 0}.bubble-tutor blockquote{margin:12px 0;padding:10px 14px;border-left:3px solid #5ba49f;border-radius:0 6px 6px 0;background:#ffffff0a;color:#f0f4f8a6}.bubble-tutor blockquote p:last-child{margin-bottom:0}.bubble-tutor blockquote strong{color:#f0f4f8}.bubble-tutor a{color:#5ba49f;text-decoration:underline}.streaming-cursor{display:inline-block;width:6px;height:14px;background:#60a5fa;margin-left:2px;animation:blink 1s step-end infinite;vertical-align:text-bottom}@keyframes blink{50%{opacity:0}}@keyframes fadeIn{0%{opacity:.4}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.chat-footer{padding:10px 16px 14px;border-top:1px solid rgba(148,163,184,.25);background:#0f1929fa}.chat-input-form{display:flex;gap:10px;align-items:flex-end}.chat-input{flex:1;resize:none;border-radius:999px;border:1px solid rgba(148,163,184,.6);background:#0f1929f2;color:#e5e7eb;padding:8px 14px;font-size:var(--app-font-size, 14px);line-height:1.5;max-height:150px;font-family:inherit}.chat-input:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 1px #60a5fab3}.chat-input::placeholder{color:#6b7280}.chat-send-btn{border-radius:999px;border:none;padding:8px 16px;font-size:var(--app-font-size, 14px);font-weight:500;cursor:pointer;background:#88c5ab;color:#1a1a1a;transition:transform .05s,box-shadow .05s,opacity .15s;white-space:nowrap}.chat-send-btn:disabled{opacity:.5;cursor:default}.chat-send-btn:not(:disabled):hover{box-shadow:0 6px 20px #2563eb99;transform:translateY(-1px)}.welcome-screen{width:100%;max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:center;min-height:90vh}.welcome-content{background:#0f1929f7;border-radius:18px;border:1px solid rgba(148,163,184,.3);padding:40px 32px;text-align:center;box-shadow:0 24px 60px #0f1929e6}.welcome-logo img{width:64px;height:64px;margin-bottom:16px}.welcome-content h1{margin:0 0 8px;font-size:28px}.welcome-tagline{color:#88c5ab;font-size:14px;margin-bottom:16px}.welcome-desc{color:#94a3b8;font-size:14px;line-height:1.6;margin-bottom:24px;max-width:420px;margin-left:auto;margin-right:auto}.welcome-docs{margin-top:20px;text-align:left}.welcome-docs h3{font-size:14px;color:#cbd5e1;margin-bottom:10px}.welcome-divider{margin:24px 0;display:flex;align-items:center;gap:12px;color:#64748b;font-size:13px}.welcome-divider:before,.welcome-divider:after{content:"";flex:1;height:1px;background:#94a3b833}.welcome-start-btn{padding:10px 24px;border:1px solid rgba(148,163,184,.4);border-radius:10px;background:transparent;color:#e5e7eb;font-size:14px;cursor:pointer;transition:all .15s}.welcome-start-btn:hover{background:#88c5ab26;border-color:#88c5ab}.welcome-join{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:24px}.welcome-join-text{color:#94a3b8;font-size:13px}.welcome-join-btn{padding:10px 24px;border:1px solid #88C5AB;border-radius:10px;background:#88c5ab26;color:#e5e7eb;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.welcome-join-btn:hover{background:#88c5ab47;border-color:#88c5ab}.upload-zone{border:2px dashed rgba(148,163,184,.4);border-radius:12px;padding:32px 20px;cursor:pointer;transition:all .2s;text-align:center}.upload-zone:hover,.upload-zone.drag-active{border-color:#88c5ab;background:#88c5ab14}.upload-zone.uploading{cursor:wait;opacity:.7}.upload-content p{margin:8px 0 4px;color:#cbd5e1;font-size:14px}.upload-icon{font-size:32px}.upload-hint{color:#64748b;font-size:12px}.upload-spinner{width:24px;height:24px;border:3px solid rgba(148,163,184,.3);border-top-color:#88c5ab;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 8px}@keyframes spin{to{transform:rotate(360deg)}}.no-docs{color:#64748b;font-size:13px;text-align:center}.doc-list{display:flex;flex-direction:column;gap:6px}.doc-card{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid rgba(148,163,184,.2);border-radius:10px;cursor:pointer;transition:all .15s}.doc-card:hover,.doc-card.selected{border-color:#88c5ab;background:#88c5ab14}.doc-card-name{font-size:13px;font-weight:500;color:#e5e7eb}.doc-card-meta{font-size:11px;color:#64748b;margin-top:2px}.doc-delete-btn{background:none;border:none;color:#64748b;font-size:18px;cursor:pointer;padding:2px 6px;border-radius:4px}.doc-delete-btn:hover{color:#ef4444;background:#ef44441a}.quiz-panel{width:100%;max-width:700px;margin:0 auto;background:#0f1929f7;border-radius:18px;border:1px solid rgba(148,163,184,.3);box-shadow:0 24px 60px #0f1929e6;display:flex;flex-direction:column;max-height:90vh;overflow-y:auto}.quiz-header{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(148,163,184,.2)}.quiz-header h2{font-size:18px;margin:0}.quiz-close{background:none;border:none;color:#94a3b8;font-size:22px;cursor:pointer}.quiz-generating{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:#94a3b8;font-size:16px}.quiz-spinner{width:36px;height:36px;border:3px solid rgba(148,163,184,.2);border-top-color:#818cf8;border-radius:50%;animation:quiz-spin .8s linear infinite}@keyframes quiz-spin{to{transform:rotate(360deg)}}.quiz-questions{padding:16px 20px}.quiz-question{margin-bottom:24px}.quiz-q-number{font-size:11px;color:#60a5fa;font-weight:600;text-transform:uppercase;margin-bottom:6px}.quiz-q-text{font-size:15px;line-height:1.5;margin-bottom:12px}.quiz-options{display:flex;flex-direction:column;gap:6px}.quiz-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid rgba(148,163,184,.3);border-radius:10px;background:transparent;color:#e5e7eb;font-size:13px;cursor:pointer;text-align:left;transition:all .15s}.quiz-option:hover:not(:disabled){border-color:#88c5ab;background:#2563eb14}.quiz-option.selected{border-color:#88c5ab;background:#88c5ab26}.quiz-option.correct{border-color:#22c55e;background:#22c55e1f}.quiz-option.wrong{border-color:#ef4444;background:#ef44441f}.opt-key{width:24px;height:24px;border-radius:6px;background:#94a3b826;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;flex-shrink:0}.quiz-explanation{margin-top:8px;padding:10px 12px;border-radius:8px;font-size:13px;line-height:1.5}.quiz-explanation.correct{background:#22c55e1a;color:#86efac}.quiz-explanation.wrong{background:#ef44441a;color:#fca5a5}.quiz-footer{padding:16px 20px;border-top:1px solid rgba(148,163,184,.2);display:flex;align-items:center;justify-content:space-between;gap:12px}.quiz-submit-btn{padding:8px 20px;border:none;border-radius:8px;background:#88c5ab;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.quiz-submit-btn:disabled{opacity:.5;cursor:default}.quiz-submit-btn:not(:disabled):hover{background:#60a5fa}.quiz-back-btn{padding:8px 16px;border:1px solid rgba(148,163,184,.3);border-radius:8px;background:transparent;color:#cbd5e1;font-size:13px;cursor:pointer}.quiz-back-btn:hover{background:#94a3b81a}.quiz-score{font-size:16px;font-weight:600;color:#e5e7eb}.quiz-badges{font-size:13px;color:#fbbf24;margin-top:4px}.progress-panel{width:100%;max-width:700px;margin:0 auto;background:#0f1929f7;border-radius:18px;border:1px solid rgba(148,163,184,.3);box-shadow:0 24px 60px #0f1929e6;max-height:90vh;overflow-y:auto}.progress-header{padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(148,163,184,.2)}.progress-header h2{font-size:18px;margin:0}.progress-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:20px}.stat-card{text-align:center;padding:16px 8px;border:1px solid rgba(148,163,184,.2);border-radius:12px;background:#0003}.stat-value{font-size:24px;font-weight:700;color:#60a5fa}.stat-label{font-size:11px;color:#94a3b8;margin-top:4px}.badges-section,.sections-progress{padding:0 20px 20px}.badges-section h3,.sections-progress h3{font-size:14px;color:#cbd5e1;margin-bottom:12px}.badge-grid{display:flex;flex-wrap:wrap;gap:8px}.badge-card{padding:8px 14px;border:1px solid rgba(148,163,184,.2);border-radius:8px;text-align:center;font-size:12px}.badge-card.earned{border-color:#fbbf24;background:#fbbf2414}.badge-icon{font-size:20px;margin-bottom:4px}.badge-name{color:#fbbf24}.section-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}.section-name{font-size:13px;color:#cbd5e1;width:160px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.section-bar-container{flex:1;height:8px;background:#94a3b826;border-radius:4px;overflow:hidden}.section-bar-fill{height:100%;background:linear-gradient(90deg,#2563eb,#60a5fa);border-radius:4px;transition:width .3s}.section-pct{font-size:12px;color:#94a3b8;width:40px;text-align:right}.progress-footer{padding:16px 20px;border-top:1px solid rgba(148,163,184,.2);display:flex;justify-content:flex-end}.recommendations-section{padding:0 20px 20px}.recommendations-section h3{font-size:14px;color:#88c5ab;margin-bottom:12px}.rec-list{display:flex;flex-direction:column;gap:8px}.rec-card{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border:1px solid rgba(148,163,184,.2);border-radius:10px;background:#00000026;transition:all .15s}.rec-card:hover{border-color:#88c5ab66;background:#88c5ab0d}.rec-info{flex:1;min-width:0}.rec-section-name{font-size:13px;font-weight:500;color:#e5e7eb;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rec-reason{font-size:11px;color:#94a3b8;margin-top:2px}.rec-quiz-btn{padding:4px 12px;border:1px solid rgba(136,197,171,.5);border-radius:6px;background:transparent;color:#88c5ab;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;margin-left:12px;flex-shrink:0}.rec-quiz-btn:hover{background:#88c5ab26;border-color:#88c5ab}.quiz-result-info{display:flex;flex-direction:column;gap:8px}.quiz-difficulty-change{font-size:13px;padding:8px 12px;border-radius:8px;background:#88c5ab1f;color:#88c5ab;border:1px solid rgba(136,197,171,.3);line-height:1.5}.quiz-feedback-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:8px;background:#94a3b80f;border:1px solid rgba(148,163,184,.15)}.quiz-feedback-prompt{display:flex;align-items:center;gap:12px}.quiz-feedback-label{font-size:13px;color:#cbd5e1}.quiz-feedback-buttons{display:flex;gap:6px}.quiz-feedback-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;border:1px solid rgba(148,163,184,.25);background:transparent;color:#cbd5e1;font-size:12px;cursor:pointer;transition:background .12s,border-color .12s,color .12s}.quiz-feedback-btn:hover:not(:disabled){background:#94a3b81a;border-color:#94a3b866;color:#e5e7eb}.quiz-feedback-btn:disabled{cursor:default;opacity:.7}.quiz-feedback-btn.voted{opacity:1}.quiz-feedback-btn.voted[aria-pressed=true][aria-label*=Upvote]{background:#88c5ab2e;border-color:#88c5ab73;color:#88c5ab}.quiz-feedback-btn.voted[aria-pressed=true][aria-label*=Downvote]{background:#6b6e5433;border-color:#6b6e5480;color:#b8b89a}.quiz-feedback-btn-text{font-weight:500}.quiz-regenerate-btn{padding:6px 12px;border-radius:6px;border:1px solid rgba(148,163,184,.25);background:transparent;color:#cbd5e1;font-size:12px;cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap}.quiz-regenerate-btn:hover{background:#60a5fa1a;border-color:#60a5fa66;color:#93c5fd}.auth-scene{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative;overflow:hidden}.auth-card{background:#0f1929f7;border:1px solid rgba(148,163,184,.3);box-shadow:0 24px 60px #0f1929e6;border-radius:20px;padding:40px 36px 36px;width:100%;max-width:400px;position:relative}.auth-logo-row{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.auth-logo-mark{width:44px;height:44px;border-radius:12px;background:var(--bg3);border:.5px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.auth-logo-mark img{width:28px;height:28px}.auth-wordmark{font-size:20px;font-weight:300;color:#f0ede6;letter-spacing:.02em}.auth-wordmark-accent{color:var(--gold)}.auth-tagline{font-size:12px;color:#ffffff47;letter-spacing:.06em;text-transform:uppercase;margin-top:4px}.auth-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;letter-spacing:.07em;text-transform:uppercase;color:#88c5ab;background:#88c5ab1a;border:.5px solid rgba(136,197,171,.2);border-radius:999px;padding:3px 9px;margin-top:8px}.auth-badge-dot{width:5px;height:5px;border-radius:50%;background:#88c5ab}.auth-tabs{display:flex;background:#ffffff0a;border:.5px solid rgba(255,255,255,.07);border-radius:10px;padding:3px;margin-bottom:24px}.auth-tabs button{flex:1;text-align:center;padding:7px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;border:none;background:transparent;font-family:inherit;color:#ffffff8c}.auth-tabs button.active{background:var(--bg4);color:#e8e5dc;border:.5px solid rgba(255,255,255,.1)}.auth-tabs button:not(.active):hover{color:#ffffffbf}.auth-role-toggle{display:flex;background:#ffffff0a;border:.5px solid rgba(255,255,255,.07);border-radius:10px;padding:3px}.auth-role-toggle button{flex:1;text-align:center;padding:7px;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .18s;border:none;background:transparent;color:#ffffff8c}.auth-role-toggle button.active{background:#1a2035;color:#e8e5dc;border:.5px solid rgba(255,255,255,.1)}.auth-role-toggle button:not(.active):hover{color:#ffffffbf}.educator-placeholder-body{margin:8px 0 24px;text-align:center}.educator-placeholder-title{margin:0 0 12px;font-size:18px;font-weight:600;color:#e8e5dc}.educator-placeholder-copy{font-size:14px;line-height:1.5;color:#cbd5e1}.educator-placeholder-logout{margin-top:8px}.auth-error-banner{padding:10px 14px;border-radius:10px;background:#ef444414;border:.5px solid rgba(239,68,68,.2);color:#fca5a5;font-size:13px;margin-bottom:16px;line-height:1.4}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{display:block;font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#ffffff59}.auth-field input{width:100%;background:#fff;border:.5px solid rgba(255,255,255,.1);border-radius:10px;padding:11px 14px;font-size:14px;color:#1a1a1a;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.auth-field input::placeholder{color:#9ca3af}.auth-field input:focus{border-color:#88c5ab;box-shadow:0 0 0 3px #88c5ab26}.auth-forgot{text-align:right;margin-top:-6px;margin-bottom:8px}.auth-forgot button{font-size:12px;color:#ffffff4d;background:none;border:none;cursor:pointer;font-family:inherit;padding:0;transition:color .15s}.auth-forgot button:hover{color:#88c5ab}.auth-submit{width:100%;background:#88c5ab;border:none;border-radius:10px;padding:12px;font-size:14px;font-weight:500;color:#1a1a1a;cursor:pointer;transition:background .15s,transform .1s;letter-spacing:.01em;font-family:inherit;display:flex;align-items:center;justify-content:center;gap:6px}.auth-submit:hover:not(:disabled){background:#78b89e}.auth-submit:active:not(:disabled){transform:scale(.98)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-arrow{font-size:16px}.auth-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.auth-divider{display:flex;align-items:center;gap:10px;margin:18px 0}.auth-divider-line{flex:1;height:.5px;background:#ffffff12}.auth-divider span{font-size:11px;color:#fff3;text-transform:uppercase;letter-spacing:.06em}.auth-google{width:100%;background:transparent;border:.5px solid rgba(255,255,255,.1);border-radius:10px;padding:10px;font-size:13px;color:#ffffff8c;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:border-color .15s,color .15s;font-family:inherit}.auth-google:hover{border-color:#fff3;color:#ffffffbf}.auth-footer-note{text-align:center;font-size:11px;color:#fff3;margin-top:20px;line-height:1.6}.auth-footer-note a{color:#ffffff59;text-decoration:underline;cursor:pointer}.auth-footer-note a:hover{color:#88c5ab}.auth-error{color:#ef4444;font-size:13px;margin:0}.top-bar{position:fixed;top:16px;right:16px;display:flex;gap:8px;z-index:100}.logout-btn{padding:6px 14px;border:1px solid rgba(148,163,184,.3);border-radius:8px;background:#0f1929e6;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .15s}.logout-btn:hover{color:#e5e7eb;border-color:#94a3b880}.trial-banner{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:#3b82f626;border-bottom:1px solid rgba(59,130,246,.3);color:#93c5fd;font-size:13px;z-index:200}.trial-banner--urgent{background:#ef444426;border-bottom-color:#ef44444d;color:#fca5a5}.trial-banner-btn{padding:4px 12px;border:1px solid currentColor;border-radius:6px;background:transparent;color:inherit;font-size:12px;cursor:pointer;transition:all .15s}.trial-banner-btn:hover{background:#ffffff1a}.past-due-banner{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 16px;background:#f59e0b26;border-bottom:1px solid rgba(245,158,11,.35);color:#fcd34d;font-size:13px;z-index:200}.past-due-banner--urgent{background:#ef444426;border-bottom-color:#ef444459;color:#fca5a5}.past-due-banner-btn{flex-shrink:0;padding:4px 12px;border:1px solid currentColor;border-radius:6px;background:transparent;color:inherit;font-size:12px;cursor:pointer;transition:all .15s}.past-due-banner-btn:hover{background:#ffffff1a}.paywall-content{text-align:center;padding:8px 0}.paywall-title{font-size:20px;font-weight:600;color:#e5e7eb;margin:0 0 8px}.paywall-description{color:#94a3b8;font-size:14px;margin:0 0 20px;line-height:1.5}.paywall-price-card{background:#1e293bcc;border:1px solid rgba(148,163,184,.2);border-radius:12px;padding:20px;margin-bottom:20px}.paywall-price{margin-bottom:16px}.paywall-amount{font-size:36px;font-weight:700;color:#e5e7eb}.paywall-period{font-size:16px;color:#94a3b8}.paywall-features{list-style:none;padding:0;margin:0;text-align:left}.paywall-features li{padding:6px 0;color:#94a3b8;font-size:14px}.paywall-features li:before{content:"✓";color:#34d399;margin-right:8px}.paywall-logout{margin-top:12px;padding:8px 16px;border:none;background:transparent;color:#64748b;font-size:13px;cursor:pointer}.paywall-logout:hover{color:#94a3b8}.paywall-secondary{display:block;width:100%;margin-top:10px;padding:10px 16px;border:1px solid rgba(148,163,184,.4);border-radius:8px;background:transparent;color:#e5e7eb;font-size:14px;font-weight:500;cursor:pointer}.paywall-secondary:hover{border-color:#94a3b8b3;background:#94a3b814}@media(max-width:640px){.chat-shell{height:100vh;max-width:100%;border-radius:0}.chat-message-body{max-width:85%}.progress-stats{grid-template-columns:repeat(2,1fr)}.level-picker-btn,.action-btn{font-size:11px;padding:4px 8px}}.menu-btn{width:36px;height:36px;padding:0;border:1px solid rgba(148,163,184,.3);border-radius:8px;background:#0f1929e6;color:#94a3b8;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}.menu-btn:hover{color:#e5e7eb;border-color:#94a3b880}.menu-wrapper{position:relative}.settings-menu{position:absolute;top:calc(100% + 8px);right:0;width:240px;padding:8px;display:flex;flex-direction:column;gap:2px;background:#0f1929f7;border:1px solid rgba(148,163,184,.3);border-radius:12px;box-shadow:0 12px 32px #0f192999;z-index:150}.settings-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#cbd5e1;font-size:13px;font-family:inherit;text-align:left;cursor:pointer;transition:all .1s}.settings-menu-item:hover{background:#88c5ab1a;color:#88c5ab}.settings-menu-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:#94a3b8;transition:color .1s}.settings-menu-item:hover .settings-menu-icon{color:currentColor}.settings-menu-icon svg{display:block}.settings-menu-item--logout{margin-top:6px;padding-top:12px;border-top:1px solid rgba(148,163,184,.15);border-radius:0 0 8px 8px;color:#94a3b8}.settings-menu-item--logout:hover{background:#ef44441a;color:#fca5a5}.settings-menu-item--logout:hover .settings-menu-icon{color:#fca5a5}.settings-screen{width:100%;max-width:1024px;height:90vh;display:flex;background:#0f1929f7;border-radius:18px;border:1px solid rgba(148,163,184,.3);overflow:hidden;box-shadow:0 24px 60px #0f1929e6}.settings-sidebar{width:240px;flex-shrink:0;background:#0003;border-right:1px solid rgba(148,163,184,.2);display:flex;flex-direction:column;overflow-y:auto}.settings-sidebar-header{display:flex;align-items:center;gap:10px;padding:16px 18px;border-bottom:1px solid rgba(148,163,184,.15)}.settings-sidebar-header h1{margin:0;font-size:16px;font-weight:600;color:#e5e7eb;letter-spacing:.02em}.settings-back-btn{background:none;border:1px solid rgba(148,163,184,.3);border-radius:8px;color:#94a3b8;font-size:14px;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.settings-back-btn:hover{background:#94a3b81a;color:#e5e7eb;border-color:#88c5ab}.settings-nav{display:flex;flex-direction:column;padding:10px 8px;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#cbd5e1;font-size:13px;cursor:pointer;text-align:left;transition:all .1s;font-family:inherit}.settings-nav-item:hover{background:#88c5ab1a;color:#e5e7eb}.settings-nav-item--active{background:#88c5ab2e;color:#88c5ab;font-weight:600}.settings-nav-item--logout{margin-top:auto;padding-top:12px;border-top:1px solid rgba(148,163,184,.15);border-radius:0 0 8px 8px;color:#94a3b8}.settings-nav-item--logout:hover{background:#ef44441a;color:#fca5a5}.settings-nav-item--logout:hover .settings-nav-icon{color:#fca5a5}.settings-nav{flex:1;min-height:0}.settings-nav-icon{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:#94a3b8;transition:color .1s}.settings-nav-item:hover .settings-nav-icon,.settings-nav-item--active .settings-nav-icon{color:currentColor}.settings-nav-icon svg{display:block}.settings-content{flex:1;overflow-y:auto;padding:24px 28px 48px}.settings-section{max-width:640px;margin:0 auto;position:relative}.settings-section h2{margin:0 0 20px;font-size:22px;color:#e5e7eb;letter-spacing:.01em}.settings-section h3{margin:0 0 8px;font-size:14px;color:#cbd5e1;letter-spacing:.02em}.settings-card{padding:18px 20px;border:1px solid rgba(148,163,184,.2);border-radius:12px;background:#00000026;margin-bottom:14px}.settings-card--danger{border-color:#ef444459;background:#ef44440a}.settings-card--danger h3{color:#fca5a5}.settings-meta{font-size:13px;color:#94a3b8;margin:6px 0;line-height:1.5}.settings-meta--hint{font-size:12px;color:#64748b}.settings-form{display:flex;flex-direction:column;gap:12px}.settings-field{display:flex;flex-direction:column;gap:6px;margin-top:10px}.settings-field label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:#ffffff73}.settings-field input[type=text],.settings-field input[type=email],.settings-field input[type=password],.settings-field input[type=time],.settings-field select,.settings-field textarea{width:100%;background:#0f192999;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:10px 12px;font-size:14px;color:#e5e7eb;outline:none;transition:border-color .15s,box-shadow .15s;font-family:inherit}.settings-field textarea{resize:vertical;min-height:90px}.settings-field input:focus,.settings-field select:focus,.settings-field textarea:focus{border-color:#88c5ab;box-shadow:0 0 0 3px #88c5ab26}.settings-row-between{display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-row-between+.settings-row-between{margin-top:16px;padding-top:16px;border-top:1px solid rgba(148,163,184,.15)}.settings-inline-row{display:flex;gap:8px}.settings-inline-row input{flex:1;background:#0f192999;border:1px solid rgba(148,163,184,.25);border-radius:10px;padding:10px 12px;font-size:14px;color:#e5e7eb;outline:none;font-family:inherit}.settings-inline-row input:focus{border-color:#88c5ab;box-shadow:0 0 0 3px #88c5ab26}.settings-inline-actions{display:flex;gap:8px;flex-wrap:wrap}.settings-btn-primary,.settings-btn-ghost,.settings-btn-danger{padding:9px 16px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.settings-btn-primary{background:#88c5ab;color:#1a1a1a;border:1px solid #88C5AB}.settings-btn-primary:hover:not(:disabled){background:#78b89e}.settings-btn-primary:disabled{opacity:.5;cursor:not-allowed}.settings-btn-ghost{background:transparent;color:#cbd5e1;border:1px solid rgba(148,163,184,.3)}.settings-btn-ghost:hover:not(:disabled){background:#94a3b81a;border-color:#88c5ab;color:#e5e7eb}.settings-btn-ghost:disabled{opacity:.5;cursor:not-allowed}.settings-btn-danger{background:transparent;color:#fca5a5;border:1px solid rgba(239,68,68,.45)}.settings-btn-danger:hover:not(:disabled){background:#ef44441f;border-color:#ef4444;color:#fca5a5}.settings-btn-danger:disabled{opacity:.5;cursor:not-allowed}.settings-radio-row{display:flex;flex-wrap:wrap;gap:8px}.settings-radio{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid rgba(148,163,184,.25);border-radius:999px;cursor:pointer;background:#0f192999;color:#cbd5e1;font-size:13px;transition:all .15s}.settings-radio:hover{border-color:#88c5ab;color:#e5e7eb}.settings-radio input{accent-color:#88C5AB}.settings-radio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:8px}.settings-subgroup{margin-top:12px}.settings-subgroup h4{margin:0 0 6px;text-transform:uppercase;letter-spacing:.04em}.settings-radio-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border:1px solid rgba(148,163,184,.25);border-radius:10px;cursor:pointer;background:#0f192999;transition:all .15s}.settings-radio-card:hover{border-color:#88c5ab}.settings-radio-card input{margin-top:3px;accent-color:#88C5AB}.settings-radio-card strong{color:#e5e7eb;font-size:13px;display:block;margin-bottom:2px}.settings-chip-grid{display:flex;flex-wrap:wrap;gap:6px}.settings-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:#0f1929b3;border:1px solid rgba(148,163,184,.25);border-radius:999px;font-size:12px;color:#cbd5e1;cursor:pointer;transition:all .15s;font-family:inherit}.settings-chip:hover{border-color:#88c5ab;color:#e5e7eb}.settings-chip--active{background:#88c5ab2e;border-color:#88c5ab;color:#88c5ab;font-weight:600}.settings-chip--tag{cursor:default;background:#88c5ab1f;border-color:#88c5ab4d;color:#e5e7eb}.settings-chip--tag button{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:14px;padding:0;line-height:1}.settings-chip--tag button:hover{color:#fca5a5}.settings-avatar-row{display:flex;align-items:center;gap:16px;margin-bottom:12px}.settings-avatar{width:64px;height:64px;border-radius:999px;background:#88c5ab26;border:1px solid rgba(148,163,184,.3);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;color:#88c5ab;font-size:22px;font-weight:600}.settings-avatar img{width:100%;height:100%;object-fit:cover}.settings-avatar-controls{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.settings-toggle{position:relative;width:44px;height:24px;border-radius:999px;background:#94a3b84d;border:none;cursor:pointer;transition:background .15s;padding:0;flex-shrink:0}.settings-toggle--on{background:#88c5ab}.settings-toggle-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:999px;background:#fff;transition:transform .15s;box-shadow:0 1px 3px #0000004d}.settings-toggle--on .settings-toggle-thumb{transform:translate(20px)}.settings-slider-row{display:flex;align-items:center;gap:10px}.settings-slider-row input[type=range]{flex:1;accent-color:#88C5AB}.settings-progress-track{height:8px;background:#94a3b82e;border-radius:999px;overflow:hidden;margin-top:8px}.settings-progress-fill{height:100%;background:linear-gradient(90deg,#88c5ab,#60a5fa);border-radius:999px;transition:width .3s}.settings-plan-label{font-size:18px;font-weight:600;color:#e5e7eb;margin:0 0 6px}.settings-usage-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.settings-usage-stat{padding:14px 12px;border:1px solid rgba(148,163,184,.15);border-radius:10px;background:#0003;text-align:center}.settings-usage-value{font-size:22px;font-weight:700;color:#88c5ab}.settings-usage-label{font-size:11px;color:#94a3b8;margin-top:4px}.settings-sticky-save{display:flex;justify-content:flex-end;padding-top:8px}.settings-link-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:6px}.settings-link-list a{color:#88c5ab;font-size:13px;text-decoration:none;border-bottom:1px solid transparent;padding-bottom:1px;transition:border-color .15s}.settings-link-list a:hover{border-color:#88c5ab}.settings-bullet-list{margin:8px 0;padding-left:20px;color:#cbd5e1;font-size:13px;line-height:1.6}.settings-toast{position:sticky;top:0;z-index:5;padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:12px;animation:fadeInUp .2s ease-out}.settings-toast--success{background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:#86efac}.settings-toast--error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.settings-modal-backdrop{position:fixed;inset:0;background:#020617b3;display:flex;align-items:center;justify-content:center;z-index:500;padding:20px}.settings-modal{width:100%;max-width:460px;background:#0f1423;border:1px solid rgba(148,163,184,.25);border-radius:16px;padding:24px;box-shadow:0 24px 60px #0009}.settings-modal-title{margin:0 0 12px;font-size:17px;color:#e5e7eb}.settings-modal-body{color:#cbd5e1;font-size:13px;line-height:1.5}.settings-modal-body p{margin:0 0 10px}.settings-modal-body code{background:#88c5ab26;color:#88c5ab;padding:1px 6px;border-radius:4px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.settings-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}html[data-theme=light] body{background:#f8fafc;color:#1a1a1a}html[data-theme=light] .settings-screen,html[data-theme=light] .chat-shell,html[data-theme=light] .welcome-content,html[data-theme=light] .quiz-panel,html[data-theme=light] .progress-panel{background:#fff;border-color:#0f19291f;box-shadow:0 24px 60px #0f19291f;color:#1a1a1a}html[data-theme=light] .settings-sidebar{background:#f1f5f9;border-right-color:#0f19291a}html[data-theme=light] .settings-sidebar-header h1,html[data-theme=light] .settings-section h2,html[data-theme=light] .settings-section h3,html[data-theme=light] .settings-plan-label{color:#0f172a}html[data-theme=light] .settings-card{background:#f8fafc;border-color:#0f19291a}html[data-theme=light] .settings-nav-item{color:#334155}html[data-theme=light] .settings-nav-item--active{background:#88c5ab33;color:#0f8a63}html[data-theme=light] .settings-meta{color:#475569}html[data-theme=light] .settings-meta--hint{color:#64748b}html[data-theme=light] .bubble-tutor{background:#f3f4f6;border-color:#e5e7eb;color:#1f2937}html[data-theme=light] .bubble-tutor h1,html[data-theme=light] .bubble-tutor h2,html[data-theme=light] .bubble-tutor h3,html[data-theme=light] .bubble-tutor h4{color:#0f172a}html[data-theme=light] .bubble-tutor p,html[data-theme=light] .bubble-tutor li{color:#475569}html[data-theme=light] .bubble-tutor strong{color:#0f172a}html[data-theme=light] .bubble-tutor blockquote{background:#88c5ab1f;color:#334155}html[data-theme=light] .bubble-tutor blockquote strong{color:#0f172a}html[data-theme=light] .bubble-student{background:#fff;border:2px solid #88C5AB;color:#000}html[data-theme=light] .welcome-desc,html[data-theme=light] .welcome-join-text,html[data-theme=light] .upload-content p,html[data-theme=light] .upload-hint,html[data-theme=light] .doc-card-meta,html[data-theme=light] .doc-source-badge,html[data-theme=light] .no-docs{color:#475569}html[data-theme=light] .welcome-tagline{color:var(--teal-dim)}html[data-theme=light] .welcome-docs h3{color:#1e293b}html[data-theme=light] .doc-card-name{color:#0f172a}html[data-theme=light] .welcome-divider{color:#475569}html[data-theme=light] .welcome-divider:before,html[data-theme=light] .welcome-divider:after{background:#0f192924}html[data-theme=light] .welcome-join-btn{background:var(--teal-dim);border-color:var(--teal-dim);color:#fff}html[data-theme=light] .welcome-join-btn:hover{background:#2f615d;border-color:#2f615d}html[data-theme=light] .welcome-start-btn{border-color:var(--teal-dim);color:var(--teal-dim)}html[data-theme=light] .welcome-start-btn:hover{background:#5ba49f1a;border-color:var(--teal-dim)}html[data-theme=light] .upload-zone{border-color:#0f192940}html[data-theme=light] .upload-zone:hover,html[data-theme=light] .upload-zone.drag-active,html[data-theme=light] .doc-card:hover,html[data-theme=light] .doc-card.selected{border-color:var(--teal-dim);background:#5ba49f1a}html[data-theme=light] .doc-card{border-color:#0f192926}html[data-theme=light] .settings-menu{background:#fff;border-color:#0f19291f;box-shadow:0 12px 32px #0f19291f}html[data-theme=light] .settings-menu-item{color:#334155}html[data-theme=light] .settings-menu-icon{color:#64748b}html[data-theme=light] .settings-menu-item:hover{background:#5ba49f1f;color:var(--teal-dim)}html[data-theme=light] .settings-menu-item--logout{border-top-color:#0f19291a}html[data-theme=light] .settings-menu-item--logout:hover{background:#dc26261a;color:#b91c1c}html[data-theme=light] .settings-field label{color:#475569}html[data-theme=light] .settings-field input[type=text],html[data-theme=light] .settings-field input[type=email],html[data-theme=light] .settings-field input[type=password],html[data-theme=light] .settings-field input[type=time],html[data-theme=light] .settings-field select,html[data-theme=light] .settings-field textarea,html[data-theme=light] .settings-inline-row input{background:#fff;border-color:#0f192933;color:#0f172a}html[data-theme=light] .settings-field input::placeholder,html[data-theme=light] .settings-field textarea::placeholder,html[data-theme=light] .settings-inline-row input::placeholder{color:#64748b}html[data-theme=light] .settings-field input:focus,html[data-theme=light] .settings-field select:focus,html[data-theme=light] .settings-field textarea:focus,html[data-theme=light] .settings-inline-row input:focus{border-color:var(--teal-dim);box-shadow:0 0 0 3px #5ba49f33}html[data-theme=light] .settings-chip{background:#fff;border-color:#0f192933;color:#334155}html[data-theme=light] .settings-chip:hover{border-color:var(--teal-dim);color:var(--teal-dim)}html[data-theme=light] .settings-chip--active{background:var(--teal-dim);border-color:var(--teal-dim);color:#fff}html[data-theme=light] .settings-chip--tag{background:#5ba49f1f;border-color:#5ba49f66;color:#334155}html[data-theme=light] .settings-chip--tag button{color:#64748b}html[data-theme=light] .settings-radio,html[data-theme=light] .settings-radio-card{background:#fff;border-color:#0f192933;color:#334155}html[data-theme=light] .settings-radio:hover,html[data-theme=light] .settings-radio-card:hover{border-color:var(--teal-dim)}html[data-theme=light] .settings-radio-card strong{color:#0f172a}html[data-theme=light] .settings-radio input,html[data-theme=light] .settings-radio-card input,html[data-theme=light] .settings-slider-row input[type=range]{accent-color:var(--teal-dim)}html[data-theme=light] .settings-toggle{background:#0f192933}html[data-theme=light] .settings-toggle--on{background:var(--teal-dim)}html[data-theme=light] .settings-avatar{border-color:#0f192926;color:var(--teal-dim)}html[data-theme=light] .settings-btn-primary{background:var(--teal-dim);border-color:var(--teal-dim);color:#fff}html[data-theme=light] .settings-btn-primary:hover:not(:disabled){background:#2f615d;border-color:#2f615d}html[data-theme=light] .settings-btn-ghost{color:#334155;border-color:#0f192940}html[data-theme=light] .settings-btn-ghost:hover:not(:disabled){background:#5ba49f1a;border-color:var(--teal-dim);color:var(--teal-dim)}html[data-theme=light] .settings-btn-danger{color:#b91c1c;border-color:#dc262666}html[data-theme=light] .settings-btn-danger:hover:not(:disabled){background:#dc26261a;border-color:#b91c1c;color:#b91c1c}html[data-theme=light] .chat-welcome{color:#475569}html[data-theme=light] .chat-welcome h2{color:#0f172a}html[data-theme=light] .chat-welcome-doc{color:var(--teal-dim)}.chat-with-sidebar{width:100%;max-width:1304px;height:90vh;display:flex;gap:16px;align-items:stretch}.chat-with-sidebar>.chat-shell{flex:1;height:100%;max-width:none}.chat-sidebar{width:264px;flex-shrink:0;height:100%;background:#0f1929f7;border:1px solid rgba(148,163,184,.3);border-radius:18px;box-shadow:0 24px 60px #0f1929e6;display:flex;flex-direction:column;overflow:hidden;color:#e5e7eb;transition:width .22s ease}.chat-sidebar--collapsed{width:52px;background:transparent;border-color:transparent;box-shadow:none}.chat-sidebar-rail{position:fixed;top:16px;left:16px;z-index:100;display:flex;flex-direction:column;align-items:flex-start;gap:6px}.chat-sidebar-rail-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;transition:background .12s ease,color .12s ease}.chat-sidebar-rail-btn:hover{background:#94a3b829;color:#fff}.chat-sidebar-header{padding:12px;border-bottom:1px solid rgba(148,163,184,.25);display:flex;align-items:center;gap:8px}.chat-sidebar-toggle{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:#cbd5e1;cursor:pointer;transition:background .12s ease,color .12s ease}.chat-sidebar-toggle:hover{background:#94a3b829;color:#fff}.chat-sidebar-header .chat-sidebar-new{flex:1}.chat-sidebar-new{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;background:#88c5ab29;color:#88c5ab;border:1px solid rgba(136,197,171,.45);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease}.chat-sidebar-new:hover{background:#88c5ab3d}.chat-sidebar-list{list-style:none;margin:0;padding:8px;overflow-y:auto;flex:1}.chat-sidebar-entry{display:flex;align-items:stretch;border-radius:10px;margin-bottom:4px;position:relative;transition:background .12s ease}.chat-sidebar-entry:hover{background:#94a3b81f}.chat-sidebar-entry--active{background:#88c5ab29}.chat-sidebar-entry--active:hover{background:#88c5ab38}.chat-sidebar-entry-main{flex:1;text-align:left;background:transparent;border:none;color:inherit;padding:10px 12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:0}.chat-sidebar-entry-title{font-size:13px;font-weight:500;color:#e5e7eb;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-sidebar-entry--active .chat-sidebar-entry-title{color:#fff}.chat-sidebar-entry-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:#94a3b8;min-width:0}.chat-sidebar-entry-doc{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#88c5ab;opacity:.85}.chat-sidebar-entry-delete{display:flex;align-items:center;justify-content:center;width:32px;background:transparent;border:none;color:#94a3b8;cursor:pointer;opacity:0;transition:opacity .12s ease,color .12s ease;border-radius:0 10px 10px 0}.chat-sidebar-entry:hover .chat-sidebar-entry-delete,.chat-sidebar-entry:focus-within .chat-sidebar-entry-delete{opacity:1}.chat-sidebar-entry-delete:hover{color:#ef4444;background:#ef44441f}.chat-sidebar-empty{padding:24px 16px;text-align:center;color:#94a3b8}.chat-sidebar-empty p{margin:0}.chat-sidebar-empty-hint{margin-top:8px!important;font-size:12px;opacity:.75}.chat-sidebar-toast{margin:8px 12px;padding:8px 12px;background:#ef444426;border:1px solid rgba(239,68,68,.4);color:#fecaca;border-radius:8px;font-size:12px}html[data-theme=light] .chat-sidebar{background:#fff;border-color:#0f19291f;box-shadow:0 24px 60px #0f19291f;color:#1a1a1a}html[data-theme=light] .chat-sidebar-header{border-bottom-color:#0f19291a}html[data-theme=light] .chat-sidebar-entry:hover{background:#0f19290d}html[data-theme=light] .chat-sidebar-entry--active{background:#88c5ab2e}html[data-theme=light] .chat-sidebar-entry--active:hover{background:#88c5ab42}html[data-theme=light] .chat-sidebar-entry-title,html[data-theme=light] .chat-sidebar-entry--active .chat-sidebar-entry-title{color:#0f172a}html[data-theme=light] .chat-sidebar-entry-meta{color:#64748b}html[data-theme=light] .chat-sidebar-entry-doc{color:#0f8a63}html[data-theme=light] .chat-sidebar-entry-delete{color:#64748b}html[data-theme=light] .chat-sidebar-entry-delete:hover{color:#dc2626;background:#dc26261a}html[data-theme=light] .chat-sidebar-empty{color:#64748b}html[data-theme=light] .chat-sidebar-toast{background:#fee2e2;border-color:#fecaca;color:#991b1b}html[data-theme=light] .chat-sidebar-rail-btn,html[data-theme=light] .chat-sidebar-toggle{color:#475569}html[data-theme=light] .chat-sidebar-rail-btn:hover,html[data-theme=light] .chat-sidebar-toggle:hover{background:#0f19290f;color:#0f172a}html[data-theme=light] .chat-sidebar.chat-sidebar--collapsed{background:transparent;border-color:transparent;box-shadow:none}@media(max-width:768px){.chat-with-sidebar{flex-direction:column;height:auto;max-height:96vh}.chat-sidebar{width:100%;max-height:200px}.chat-sidebar--collapsed{width:100%;max-height:56px}.chat-sidebar--collapsed .chat-sidebar-rail{flex-direction:row;padding:8px 12px;justify-content:flex-start}}html[data-math-style] .settings-content{font-size:var(--app-font-size, 14px)}@media(max-width:768px){.settings-screen{flex-direction:column;height:100vh;max-width:100%;border-radius:0}.settings-sidebar{width:100%;max-height:180px;border-right:none;border-bottom:1px solid rgba(148,163,184,.2)}.settings-nav{flex-direction:row;overflow-x:auto}.settings-nav-item{white-space:nowrap}}.doc-source-badge{font-size:11px;color:#94a3b8;margin-top:4px;display:flex;gap:4px;align-items:center}.doc-source-badge:before{content:"👥";font-size:11px;flex-shrink:0}.classes-join-btn{padding:7px 14px;background:var(--teal);color:#0f172a;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;flex-shrink:0}.classes-join-btn:hover{filter:brightness(1.05)}.classes-join-btn:disabled{opacity:.5;cursor:not-allowed}.classes-flash{padding:10px 14px;border-radius:10px;background:#22c55e1f;border:1px solid rgba(34,197,94,.3);color:#86efac;font-size:13px;margin-bottom:14px}.classes-loading{font-size:13px;color:#94a3b8;padding:14px 0}.classes-error{padding:10px 14px;border-radius:10px;background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#fca5a5;font-size:13px}.classes-empty p{margin:0;line-height:1.5}.classes-list{display:flex;flex-direction:column;gap:0}.classes-card{display:flex;flex-direction:column;gap:6px}.classes-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px}.classes-card-name{font-size:15px;font-weight:600;color:#e5e7eb}.classes-card-joined{font-size:11px;color:#64748b;white-space:nowrap;flex-shrink:0}.classes-card-teacher{font-size:13px;color:#94a3b8}.classes-card-desc{font-size:12px;color:#64748b;line-height:1.5;margin-top:2px}.classes-card-actions{margin-top:8px;display:flex;justify-content:flex-end}.classes-leave-btn{padding:5px 12px;background:transparent;border:1px solid rgba(148,163,184,.25);border-radius:6px;color:#94a3b8;font-size:12px;cursor:pointer}.classes-leave-btn:hover{background:#94a3b814;color:#e5e7eb}html[data-theme=light] .classes-card-name{color:#0f172a}html[data-theme=light] .classes-card-teacher,html[data-theme=light] .classes-card-joined,html[data-theme=light] .classes-card-desc{color:#475569}html[data-theme=light] .classes-leave-btn{color:#334155;border-color:#0f192940}html[data-theme=light] .classes-leave-btn:hover{background:#5ba49f1a;border-color:var(--teal-dim);color:var(--teal-dim)}.join-class-backdrop{position:fixed;inset:0;background:#020617bf;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.join-class-modal{background:#0f172a;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:24px;max-width:420px;width:100%;box-shadow:0 16px 48px #00000073}.join-class-modal h2{margin:0 0 6px;font-size:18px;color:#e5e7eb}.join-class-stepper{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.06em}.join-class-step{display:inline-flex;align-items:center;gap:6px}.join-class-step.active{color:var(--teal)}.join-class-step.done{color:#94a3b8}.join-class-step-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:#94a3b84d}.join-class-step.active .join-class-step-dot{background:var(--teal)}.join-class-step.done .join-class-step-dot{background:#94a3b8}.join-class-step-divider{flex-grow:1;height:1px;background:#94a3b833}.join-class-subtitle{margin:0 0 18px;font-size:13px;color:#94a3b8;line-height:1.5}.join-class-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:6px}.join-class-input{display:block;width:100%;padding:10px 12px;background:#02061799;border:1px solid rgba(148,163,184,.25);border-radius:8px;color:#e5e7eb;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:14px;letter-spacing:.05em}.join-class-input:focus{outline:none;border-color:var(--teal)}.join-class-input:disabled{opacity:.6}.join-class-hint{margin-top:6px;font-size:11px;color:#64748b}.join-class-error{margin-top:12px;padding:10px 12px;border-radius:8px;background:#ef444414;border:1px solid rgba(239,68,68,.25);color:#fca5a5;font-size:12px;line-height:1.5}.join-class-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.join-class-btn{padding:7px 14px;background:transparent;border:1px solid rgba(148,163,184,.25);border-radius:8px;color:#cbd5e1;font-size:13px;cursor:pointer;font-family:inherit}.join-class-btn:hover:not(:disabled){background:#94a3b814}.join-class-btn:disabled{opacity:.5;cursor:not-allowed}.join-class-btn--primary{background:var(--teal);border-color:transparent;color:#0f172a;font-weight:600}.join-class-btn--primary:hover:not(:disabled){filter:brightness(1.05)}.educator-app{--edu-bg: var(--bg);--edu-surface: var(--bg2);--edu-surface-2: var(--bg3);--edu-surface-hover: var(--bg4);--edu-border: rgba(148, 163, 184, .12);--edu-border-strong: rgba(148, 163, 184, .25);--edu-text: #e2e8f0;--edu-text-muted: #94a3b8;--edu-text-dim: #64748b;--edu-accent: #60a5fa;--edu-accent-hover: #93c5fd;--edu-accent-bg: rgba(96, 165, 250, .1);--edu-success: #4ade80;--edu-warning: #fbbf24;--edu-danger: #f87171;--edu-danger-bg: rgba(248, 113, 113, .1);--edu-heat-0: #7a6f3d;--edu-heat-1: var(--teal-dim);--edu-heat-2: var(--teal);--edu-heat-3: #c2a04a;--edu-heat-4: var(--gold);--edu-radius: 8px;--edu-radius-sm: 4px;--edu-spacing-tight: 8px;--edu-spacing: 16px;--edu-spacing-loose: 24px;background:var(--edu-bg);color:var(--edu-text);font-size:14px;line-height:1.5;min-height:100vh;font-variant-numeric:tabular-nums}.educator-app *{box-sizing:border-box}.edu-shell{display:flex;min-height:100vh}.edu-sidebar{width:240px;flex-shrink:0;background:var(--edu-surface);border-right:1px solid var(--edu-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}.edu-sidebar-brand{padding:var(--edu-spacing);border-bottom:1px solid var(--edu-border);display:flex;align-items:center;gap:8px}.edu-sidebar-brand img{width:24px;height:24px;border-radius:4px}.edu-sidebar-brand-text{font-size:14px;font-weight:600;color:var(--edu-text)}.edu-sidebar-brand-text-accent{color:var(--gold)}.edu-sidebar-section{padding:var(--edu-spacing) var(--edu-spacing) 8px}.edu-sidebar-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--edu-text-dim);padding:0 var(--edu-spacing) 8px}.edu-sidebar-classes{flex-shrink:0;max-height:30vh;overflow-y:auto}.edu-sidebar-class{display:block;width:100%;text-align:left;padding:8px var(--edu-spacing);background:transparent;border:none;color:var(--edu-text-muted);font-size:13px;cursor:pointer;border-left:2px solid transparent;transition:background .12s,color .12s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:inherit}.edu-sidebar-class:hover{background:var(--edu-surface-hover);color:var(--edu-text)}.edu-sidebar-class.active{background:var(--edu-surface-2);border-left-color:var(--edu-accent);color:var(--edu-text);font-weight:500}.edu-sidebar-create-class{display:flex;align-items:center;gap:6px;width:calc(100% - 32px);margin:8px var(--edu-spacing);padding:7px 10px;background:transparent;border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text-muted);font-size:13px;cursor:pointer;font-family:inherit}.edu-sidebar-create-class:hover{background:var(--edu-surface-hover);color:var(--edu-text);border-color:var(--edu-border-strong)}.edu-sidebar-divider{height:1px;background:var(--edu-border);margin:var(--edu-spacing) 0}.edu-sidebar-nav{flex-grow:1;display:flex;flex-direction:column}.edu-sidebar-tab{display:flex;align-items:center;gap:10px;padding:9px var(--edu-spacing);background:transparent;border:none;border-left:2px solid transparent;color:var(--edu-text-muted);font-size:13px;cursor:pointer;text-align:left;font-family:inherit;transition:background .12s,color .12s}.edu-sidebar-tab:hover{background:var(--edu-surface-hover);color:var(--edu-text)}.edu-sidebar-tab.active{background:var(--edu-surface-2);border-left-color:var(--edu-accent);color:var(--edu-text);font-weight:500}.edu-sidebar-tab-icon{font-size:14px;width:16px;display:inline-flex;justify-content:center;color:var(--edu-text-dim)}.edu-sidebar-tab.active .edu-sidebar-tab-icon{color:var(--edu-accent)}.edu-sidebar-footer{padding:var(--edu-spacing);border-top:1px solid var(--edu-border)}.edu-sidebar-logout{width:100%;padding:7px 10px;background:transparent;border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text-muted);font-size:13px;cursor:pointer;font-family:inherit}.edu-sidebar-logout:hover{background:var(--edu-surface-hover);color:var(--edu-text)}.edu-main{flex-grow:1;min-width:0;display:flex;flex-direction:column}.edu-header{position:sticky;top:0;z-index:5;background:var(--edu-bg);border-bottom:1px solid var(--edu-border);padding:12px var(--edu-spacing-loose);display:flex;align-items:center;gap:12px}.edu-header-title{flex-grow:1;min-width:0}.edu-header-name{font-size:16px;font-weight:600;color:var(--edu-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edu-header-subtitle{font-size:12px;color:var(--edu-text-dim);margin-top:2px}.edu-header-actions{display:flex;align-items:center;gap:8px}.edu-header-button{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:transparent;border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text-muted);font-size:12px;cursor:pointer;font-family:inherit}.edu-header-button:hover{background:var(--edu-surface-hover);color:var(--edu-text)}.edu-header-code{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;color:var(--edu-text);cursor:pointer}.edu-header-code:hover{background:var(--edu-surface-hover)}.edu-header-code-label{color:var(--edu-text-dim);font-family:inherit;font-size:11px}.edu-demo-banner{background:linear-gradient(90deg,#60a5fa1f,#60a5fa0a);border-bottom:1px solid rgba(96,165,250,.3);padding:12px var(--edu-spacing-loose);display:flex;align-items:center;gap:12px}.edu-demo-banner-text{flex-grow:1;font-size:13px;color:var(--edu-text)}.edu-demo-banner-emphasis{color:var(--edu-accent);font-weight:600}.edu-demo-banner-subtle{color:var(--edu-text-muted)}.edu-demo-banner-action{padding:6px 12px;background:var(--edu-accent);color:#0a0e1a;border:none;border-radius:var(--edu-radius-sm);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit}.edu-demo-banner-action:hover{background:var(--edu-accent-hover)}.edu-content{padding:var(--edu-spacing-loose);flex-grow:1}.edu-section{margin-bottom:var(--edu-spacing-loose)}.edu-section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--edu-spacing)}.edu-section-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--edu-text-dim)}.edu-section-meta{font-size:12px;color:var(--edu-text-dim)}.edu-card{background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius);padding:var(--edu-spacing)}.edu-card-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--edu-spacing-tight)}.edu-card-title{font-size:13px;font-weight:600;color:var(--edu-text)}.edu-stat{background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius);padding:var(--edu-spacing)}.edu-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--edu-text-dim);margin-bottom:6px}.edu-stat-value{font-size:24px;font-weight:600;color:var(--edu-text);font-variant-numeric:tabular-nums;line-height:1.1}.edu-stat-suffix{font-size:13px;font-weight:400;color:var(--edu-text-muted);margin-left:4px}.edu-stat-sublabel{font-size:12px;color:var(--edu-text-dim);margin-top:4px}.edu-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--edu-spacing);margin-bottom:var(--edu-spacing-loose)}@media(max-width:1100px){.edu-stat-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.edu-stat-row{grid-template-columns:1fr}}.edu-two-col{display:grid;grid-template-columns:3fr 2fr;gap:var(--edu-spacing)}@media(max-width:1100px){.edu-two-col{grid-template-columns:1fr}}.edu-heatmap-compact-row{display:grid;grid-template-columns:1fr 1fr 80px 80px 80px;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--edu-border);cursor:pointer;transition:background .12s}.edu-heatmap-compact-row:hover{background:var(--edu-surface-hover);margin:0 calc(var(--edu-spacing) * -1);padding:10px var(--edu-spacing)}.edu-heatmap-compact-row:last-child{border-bottom:none}.edu-heatmap-section-cell{min-width:0}.edu-heatmap-section-name{font-size:13px;font-weight:500;color:var(--edu-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.edu-heatmap-section-doc{font-size:11px;color:var(--edu-text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.edu-heatmap-bar-cell{position:relative;height:20px;background:var(--edu-surface-2);border-radius:var(--edu-radius-sm);overflow:hidden}.edu-heatmap-bar-fill{position:absolute;top:0;bottom:0;left:0;border-radius:var(--edu-radius-sm);transition:width .2s}.edu-heatmap-numeric{font-size:12px;color:var(--edu-text-muted);text-align:right;font-variant-numeric:tabular-nums}.edu-heatmap-numeric-strong{color:var(--edu-text)}.edu-activity-list{display:flex;flex-direction:column}.edu-activity-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--edu-border)}.edu-activity-item:last-child{border-bottom:none}.edu-activity-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;font-family:ui-monospace,monospace}.edu-activity-icon.message{background:#60a5fa26;color:var(--edu-accent)}.edu-activity-icon.quiz{background:#4ade8026;color:var(--edu-success)}.edu-activity-icon.join{background:#fbbf2426;color:var(--edu-warning)}.edu-activity-content{flex-grow:1;min-width:0}.edu-activity-text{font-size:13px;color:var(--edu-text);line-height:1.4}.edu-activity-student{font-weight:500}.edu-activity-detail{color:var(--edu-text-muted)}.edu-activity-time{font-size:11px;color:var(--edu-text-dim);margin-top:2px}.edu-empty{text-align:center;padding:var(--edu-spacing-loose) var(--edu-spacing)}.edu-empty-title{font-size:14px;font-weight:500;color:var(--edu-text);margin-bottom:4px}.edu-empty-copy{font-size:13px;color:var(--edu-text-muted);max-width:380px;margin:0 auto var(--edu-spacing);line-height:1.5}.edu-empty-action{padding:7px 14px;background:var(--edu-accent-bg);border:1px solid var(--edu-accent);color:var(--edu-accent);border-radius:var(--edu-radius-sm);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit}.edu-empty-action:hover{background:#60a5fa2e}.edu-engagement-note{margin:4px 0 var(--edu-spacing);font-size:12px;color:var(--edu-text-dim);line-height:1.4}.edu-engagement-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--edu-spacing)}.edu-engagement-section{margin-top:var(--edu-spacing-loose)}.edu-engagement-subtitle{font-size:12px;font-weight:600;color:var(--edu-text-muted);margin-bottom:var(--edu-spacing-tight)}.edu-engagement-trend{display:flex;align-items:flex-end;gap:6px;height:88px}.edu-engagement-trend-col{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.edu-engagement-trend-bar{width:100%;min-height:2px;background:var(--edu-accent);border-radius:var(--edu-radius-sm) var(--edu-radius-sm) 0 0}.edu-engagement-trend-label{margin-top:4px;font-size:10px;color:var(--edu-text-dim);white-space:nowrap}.edu-engagement-docs{display:flex;flex-direction:column;gap:var(--edu-spacing-tight)}.edu-engagement-doc-row{display:grid;grid-template-columns:minmax(0,1.4fr) 2fr minmax(0,auto);align-items:center;gap:var(--edu-spacing)}.edu-engagement-doc-title{font-size:12px;color:var(--edu-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edu-engagement-doc-track{height:8px;background:var(--edu-surface-2);border-radius:999px;overflow:hidden}.edu-engagement-doc-fill{height:100%;background:var(--edu-accent);border-radius:999px}.edu-engagement-doc-count{font-size:11px;color:var(--edu-text-muted);white-space:nowrap}@media(max-width:1100px){.edu-engagement-doc-row{grid-template-columns:minmax(0,1fr) 1.4fr minmax(0,auto)}}.edu-preview-levels{display:flex;flex-direction:column;gap:6px}.edu-preview-level-row{display:grid;grid-template-columns:84px 1fr 32px;align-items:center;gap:var(--edu-spacing-tight)}.edu-preview-level-label{font-size:12px;color:var(--edu-text-muted)}.edu-preview-level-track{height:8px;background:var(--edu-surface-2);border-radius:999px;overflow:hidden}.edu-preview-level-fill{height:100%;background:#a78bfad9;border-radius:999px}.edu-preview-level-count{font-size:11px;color:var(--edu-text-muted);text-align:right}.edu-preview-collecting{font-size:12px;color:var(--edu-text-muted);line-height:1.5}.edu-loading{text-align:center;padding:var(--edu-spacing-loose);color:var(--edu-text-dim);font-size:13px}.edu-loading-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--edu-border);border-top-color:var(--edu-accent);border-radius:50%;animation:edu-spin .8s linear infinite;margin-right:8px;vertical-align:middle}@keyframes edu-spin{to{transform:rotate(360deg)}}.edu-error{padding:var(--edu-spacing);background:var(--edu-danger-bg);border:1px solid var(--edu-danger);border-radius:var(--edu-radius);color:var(--edu-danger);font-size:13px}.edu-toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:1000}.edu-toast{min-width:280px;max-width:380px;padding:10px 14px;background:var(--edu-surface);border:1px solid var(--edu-border-strong);border-radius:var(--edu-radius);color:var(--edu-text);font-size:13px;box-shadow:0 4px 16px #0006;animation:edu-toast-in .18s ease-out}.edu-toast.success{border-left:3px solid var(--edu-success)}.edu-toast.error{border-left:3px solid var(--edu-danger)}.edu-toast.info{border-left:3px solid var(--edu-accent)}@keyframes edu-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.edu-dialog-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:800}.edu-dialog{background:var(--edu-surface);border:1px solid var(--edu-border-strong);border-radius:var(--edu-radius);padding:var(--edu-spacing-loose);max-width:440px;width:calc(100% - 48px)}.edu-dialog-title{font-size:16px;font-weight:600;color:var(--edu-text);margin:0 0 8px}.edu-dialog-body{font-size:13px;color:var(--edu-text-muted);line-height:1.5;margin-bottom:var(--edu-spacing-loose)}.edu-dialog-actions{display:flex;justify-content:flex-end;gap:8px}.edu-button{padding:7px 14px;background:transparent;border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text-muted);font-size:13px;cursor:pointer;font-family:inherit}.edu-button:hover{background:var(--edu-surface-hover);color:var(--edu-text)}.edu-button.primary{background:var(--edu-accent);color:#0a0e1a;border-color:var(--edu-accent);font-weight:500}.edu-button.primary:hover{background:var(--edu-accent-hover)}.edu-button.danger{background:var(--edu-danger-bg);border-color:var(--edu-danger);color:var(--edu-danger)}.edu-button.danger:hover{background:#f871712e}.edu-button.ghost{background:transparent;border-color:transparent}.edu-modal-content{max-width:560px}.edu-modal-content h2{font-size:18px;font-weight:600;color:var(--edu-text);margin:0 0 6px}.edu-modal-subtitle{font-size:13px;color:var(--edu-text-muted);margin:0 0 var(--edu-spacing)}.edu-form-field{margin-bottom:var(--edu-spacing)}.edu-form-label{display:block;font-size:12px;font-weight:500;color:var(--edu-text-muted);margin-bottom:6px}.edu-form-input,.edu-form-textarea{display:block;width:100%;padding:8px 10px;background:var(--edu-bg);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text);font-size:13px;font-family:inherit}.edu-form-input:focus,.edu-form-textarea:focus{outline:none;border-color:var(--edu-accent)}.edu-form-textarea{resize:vertical;min-height:80px}.edu-filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:var(--edu-spacing);padding-bottom:var(--edu-spacing);border-bottom:1px solid var(--edu-border)}.edu-filter-bar select,.edu-filter-bar input{padding:7px 10px;background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text);font-size:13px;font-family:inherit}.edu-filter-meta{margin-left:auto;font-size:12px;color:var(--edu-text-dim)}.edu-heatmap-row{display:grid;grid-template-columns:minmax(180px,2fr) minmax(140px,1.5fr) 70px 70px 60px 16px;gap:12px;align-items:center;padding:10px 0;border-bottom:1px solid var(--edu-border);cursor:pointer;font-size:13px;transition:background .12s}.edu-heatmap-row:hover{background:var(--edu-surface-hover);margin:0 calc(var(--edu-spacing) * -1);padding:10px var(--edu-spacing)}.edu-heatmap-engagement-text{font-size:11px;color:var(--edu-text-dim);font-variant-numeric:tabular-nums;white-space:nowrap}.edu-caret{font-size:10px;color:var(--edu-text-dim);text-align:center;transition:transform .15s}.edu-heatmap-row.expanded .edu-caret{transform:rotate(90deg)}.edu-heatmap-expand{grid-column:1 / -1;padding:var(--edu-spacing);background:var(--edu-surface);border-radius:var(--edu-radius);margin-top:8px;margin-bottom:8px}.edu-expand-section-list{display:flex;flex-direction:column;border-bottom:1px solid var(--edu-border);margin-bottom:var(--edu-spacing);padding-bottom:var(--edu-spacing)}.edu-expand-student-row{display:grid;grid-template-columns:2fr 80px 80px 80px;gap:12px;align-items:center;padding:6px 0;cursor:pointer;font-size:12px;color:var(--edu-text-muted)}.edu-expand-student-row:hover{color:var(--edu-text)}.edu-bloom{margin-top:var(--edu-spacing)}.edu-bloom-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--edu-text-dim);margin-bottom:10px}.edu-bloom-row{display:grid;grid-template-columns:100px 1fr 50px;gap:10px;align-items:center;padding:4px 0;font-size:12px}.edu-bloom-label{color:var(--edu-text-muted)}.edu-bloom-bar{height:12px;background:var(--edu-surface-2);border-radius:var(--edu-radius-sm);overflow:hidden}.edu-bloom-bar-fill{height:100%;border-radius:var(--edu-radius-sm)}.edu-bloom-value{text-align:right;font-variant-numeric:tabular-nums;color:var(--edu-text-muted)}.edu-bloom-placeholder{margin-top:var(--edu-spacing);padding:var(--edu-spacing);background:var(--edu-surface-2);border:1px dashed var(--edu-border-strong);border-radius:var(--edu-radius)}.edu-bloom-placeholder-title{font-size:13px;font-weight:600;color:var(--edu-text-muted);margin-bottom:6px}.edu-bloom-placeholder-copy{font-size:12px;color:var(--edu-text-dim);line-height:1.5}.edu-weighted-count{font-size:11px;color:var(--edu-text-dim);margin-top:2px;font-variant-numeric:tabular-nums}.edu-bloom-badge{display:inline-block;padding:1px 6px;border-radius:var(--edu-radius-sm);font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--edu-text-dim);background:var(--edu-surface-2);margin-left:8px;vertical-align:1px}.edu-student-bloom-strip{margin-bottom:var(--edu-spacing);padding-bottom:var(--edu-spacing);border-bottom:1px solid var(--edu-border)}.edu-student-bloom-strip .edu-bloom{margin-top:0}.edu-bloom-student .edu-bloom-row{grid-template-columns:88px 1fr 44px;gap:8px;padding:3px 0}.edu-bloom-student .edu-bloom-bar{height:10px}.edu-roster-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:var(--edu-spacing);flex-wrap:wrap}.edu-roster-toolbar input{flex-grow:1;min-width:200px;padding:7px 10px;background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text);font-size:13px;font-family:inherit}.edu-roster-toolbar select{padding:7px 10px;background:var(--edu-surface);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);color:var(--edu-text);font-size:13px;font-family:inherit}.edu-roster-toggle{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--edu-text-muted)}.edu-roster-bulk-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--edu-accent-bg);border:1px solid var(--edu-accent);border-radius:var(--edu-radius-sm);margin-bottom:var(--edu-spacing);font-size:12px;color:var(--edu-text)}.edu-roster-table{width:100%;border-collapse:collapse;font-size:13px}.edu-roster-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--edu-text-dim);padding:8px 12px 8px 0;border-bottom:1px solid var(--edu-border)}.edu-roster-table th .edu-th-disambiguator{display:block;font-size:10px;font-weight:400;color:var(--edu-text-dim);text-transform:none;letter-spacing:0;margin-top:2px}.edu-roster-table td{padding:10px 12px 10px 0;border-bottom:1px solid var(--edu-border);color:var(--edu-text-muted);font-variant-numeric:tabular-nums}.edu-roster-table tr{cursor:pointer}.edu-roster-table tr:hover{background:var(--edu-surface-hover)}.edu-roster-table tr.removed{opacity:.6}.edu-roster-table tr.removed .edu-roster-name{text-decoration:line-through}.edu-roster-name{color:var(--edu-text);font-weight:500}.edu-status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle}.edu-status-dot.green{background:var(--edu-success)}.edu-status-dot.yellow{background:var(--edu-warning)}.edu-status-dot.red{background:var(--edu-danger)}.edu-status-dot.gray{background:var(--edu-text-dim)}.edu-roster-status{white-space:nowrap}.edu-back-link{display:inline-block;background:transparent;border:none;color:var(--edu-text-muted);font-size:13px;cursor:pointer;padding:0;margin-bottom:var(--edu-spacing);font-family:inherit}.edu-back-link:hover{color:var(--edu-text)}.edu-detail-header{margin-bottom:var(--edu-spacing-loose)}.edu-detail-header h1{font-size:20px;font-weight:600;color:var(--edu-text);margin:0 0 4px}.edu-detail-header-email{font-size:13px;color:var(--edu-text-dim);margin-bottom:8px}.edu-detail-meta{display:flex;gap:var(--edu-spacing);font-size:12px;color:var(--edu-text-muted)}.edu-detail-meta span{display:inline-flex;align-items:center;gap:6px}.edu-engagement-strip{display:flex;gap:3px;margin:var(--edu-spacing) 0}.edu-engagement-day{width:14px;height:14px;border-radius:2px;background:var(--edu-surface-2)}.edu-engagement-day.l1{background:#60a5fa40}.edu-engagement-day.l2{background:#60a5fa80}.edu-engagement-day.l3{background:#60a5fabf}.edu-engagement-day.l4{background:var(--edu-accent)}.edu-detail-doc-section{border:1px solid var(--edu-border);border-radius:var(--edu-radius);margin-bottom:var(--edu-spacing);overflow:hidden}.edu-detail-doc-header{background:var(--edu-surface-2);padding:10px var(--edu-spacing);display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:13px;font-weight:500;color:var(--edu-text)}.edu-detail-doc-body{padding:var(--edu-spacing)}.edu-detail-section-row{display:grid;grid-template-columns:2fr 1fr 80px 80px;gap:12px;align-items:center;padding:6px 0;font-size:12px;color:var(--edu-text-muted);border-bottom:1px solid var(--edu-border)}.edu-detail-section-row:last-child{border-bottom:none}.edu-detail-section-bar{height:8px;background:var(--edu-surface-2);border-radius:4px;overflow:hidden}.edu-detail-section-bar-fill{height:100%;border-radius:4px}.edu-settings-group{border-bottom:1px solid var(--edu-border);padding:var(--edu-spacing-loose) 0}.edu-settings-group:first-child{padding-top:0}.edu-settings-group:last-child{border-bottom:none}.edu-settings-group h3{font-size:14px;font-weight:600;color:var(--edu-text);margin:0 0 4px}.edu-settings-group-subtitle{font-size:12px;color:var(--edu-text-dim);margin-bottom:var(--edu-spacing)}.edu-settings-row{display:flex;align-items:center;justify-content:space-between;gap:var(--edu-spacing);padding:8px 0}.edu-settings-row-label{font-size:13px;color:var(--edu-text)}.edu-settings-row-sub{font-size:12px;color:var(--edu-text-dim);margin-top:2px}.edu-toggle{position:relative;width:36px;height:20px;background:var(--edu-surface-2);border-radius:10px;cursor:pointer;transition:background .18s;border:1px solid var(--edu-border)}.edu-toggle.on{background:var(--edu-accent)}.edu-toggle:after{content:"";position:absolute;top:1px;left:1px;width:16px;height:16px;background:var(--edu-bg);border-radius:50%;transition:transform .18s}.edu-toggle.on:after{transform:translate(16px)}.edu-join-code-display{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;background:var(--edu-bg);border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:14px;font-weight:500;color:var(--edu-text)}.edu-warning-text{color:var(--edu-warning);font-size:12px;margin-top:6px}.edu-danger-zone{margin-top:var(--edu-spacing-loose);padding:var(--edu-spacing);border:1px solid var(--edu-danger);border-radius:var(--edu-radius);background:#f871710a}.edu-danger-zone h3{color:var(--edu-danger);margin:0 0 6px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.edu-shared-doc-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--edu-border)}.edu-shared-doc-row:last-child{border-bottom:none}.edu-shared-doc-meta{font-size:12px;color:var(--edu-text-dim)}.edu-doc-picker{max-height:360px;overflow-y:auto;border:1px solid var(--edu-border);border-radius:var(--edu-radius-sm)}.edu-doc-picker-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--edu-border);cursor:pointer}.edu-doc-picker-row:last-child{border-bottom:none}.edu-doc-picker-row:hover{background:var(--edu-surface-hover)}.edu-doc-picker-row.selected{background:var(--edu-accent-bg)}.edu-doc-picker-name{font-size:13px;color:var(--edu-text)}.edu-doc-picker-meta{font-size:11px;color:var(--edu-text-dim)}@media(max-width:900px){.edu-sidebar{width:200px}.edu-content{padding:var(--edu-spacing)}.edu-roster-table th,.edu-roster-table td{padding-right:8px}}:root{color-scheme:dark;--gold: #e8b84b;--gold-dim: rgba(232, 184, 75, .12);--teal: #5ba49f;--teal-dim: #3d7a76;--bg: #0b1220;--bg2: #0f1929;--bg3: #141f30;--bg4: #1a2840;--navy: #1e3050;--white: #f0f4f8;--white-dim: rgba(240, 244, 248, .65)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg);color:#e5e7eb;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;font-size:var(--app-font-size, 14px)}#root{min-height:100vh}
