:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f6f7fb;background-color:#090b13;--page-padding: clamp(1rem, 4vw, 3rem)}*{box-sizing:border-box}html{width:100%;min-height:100%}body{margin:0;min-height:100vh;width:100%;overflow-x:hidden;background:radial-gradient(circle at top,#1d2540,#070a10 60%)}#root{min-height:100vh;width:100%}.app-shell{width:100%;max-width:none;margin:0;padding:2.5rem var(--page-padding) 4rem;display:flex;flex-direction:column;gap:2rem}.app-header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.brand{display:flex;flex-direction:column;gap:.25rem}.brand-logo{width:220px;height:auto;object-fit:contain}.user-chip{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;border-radius:1rem;border:1px solid rgba(129,159,255,.3);background:#090b13cc}.user-menu{position:relative}.user-menu-panel{position:absolute;right:0;top:110%;background:#090b13f2;border:1px solid rgba(129,159,255,.25);border-radius:.75rem;padding:.75rem;display:flex;flex-direction:column;gap:.5rem;min-width:200px;box-shadow:0 12px 30px #03040a73;z-index:20}.header-actions{display:flex;align-items:flex-start;gap:1rem}.session-timer-card{min-width:240px;border:1px solid rgba(129,159,255,.4);border-radius:1rem;padding:.9rem 1.1rem;background:#090b13cc;box-shadow:inset 0 1px #ffffff08}.timer-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.timer-status{font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .7rem;border-radius:999px;border:1px solid rgba(129,159,255,.3);color:#c9d2ff}.timer-status.running{border-color:#6feebc99;color:#6fee9e}.timer-status.paused{border-color:#ffb34799;color:#ffcf7a}.timer-status.finished{border-color:#ff6e9e99;color:#ff9bbf}.timer-display{margin-top:.65rem;display:flex;align-items:baseline;gap:1rem}.timer-value{font-size:2.15rem;font-weight:700;letter-spacing:.05em}.timer-meta{display:flex;flex-direction:column;gap:.15rem;font-size:.85rem;color:#8fa4ff}.timer-actions{margin-top:.75rem;display:flex}.timer-note{font-size:.75rem;color:#ffcf7a}.auto-pause-hint{margin:.5rem 0 0;font-size:.82rem;color:#ffcf7a}.user-name{margin:0;font-weight:600}.user-role{margin:0;font-size:.85rem;color:#9bb0ff}.eyebrow{letter-spacing:.3em;text-transform:uppercase;color:#7f8ab2;font-size:.8rem;margin-bottom:.2rem}h1{margin:0;font-size:2.5rem}.subtitle{margin-top:.75rem;color:#c7cee5}.layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;align-items:flex-start}.sidebar{display:flex;flex-direction:column;gap:1.25rem}.card{background:#0d0f19e6;border:1px solid rgba(129,159,255,.2);padding:1.5rem;border-radius:1rem;color:#d9e2ff;box-shadow:0 20px 60px #03040a99}.card h2,.card h3{margin-top:0}.card ol{margin:.5rem 0 0;padding-left:1.25rem;line-height:1.5}.card ul{margin:.5rem 0 0;padding-left:1rem}.muted{color:#8e99c8;font-size:.9rem}.auth-main{display:flex;justify-content:center;padding:2rem 0 4rem}.auth-card{max-width:480px;text-align:left}.admin-card ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.65rem}.admin-card li{border-bottom:1px solid rgba(129,159,255,.15);padding-bottom:.5rem}.admin-card li:last-child{border-bottom:none}.content-panel{background:#07090fe6;border:1px solid rgba(129,159,255,.2);border-radius:1.5rem;display:flex;flex-direction:column;min-height:75vh;padding:1.25rem;box-shadow:0 20px 80px #03040abf;gap:1rem}.chat-view{flex:1;display:flex;flex-direction:column;gap:1rem}.mode-toggle{display:inline-flex;border:1px solid rgba(129,159,255,.4);border-radius:999px;overflow:hidden}.mode-btn{padding:.35rem 1rem;background:transparent;border:none;color:#9bb0ff;font-weight:600;cursor:pointer;transition:background .12s,color .12s}.mode-btn.active{background:#819fff33;color:#f4f5fb}.mode-btn:not(.active):hover{background:#819fff1a}.quiz-panel{border:1px dashed rgba(129,159,255,.35);border-radius:1rem;padding:1rem;background:#0b0d17d9}.quiz-head{display:flex;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.quiz-head h2{margin:.25rem 0}.quiz-controls{display:flex;flex-direction:column;gap:.4rem;min-width:240px}.quiz-controls input{background:#090b14e6;border:1px solid rgba(129,159,255,.3);border-radius:.75rem;padding:.5rem .85rem;color:#f4f5fb}.quiz-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.quiz-buttons .finish{border-color:#ff8c8c99;color:#ffb0b0}.quiz-question-list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:1rem}.quiz-question{border:1px solid rgba(129,159,255,.2);border-radius:1rem;padding:.85rem;background:#090c14b3}.quiz-question.correct{border-color:#47d9be99}.quiz-question.incorrect{border-color:#ff8c8c99}.quiz-question-prompt{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.65rem}.quiz-badge{font-size:.8rem;border:1px solid rgba(129,159,255,.4);border-radius:999px;padding:.1rem .55rem;color:#9bb0ff}.quiz-choices{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem}.quiz-choice{display:flex;align-items:center;gap:.5rem;padding:.65rem .85rem;border-radius:.85rem;border:1px solid rgba(129,159,255,.3);background:#0d101aa6;color:#f4f5fb;cursor:pointer;transition:border-color .12s,transform .12s}.quiz-choice:not(:disabled):hover{border-color:#819fff99;transform:translateY(-1px)}.quiz-choice.correct{border-color:#47d9bea6}.quiz-choice.selected{border-color:#819fffd9}.quiz-choice:disabled{opacity:.55;cursor:not-allowed}.choice-key{font-weight:600;color:#9bb0ff}.quiz-feedback{margin-top:.65rem;display:flex;justify-content:space-between;align-items:center;gap:.75rem;font-size:.9rem}.quiz-feedback.correct{color:#52d7b0}.quiz-feedback.incorrect{color:#ff9b9b}.quiz-feedback button{border:none;background:none;color:#9bb0ff;cursor:pointer}.quiz-explanation{margin:.4rem 0 0;font-size:.9rem;color:#d6dbff;background:#0a0e18e6;border-radius:.75rem;padding:.65rem}.quiz-summary-card ul{margin:.75rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.75rem}.quiz-summary-row{width:100%;display:flex;justify-content:space-between;gap:.5rem;font-size:.95rem;border:none;background:#0f121e99;color:#d9e2ff;border-radius:.75rem;padding:.35rem .65rem;cursor:pointer;transition:background .12s,color .12s}.quiz-summary-row .focus{font-weight:600}.quiz-summary-row:hover{background:#819fff40;color:#f4f5fb}.review-topics{margin:.35rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:.35rem;font-size:.85rem}.review-topics li{display:flex;justify-content:space-between;align-items:center;gap:.35rem;color:#c1c9ff}.review-topics button{border:none;background:#819fff33;color:#f6f7fb;border-radius:.6rem;padding:.2rem .6rem;font-size:.75rem;cursor:pointer}.review-card{background:#0d101ae6}.review-list .quiz-question{padding:.75rem}.secondary-btn.tiny{font-size:.75rem;padding:.35rem .55rem;border-radius:.65rem}.chat-window{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem;padding-right:.5rem}.bubble{padding:1rem 1.25rem;border-radius:1.1rem;max-width:85%;position:relative}.bubble header{font-weight:600;margin-bottom:.25rem}.bubble p{margin:0;line-height:1.45}.bubble.assistant{background:#5566b440;border:1px solid rgba(142,173,255,.5);align-self:flex-start}.bubble.assistant.ghost{opacity:.6}.bubble.user{background:#47d9be26;border:1px solid rgba(71,217,190,.45);align-self:flex-end}.timestamp{display:inline-block;margin-top:.5rem;font-size:.75rem;color:#98a9d8}.composer{margin-top:1rem;display:flex;flex-direction:column;gap:.75rem}.composer textarea{width:100%;resize:none;background:#0f121ef2;border:1px solid rgba(129,159,255,.25);border-radius:1rem;padding:1rem;color:#f4f5fb;font-size:1rem;line-height:1.5}.composer textarea:focus{outline:2px solid rgba(120,173,255,.7)}.composer-actions{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.status{color:#9bb0ff;font-size:.9rem;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.error{color:#ff8ba7}.composer .send-btn{border:none;background:linear-gradient(125deg,#5f7bff,#57d9be);color:#060910;font-weight:600;padding:.85rem 1.5rem;border-radius:999px;cursor:pointer;transition:opacity .15s,transform .15s}.composer .send-btn:disabled{opacity:.6;cursor:not-allowed}.composer .send-btn:not(:disabled):hover{transform:translateY(-1px)}.voice-btn{flex:1;border:1px dashed rgba(129,159,255,.6);background:#0a0e19cc;color:#d5ddff;padding:.85rem 1rem;border-radius:999px;font-weight:600;cursor:pointer;transition:border-color .12s,color .12s,box-shadow .12s}.voice-btn.recording{border-color:#ffb347;color:#ffcf7a;box-shadow:0 0 12px #ffb34766}.voice-btn.processing{border-color:#6ac9ff;color:#6ac9ff}.voice-btn:disabled{opacity:.5;cursor:not-allowed}.transcript-hint{margin:.35rem 0 0;font-size:.85rem;color:#95a5dd}.transcript-hint button{background:none;border:none;color:#76d8ff;cursor:pointer;padding:0;margin-left:.25rem}.transcript-hint em{font-style:normal;color:#d8e0ff}.toggle-row{display:flex;align-items:center;gap:.5rem;margin:.75rem 0}.toggle-row input{width:1rem;height:1rem;accent-color:#5f7bff}.secondary-btn{border:1px solid rgba(129,159,255,.5);background:transparent;color:#dae3ff;padding:.65rem 1rem;border-radius:.85rem;cursor:pointer;transition:border-color .12s,color .12s}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.secondary-btn:not(:disabled):hover{border-color:#76d8ff;color:#76d8ff}.secondary-btn.warning:not(:disabled){border-color:#ffb347cc;color:#ffcf7a}.secondary-btn.warning:not(:disabled):hover{border-color:#ffd99c;color:#ffd99c}.session-primary-btn{border:none;background:linear-gradient(120deg,#6ac9ff,#5f7bff);color:#061023;font-weight:700;padding:.95rem 1.8rem;border-radius:999px;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:0 10px 25px #5d87ff66}.session-primary-btn:hover{transform:translateY(-1px)}.session-primary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.session-overlay{position:fixed;inset:0;background:#05070dd1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:30;display:flex;align-items:center;justify-content:center;padding:2rem 1.25rem}.session-overlay-panel{width:min(520px,100%);background:#0b0e18f2;border:1px solid rgba(129,159,255,.4);border-radius:1.25rem;padding:2rem;text-align:center;box-shadow:0 30px 80px #00000073}.overlay-description{margin:.75rem 0 1.5rem;color:#c7cee5}.overlay-timer{display:flex;flex-direction:column;gap:.25rem;align-items:center}.overlay-timer-value{font-size:2.5rem;font-weight:700;letter-spacing:.1em}.overlay-length{font-size:.9rem;color:#9bb0ff}.overlay-duration-picker{margin:1.5rem 0;display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.duration-option{border:1px solid rgba(129,159,255,.4);border-radius:999px;background:transparent;color:#d8e0ff;padding:.65rem 1.4rem;font-weight:600;cursor:pointer;transition:border-color .12s,background .12s,color .12s}.duration-option.active{background:#819fff40;border-color:#7f9dff;color:#fff}.duration-option:disabled{opacity:.5;cursor:not-allowed}.overlay-actions{display:flex;justify-content:center}.small{font-size:.85rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}@media(max-width:960px){.app-header{flex-direction:column;align-items:flex-start}.header-actions{width:100%;flex-direction:column}.session-timer-card,.user-chip{width:100%}.layout{grid-template-columns:1fr}.content-panel{height:auto;min-height:60vh}.syllabus-layout{grid-template-columns:1fr}.syllabus-hero{position:static}}.portal-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.portal-nav-btn{border:1px solid rgba(129,159,255,.35);background:transparent;color:#9bb0ff;border-radius:999px;padding:.35rem 1rem;font-weight:600;cursor:pointer;transition:background .12s,color .12s,border-color .12s}.portal-nav-btn.active{background:#819fff33;border-color:#819fffcc;color:#f6f7fb}.portal-panel{display:grid;gap:1.5rem;margin-top:1rem}.portal-banner{border:1px solid rgba(129,159,255,.35);border-radius:1rem;padding:1rem 1.25rem;background:#080b14e6;display:flex;flex-direction:column;gap:.35rem}.portal-banner.instructor{box-shadow:0 10px 40px #7293ff33}.portal-banner.admin{box-shadow:0 10px 40px #ffb47a40}.portal-panel.instructor-view{grid-template-columns:minmax(320px,420px) 1fr}.portal-panel.admin-view{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.syllabus-layout{display:grid;grid-template-columns:minmax(280px,340px) 1fr;gap:1.5rem;margin-top:1rem;align-items:flex-start}.syllabus-hero{position:sticky;top:1rem;display:flex;flex-direction:column;gap:1rem}.syllabus-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.syllabus-steps li{display:flex;gap:.75rem;align-items:flex-start}.syllabus-step-dot{width:.9rem;height:.9rem;border-radius:50%;background:linear-gradient(135deg,#74f2c9,#4c7bff);box-shadow:0 0 12px #74f2c966;margin-top:.25rem;flex-shrink:0}.syllabus-cta{display:flex;gap:.75rem;flex-wrap:wrap}.syllabus-grid{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.syllabus-card{display:flex;flex-direction:column;gap:.75rem}.syllabus-card-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.syllabus-duration{font-size:.85rem;color:#9bb0ff}.syllabus-pills{display:flex;flex-wrap:wrap;gap:.4rem}.syllabus-pill{border:1px solid rgba(129,159,255,.3);border-radius:999px;padding:.15rem .65rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#dfe7ff;background:#819fff1f}.syllabus-checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem}.syllabus-checklist li{display:flex;gap:.35rem;align-items:flex-start;color:#cbd5ff}.syllabus-checklist li:before{content:"✓";color:#7ef2cf;font-weight:700;font-size:.85rem;margin-top:.1rem}.syllabus-actions{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:auto}.primary-btn.small,.secondary-btn.small{padding:.45rem 1rem;font-size:.85rem}.full-bleed{width:calc(100% + (var(--page-padding) * 2));margin-left:calc(-1 * var(--page-padding));margin-right:calc(-1 * var(--page-padding));padding-left:clamp(.5rem,3vw,2rem);padding-right:clamp(.5rem,3vw,2rem);box-sizing:border-box}.flashcards-shell{display:flex;flex-direction:column;gap:1.5rem;margin-top:1rem;width:100%;margin:0;padding:0;overflow:hidden}.flashcards-topbar{display:flex;flex-wrap:wrap;gap:1rem;align-items:flex-start;justify-content:space-between}.flashcards-topbar .topbar-left{max-width:520px}.flashcards-topbar .topbar-right{display:flex;flex-direction:column;align-items:flex-end;gap:.4rem}.flashcard-status{font-weight:600;color:#9bb0ff}.flashcard-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.flashcards-stage{display:flex;flex-direction:column;gap:1rem;align-items:stretch;width:100%}.flashcards-logo{display:flex;justify-content:center;width:100%}.flashcards-logo img{max-width:320px;width:min(60%,320px)}.flashcard-card{width:100%;min-height:320px;background:#050810eb;border:1px solid rgba(129,159,255,.25);border-radius:1.5rem;padding:2.5rem;position:relative;overflow:hidden;box-shadow:0 12px 40px #04060cb3;transition:transform var(--flashcard-transition, .6s) ease,opacity var(--flashcard-transition, .6s) ease}.flashcard-card.phase-answer{box-shadow:0 12px 50px #55ffd240}.flashcard-badge{position:absolute;top:1rem;right:1rem;padding:.4rem .85rem;border-radius:999px;border:1px solid rgba(129,159,255,.4);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;color:#b2c0ff}.flashcard-content{display:flex;align-items:center;justify-content:stretch;text-align:left;font-size:clamp(1.5rem,2.2vw,2.4rem);line-height:1.4;width:100%;height:100%}.flashcard-question{color:#f6f7fb;width:100%;display:block}.flashcard-answer{color:#7ef2cf;font-weight:600;width:100%;display:block}.flashcard-progress{position:absolute;left:0;right:0;bottom:0;height:6px;background:#060a14cc}.flashcard-progress-bar{height:100%;width:0%;background:linear-gradient(90deg,#5f7bff,#7af4ff);transition-property:width;transition-timing-function:linear}.flashcards-controls{width:100%;border-top:1px solid rgba(129,159,255,.2);padding-top:1rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.flashcards-controls label{display:flex;flex-direction:column;font-size:.85rem;gap:.35rem;color:#9bb0ff}.flashcards-controls input{background:#070a12e6;border:1px solid rgba(129,159,255,.3);border-radius:.5rem;color:#f3f5ff;padding:.35rem .5rem;width:90px}.controls-left,.controls-right{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem}@media(max-width:900px){.portal-panel.instructor-view,.portal-panel.admin-view{grid-template-columns:1fr}.flashcards-topbar{flex-direction:column}.flashcards-topbar .topbar-right{align-items:flex-start}.flashcard-actions{justify-content:flex-start}}.card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.roster-list,.pairing-list,.detail-quiz-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.roster-row,.pairing-list li,.detail-quiz-list li{border:1px solid rgba(129,159,255,.2);border-radius:.85rem;background:#070a12cc;padding:.8rem 1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.roster-row{width:100%;cursor:pointer;color:inherit;text-align:left;border:1px solid rgba(129,159,255,.25);background:#050810e6;transition:border-color .12s,box-shadow .12s;display:flex;justify-content:space-between;gap:.75rem;flex-wrap:wrap}.roster-row.active{border-color:#819fffcc;box-shadow:0 0 0 1px #819fff4d}.roster-row .student-name{margin:0}.roster-row>div:first-child{flex:1 1 55%}.student-stats{display:flex;flex-direction:column;font-size:.85rem;color:#cfd6ff;text-align:right;flex:0 1 120px}.detail-card,.admin-pair-card{display:flex;flex-direction:column;gap:1rem}.detail-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.metric-value{font-size:1.5rem;font-weight:700;margin:.2rem 0 0}.detail-quiz-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.detail-quiz-list li{flex-wrap:wrap;cursor:default}.detail-quiz-list.selectable li{cursor:pointer;border:1px solid transparent;padding:.75rem;border-radius:.75rem;transition:border-color .12s,box-shadow .12s}.detail-quiz-list.selectable li.active{border-color:#819fffcc;box-shadow:0 0 0 1px #819fff33}.score-pill{display:flex;flex-direction:column;text-align:right;font-weight:600;gap:.15rem}.detail-section{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.detail-section-head{display:flex;justify-content:space-between;align-items:center}.session-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.session-row{width:100%;border:1px solid rgba(129,159,255,.25);border-radius:.75rem;background:#060910e6;padding:.75rem 1rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:.75rem;color:inherit;transition:border-color .12s,box-shadow .12s}.session-row.active{border-color:#819fffcc;box-shadow:0 0 0 1px #819fff4d}.session-count{font-size:.85rem;color:#ffffffb3}.session-detail-card,.quiz-detail-panel{max-height:650px;overflow:hidden}.session-detail-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.session-detail-scroll{max-height:550px;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;padding-right:.5rem}.session-message{border:1px solid rgba(129,159,255,.25);border-radius:.75rem;padding:.75rem 1rem;background:#070a12e6}.session-message.assistant{border-color:#73b9ff66}.session-message header{font-size:.85rem;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .35rem;color:#fffc}.quiz-detail-panel{margin-top:1rem;border:1px solid rgba(129,159,255,.25);border-radius:.75rem;padding:.75rem 1rem;background:#060910e6;max-height:650px;overflow:hidden}.quiz-detail-content{display:flex;flex-direction:column;gap:.75rem;max-height:550px;overflow-y:auto;padding-right:.5rem}.pair-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;align-items:end}.pair-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.pair-form select{background:#090b14e6;border:1px solid rgba(129,159,255,.35);border-radius:.75rem;color:#f4f5fb;padding:.5rem .75rem;font-size:.95rem}.pairing-line{margin:0;font-weight:600}.pairing-list li{justify-content:space-between;flex-wrap:wrap;gap:.75rem}.pairing-list li>div{flex:1 1 220px}.pairing-list li .secondary-btn{margin-left:auto}.primary-btn{border:none;background:linear-gradient(120deg,#6ac9ff,#5f7bff);color:#061023;font-weight:600;padding:.65rem 1.5rem;border-radius:999px;cursor:pointer;transition:transform .12s,box-shadow .12s;box-shadow:0 8px 20px #5d87ff59}.primary-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.handbook-page{margin-top:1rem}.handbook-shell{display:flex;flex-direction:column;gap:1.5rem}.handbook-header{display:flex;flex-direction:column;gap:.75rem}.handbook-body{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:1.5rem;align-items:flex-start}.handbook-sidebar{display:flex;flex-direction:column;gap:1.25rem}.handbook-sidebar-section h3,.handbook-syllabus h3{margin-top:0}.handbook-book-picker{display:flex;flex-direction:column;gap:.5rem}.handbook-book-select{border-radius:.75rem;border:1px solid rgba(129,159,255,.35);background:#090b14cc;color:#f6f7fb;padding:.45rem .65rem;font-size:.95rem}.handbook-toc{list-style:none;margin:0;padding:0;max-height:420px;overflow:auto}.handbook-toc-item{margin:0}.handbook-toc-button{width:100%;border:none;background:transparent;color:inherit;padding:.35rem .5rem;border-radius:.65rem;display:flex;gap:.5rem;align-items:center;cursor:pointer;transition:background .12s,color .12s}.handbook-toc-button:hover,.handbook-toc-button.active{background:#6f91ff2e;color:#f8fbff}.handbook-toc-button:disabled{opacity:.5;cursor:not-allowed}.handbook-toc-page{font-size:.75rem;color:#8aa2ff;min-width:3rem}.handbook-toc-children{list-style:none;margin:0;padding:0 0 0 1rem;border-left:1px solid rgba(129,159,255,.25)}.handbook-syllabus{border-top:1px solid rgba(129,159,255,.2);padding-top:1rem;display:flex;flex-direction:column;gap:.75rem}.handbook-syllabus-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.handbook-syllabus-card{border:1px solid rgba(129,159,255,.2);border-radius:.8rem;padding:.75rem .9rem;display:flex;gap:.75rem;align-items:center;justify-content:space-between;background:#070a12e6}.handbook-viewer{padding:0;background:linear-gradient(135deg,#070b18,#0c1328)}.handbook-viewer-toolbar{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid rgba(129,159,255,.2)}.handbook-viewer-details{display:flex;flex-direction:column;gap:.15rem}.handbook-viewer-details span{font-size:.85rem;color:#ffffffb3}.handbook-viewer-actions{display:flex;gap:.5rem;flex-wrap:wrap}.handbook-viewer-canvas{padding:1rem;min-height:400px;display:flex;justify-content:center;align-items:flex-start;background:#050913}.handbook-page-frame{width:clamp(260px,90%,920px);border-radius:.75rem;background:#0b1124;border:1px solid rgba(255,255,255,.08);overflow:hidden;box-shadow:0 30px 70px #03040a99}.handbook-page-frame object,.handbook-page-frame img{width:100%;height:auto;border:none;display:block;background:#0b1124}@media(max-width:960px){.handbook-body{grid-template-columns:1fr}}.classroom-page,.ground-shell{display:flex;flex-direction:column;gap:1.5rem}.ground-hero{display:flex;gap:1.5rem;align-items:flex-start;justify-content:space-between;background:linear-gradient(135deg,#344bff1a,#73c0ff14)}.ground-hero-actions{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.ground-hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem;padding:.75rem;border-radius:.75rem;background:#ffffff08;min-width:260px}.ground-hero-stats strong{font-size:1.25rem;color:#e7edff}.ground-grid{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:1rem;align-items:start}.ground-outline{position:sticky;top:1rem;display:flex;flex-direction:column;gap:.75rem}.outline-head{display:flex;align-items:center;justify-content:space-between}.ground-section-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.ground-section{border:1px solid rgba(129,159,255,.15);border-radius:.85rem;overflow:hidden}.ground-section-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.ground-section.active{border-color:#819fff80;box-shadow:0 12px 30px #03040a66}.ground-section-btn{width:100%;background:none;border:none;color:inherit;text-align:left;padding:.9rem 1rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;cursor:pointer}.ground-section-btn:hover{background:#ffffff05}.ground-section-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}.ground-section-meta .pill{margin-left:auto}.ground-lesson{display:flex;flex-direction:column;gap:1rem}.lesson-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.lesson-meta{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.lesson-body{display:flex;flex-direction:column;gap:1rem}.lesson-flow .flow-steps{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.35rem}.lesson-reading ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.lesson-reading li{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem;border:1px solid rgba(129,159,255,.15);border-radius:.75rem}.lesson-script p{margin:.35rem 0}.lesson-drills ul{list-style:disc;padding-left:1.25rem;margin:.25rem 0 0}.lesson-actions{display:flex;flex-wrap:wrap;gap:.5rem}.lesson-controls{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.75rem}.lesson-step{display:flex;flex-direction:column;gap:.5rem}.voice-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.modal-backdrop{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:30}.modal{background:#090b13f2;border:1px solid rgba(129,159,255,.25);border-radius:.85rem;padding:1rem;width:min(480px,90vw);color:#f6f7fb;box-shadow:0 20px 60px #03040a99}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.settings-section{display:flex;flex-direction:column;gap:.75rem}.settings-section .voice-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.settings-section .voice-row select{background:#0c101c;border:1px solid rgba(129,159,255,.4);color:#f6f7fb;border-radius:.5rem;padding:.35rem .6rem}.settings-section .voice-row select option{background:#0c101c;color:#f6f7fb}.voice-page,.voice-lab{display:flex;flex-direction:column;gap:1rem}.grid-two{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.chip-row{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:.5rem}.button-row{display:flex;gap:.5rem;flex-wrap:wrap}.voice-transcripts{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-top:.75rem}.live-class-voice{margin-bottom:1rem}.live-voice-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.transcript-log{margin-top:.5rem}.transcript-log ul{list-style:none;padding:0;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.35rem}.transcript-log li{display:flex;align-items:flex-start;gap:.5rem}.syllabus-modal{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem}.syllabus-modal.scrollable{max-height:70vh;overflow-y:auto;padding-right:.5rem}.syllabus-modal-item{border:1px solid rgba(129,159,255,.2);padding:.75rem;border-radius:.75rem;background:#0a0c14d9}.step-head{display:flex;align-items:center;justify-content:space-between}.step-actions{display:flex;gap:.5rem;flex-wrap:wrap}.card-subtle{border:1px dashed rgba(129,159,255,.2);border-radius:.85rem;padding:.75rem;background:#070a10b3}.lesson-help textarea{width:100%;background:#ffffff0a;border:1px solid rgba(129,159,255,.2);border-radius:.5rem;padding:.75rem;color:#f6f7fb;min-height:80px;resize:vertical}.help-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.help-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.help-list{list-style:none;padding:0;margin:.5rem 0 0;display:flex;flex-direction:column;gap:.4rem}.help-list li{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.6rem;border:1px solid rgba(129,159,255,.15);border-radius:.65rem}.lesson-quizzes .quiz-history-list{list-style:none;padding:0;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.5rem}.lesson-quizzes .quiz-history-list li{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;border:1px solid rgba(129,159,255,.15);border-radius:.65rem}.pill{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;border-radius:999px;background:#819fff1f;color:#e7edff;font-size:.85rem}.pill.success{background:#39d78626;color:#a1f4c9}.pill.warning{background:#ffcb7026;color:#ffdf9b}.pill.muted{background:#ffffff0d;color:#cdd6f3}.ghost-btn{background:transparent;border:1px solid rgba(129,159,255,.25);color:#cdd6f3;padding:.5rem .9rem;border-radius:.65rem;cursor:pointer}.ghost-btn:hover{background:#ffffff0a}.ghost-btn.tiny{padding:.3rem .65rem;font-size:.85rem}.help-request-list{list-style:none;padding:0;margin:.25rem 0 0;display:flex;flex-direction:column;gap:.65rem}.help-request-card{border:1px solid rgba(129,159,255,.15);border-radius:.85rem;padding:.75rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.help-request-card p{margin:.1rem 0}.help-request-actions{display:flex;align-items:center;gap:.5rem}.reset-row{display:flex;gap:.5rem;flex-wrap:wrap}@media(max-width:1080px){.ground-grid{grid-template-columns:1fr}.ground-outline{position:static}.ground-hero{flex-direction:column}}
