:root{color:#0f172a;--bg:#f6f7fb;--surface:#fff;--border:#e3e6ee;--text:#0f172a;--muted:#637085;--accent:#2754ff;--accent-soft:#e9eeff;--success:#1f9d55;--warning:#f4b740;--danger:#e25555;--shadow:0 14px 32px #0f172a14;--radius:18px;--radius-sm:12px;background:#f6f7fb;font-family:Manrope,Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:var(--bg);margin:0}a{color:inherit;text-decoration:none}h1,h2,h3{letter-spacing:-.02em;margin:0 0 8px;font-weight:700}h4{letter-spacing:-.01em;margin:0;font-weight:700}p{margin:0}.app-shell{background:var(--bg);min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:240px;height:100vh;padding:28px 20px;display:flex;position:sticky;top:0}.sidebar-brand{letter-spacing:.6px;cursor:pointer;margin-bottom:28px;font-size:20px;font-weight:800}.sidebar-nav{flex-direction:column;gap:8px;display:flex}.sidebar-link{color:var(--muted);border-radius:12px;padding:10px 14px;font-weight:600;display:block}.sidebar-link:hover{color:var(--text);background:#f3f5fb}.sidebar-link.active{background:var(--accent-soft);color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:20px}.main-area{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 36px;display:flex}.topbar-title{color:var(--muted);font-weight:600}.content{width:100%;max-width:1120px;margin:0 auto;padding:36px 36px 84px}.page-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-title{font-size:32px}.page-subtitle{color:var(--muted);font-size:15px}.hub-header-meta{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.hub-actions{align-items:flex-start;gap:16px;display:grid}.hub-action-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);gap:10px;padding:14px 16px;display:grid}.hub-action-group .row{flex-wrap:wrap}.hub-action-group .muted{text-transform:uppercase;letter-spacing:.08em;font-size:12px}.card-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;display:grid}.compact-grid{gap:14px}.dashboard-hero{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.stat-grid.compact .stat{padding:14px}.card-grid>.surface{cursor:default}.surface{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px;transition:box-shadow .12s,transform .12s}.surface:hover{transform:translateY(-1px);box-shadow:0 18px 40px #0f172a1f}.section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px}.button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:12px 18px;font-weight:600;transition:transform 80ms,box-shadow 80ms}.button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #2b5cff33}.button.secondary{background:var(--accent-soft);color:var(--accent)}.button.ghost{color:#2a2f3a;background:0 0;border:1px solid #d7d9e2}.button.danger{color:#b71c1c;background:#ffe9ea;border:1px solid #f3c5c8}.input,.textarea,select.input{border-radius:var(--radius-sm);background:#fbfcff;border:1px solid #d8dbe6;width:100%;padding:12px 14px;font-size:14px}.input:focus,.textarea:focus,select.input:focus{border-color:#b8c6ff;outline:none;box-shadow:0 0 0 3px #2754ff1f}.textarea{resize:vertical;min-height:80px}.row{align-items:center;gap:12px;display:flex}.row.wrap{flex-wrap:wrap}.muted{color:var(--muted);font-size:14px}.set-card{flex-direction:column;gap:12px;display:flex}.set-card-info{gap:12px;display:grid}.set-card-meta{color:var(--muted);gap:12px;font-size:13px;display:flex}.set-card-actions{flex-wrap:nowrap;gap:8px;margin-top:4px}.set-card-actions .button{white-space:nowrap;flex:1 1 0;justify-content:center;padding:6px 10px;font-size:13px}.set-card-actions .button.ghost{padding:6px 10px}.set-create-header{justify-content:space-between;margin-bottom:16px;display:flex}.set-form{border-radius:var(--radius-sm);background:#fbfcff;border:1px solid #e2e6f2;padding:18px}.set-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.set-form-actions{justify-content:flex-end;margin-top:12px;display:flex}.tabs{background:var(--surface);border:1px solid var(--border);border-radius:999px;flex-wrap:wrap;gap:10px;padding:8px;display:flex}.tab-button{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:8px 16px;font-weight:600}.tab-button.active{background:var(--accent-soft);color:var(--accent)}.hub-meta{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:24px;display:grid}.hub-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}.hub-mode-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-top:16px;display:grid}.hub-mode-card{border-radius:var(--radius);background:#fbfcff;border:1px solid #e2e6f2;flex-direction:column;gap:10px;padding:18px;display:flex}.hub-mode-card .button{align-self:flex-start}.hub-preview-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.hub-preview-card{background:#fbfcff}.hub-preview-text{color:var(--text);font-weight:600}.jp-helper{border-radius:var(--radius-sm);background:#fbfcff;border:1px dashed #d9dde8;gap:10px;margin-bottom:12px;padding:14px;display:grid}.jp-helper.compact{gap:8px;padding:12px}.jp-helper-notes{flex-wrap:wrap;gap:12px;display:flex}.jp-warning{color:#b45309;font-size:13px}.jp-helper-hint{font-size:12px}.jp-guide{border-radius:var(--radius-sm);background:#fbfcff;border:1px solid #e2e6f2;margin-bottom:12px;padding:10px 12px}.jp-guide.compact{padding:8px 10px}.jp-guide summary{cursor:pointer;color:var(--text);font-weight:600}.jp-guide-body{gap:12px;margin-top:10px;display:grid}.jp-guide-block h4{margin-bottom:6px}.jp-guide-examples{gap:6px;font-size:12px;display:grid}.jp-guide-examples code{background:#f1f5ff;border:1px solid #dde6ff;border-radius:8px;padding:6px 8px;font-family:JetBrains Mono,Consolas,monospace}.jp-guide-button{align-self:flex-start;padding:6px 12px;font-size:12px}.compact-card{padding:16px}.insight-list{color:var(--muted);gap:8px;margin:12px 0 0;padding:0;font-size:14px;list-style:none;display:grid}.insight-list strong{color:var(--text);font-weight:600}.quiz-shell{justify-content:center;display:flex}.quiz-card{gap:16px;width:min(760px,100%);display:grid}.quiz-front{font-size:26px;font-weight:700}.quiz-answer{gap:12px;display:grid}.quiz-reveal{gap:8px;display:grid}.quiz-text{font-weight:600}.quiz-actions{gap:12px;margin-top:12px;display:flex}.mc-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.option-button{color:var(--text);border-radius:var(--radius-sm);text-align:left;cursor:pointer;background:#fff;border:1px solid #d7d9e2;width:100%;padding:14px 16px;font-weight:600;transition:transform 80ms,box-shadow 80ms}.option-button:hover:enabled{transform:translateY(-1px);box-shadow:0 6px 16px #0f172a14}.option-button.correct{color:#1f7a45;background:#e9f7ef;border-color:#cde8d8}.option-button.incorrect{color:#b71c1c;background:#ffe9ea;border-color:#f3c5c8}.mc-feedback{gap:6px;margin-top:16px;display:grid}.feedback-pill{border-radius:999px;align-items:center;width:fit-content;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.feedback-pill.correct{color:#1f7a45;background:#e9f7ef}.feedback-pill.incorrect{color:#b71c1c;background:#ffe9ea}.explanation-text{color:var(--muted);font-size:13px;line-height:1.4}.answer-feedback{gap:6px;width:min(760px,100%);display:grid}.ordering-shell{gap:12px;width:min(760px,100%);display:grid}.ordering-chosen,.ordering-available{flex-wrap:wrap;gap:8px;display:flex}.ordering-chip{cursor:pointer}.ordering-chip.selected{background:var(--accent-soft);color:var(--accent);border-color:#ccd8ff}.particle-options{flex-wrap:wrap;gap:8px;display:flex}.particle-option.selected{color:#1f7a45;background:#e9f7ef;border-color:#cde8d8}.conjugation-clue{text-align:left;gap:10px;width:100%;font-size:18px;display:grid}.conjugation-row{justify-content:space-between;gap:12px;display:flex}.conjugation-value{color:var(--text);font-weight:600}ruby{ruby-position:over}rt{color:var(--muted);font-size:.55em}.mc-note{margin-top:6px;font-size:12px}.chip{background:#f3f5fb;border:1px solid #e5e8f0;border-radius:999px;align-items:center;gap:8px;padding:6px 12px;font-size:13px;display:inline-flex}.dictation-prompt{gap:12px;width:100%;display:grid}.dictation-audio{justify-content:center;display:flex}.dictation-toggle{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.dictation-toggle .chip.active{color:#1f7a45;background:#e9f7ef;border-color:#cde8d8}.dictation-text{font-size:28px;font-weight:600}.chip-delete{color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:12px}.mode-toggle{background:#eef2ff;border:1px solid #dfe5ff;border-radius:999px;gap:4px;padding:4px;display:inline-flex}.mode-button{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:999px;padding:8px 14px;font-weight:600}.mode-button.active{color:var(--text);background:#fff;box-shadow:0 4px 10px #0f172a14}.study-shell{justify-items:center;gap:24px;display:grid}.study-card{text-align:center;justify-content:center;align-items:center;width:min(760px,100%);min-height:360px;padding:32px;font-size:28px;font-weight:600;display:flex}.study-card.revealed{background:#f4f7ff;border-color:#d9e3ff}.rating-buttons{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;width:min(760px,100%);display:grid}.rating-buttons .button{border-radius:var(--radius-sm);padding:12px 16px}.rating-buttons .again{color:#b71c1c;background:#ffe9ea}.rating-buttons .hard{color:#8a5a10;background:#fff6df}.rating-buttons .good{color:#1f7a45;background:#e9f7ef}.rating-buttons .easy{color:#1f4aff;background:#e8f0ff}.learn-buttons{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;width:min(760px,100%);display:grid}.learn-buttons .button{border-radius:var(--radius-sm);padding:14px 18px;font-size:16px}.learn-incorrect{color:#b71c1c;background:#ffe9ea}.learn-correct{color:#1f7a45;background:#e9f7ef}.answer-area{gap:12px;width:min(760px,100%);display:grid}.answer-input{height:56px;font-size:16px}.answer-compare{border-radius:var(--radius-sm);background:#f8f9ff;border:1px solid #e2e5ff;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;width:min(760px,100%);padding:16px;display:grid}.answer-text{color:var(--text);word-break:break-word;margin-top:6px;font-weight:600}.audio-button{color:var(--text);cursor:pointer;background:#fff;border:1px solid #d7d9e2;border-radius:999px;padding:8px 14px;font-weight:600}.audio-controls{gap:10px;display:grid}.audio-controls.compact{gap:6px}.audio-buttons{flex-wrap:wrap;gap:8px;display:flex}.audio-button.active{color:#1f4aff;background:#eef2ff;border-color:#cdd8ff}.audio-toggle{color:var(--muted);align-items:center;gap:8px;font-size:13px;display:inline-flex}.audio-toggle input{accent-color:var(--accent)}.audio-error{color:var(--muted);font-size:13px}.audio-status{color:var(--muted);font-size:12px}.audio-status.on{color:#1f7a45}.audio-status.off{color:var(--muted)}.audio-button:hover{box-shadow:0 6px 16px #0f172a14}.assignment-card{background:#f7f9ff;border:1px solid #dbe4ff;gap:8px;display:grid}.assignment-card.completed{opacity:.7;background:#fbfcff}.assignment-card:hover{box-shadow:0 18px 40px #0f172a1f}.assignment-card .chip{margin-right:6px}.assignment-card .row{margin-top:4px}.status-chip.completed{color:#1f7a45;background:#e9f7ef;border-color:#cde8d8}.status-chip.in_progress{color:#8a5a10;background:#fff6df;border-color:#f1e1b6}.status-chip.not_started{color:var(--muted);background:#f3f5fb}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;display:grid}.stat{border-radius:var(--radius-sm);background:#f7f8ff;border:1px solid #e2e5ff;padding:18px}.dashboard-page .page-title{font-size:18px}.dashboard-page .page-subtitle{font-size:11px}.dashboard-page .section{padding:10px}.dashboard-page .stat{padding:8px;font-size:11px}.dashboard-page .stat div:last-child{font-size:13px;font-weight:700}.dashboard-page .surface{padding:10px}.dashboard-page .button{padding:5px 8px;font-size:11px}.dashboard-page .chip{padding:3px 7px;font-size:10px}.dashboard-page .row{gap:6px}.dashboard-page .card-grid{gap:10px}.dashboard-page .assignment-card{gap:6px}.dashboard-page .assignment-card .button{align-self:flex-start;width:auto}.table{border-collapse:collapse;width:100%}.table th,.table td{text-align:left;border-bottom:1px solid #eceff6;padding:10px;font-size:14px}.card-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.card-row td{vertical-align:middle}.card-row-actions{text-align:right;width:120px}.card-row-actions .button{padding:8px 12px}.row-helper{justify-items:end;gap:6px;display:grid}.row-helper .input{min-width:140px}.row-helper .muted{font-size:11px}.row-helper.compact{gap:4px}.row-helper-text{text-align:right;max-width:180px}.row-warning{color:#b45309;font-size:11px}.row-choice{justify-items:end;gap:6px;display:grid}.row-choice-chips{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.row-choice .chip{padding:4px 8px;font-size:11px}.textarea{font-family:inherit}.empty{text-align:center;border-radius:var(--radius);color:var(--muted);background:#fbfcff;border:1px dashed #d9dde8;padding:48px}.empty-compact{padding:28px}.assignment-groups{gap:20px;display:grid}.assignment-group{gap:12px;display:grid}.assignment-group-header{justify-content:space-between;align-items:center;display:flex}.assignment-create-header{justify-content:space-between;margin-bottom:16px;display:flex}.assignment-form{border-radius:var(--radius-sm);background:#fbfcff;border:1px solid #e2e6f2;padding:18px}.assignment-form-grid{grid-template-columns:minmax(220px,1.2fr) minmax(220px,1fr);gap:14px;display:grid}.field{gap:6px;display:grid}.assignment-create-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:14px;display:flex}.field span,.field label{text-transform:uppercase;letter-spacing:.08em;font-size:12px}.field.span-2{grid-column:span 2}.continue-grid{gap:20px;display:grid}.continue-section{gap:12px;display:grid}.entry-shell{justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:40px 20px;display:flex}.entry-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:520px;box-shadow:var(--shadow);text-align:center;padding:36px}.entry-brand{margin-bottom:16px;font-size:22px;font-weight:800}.entry-subtitle{color:var(--muted);margin-bottom:24px;font-size:15px}.entry-actions{gap:12px;margin-bottom:16px;display:grid}.entry-footnote{font-size:13px}.hamburger{cursor:pointer;background:0 0;border:none;border-radius:8px;margin-right:8px;padding:8px;font-size:22px;line-height:1;display:none}.hamburger:hover{background:#0000000d}.sidebar-backdrop{z-index:99;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;display:none;position:fixed;inset:0}.sidebar-backdrop.open{display:block}@media (width<=900px){.hamburger{justify-content:center;align-items:center;display:inline-flex}.sidebar{z-index:100;width:280px;height:100vh;transition:transform .25s ease-out;position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:4px 0 24px #00000026}.sidebar.open{transform:translate(0)}.topbar{padding:12px 16px}.topbar-title{font-size:14px}.content{padding:16px}.card-grid{grid-template-columns:1fr!important}}@media (width<=480px){.topbar>div:last-child{gap:4px!important}.topbar .button{padding:6px 10px!important;font-size:12px!important}.page-title{font-size:22px!important}.page-subtitle{font-size:13px!important}.stat-grid{grid-template-columns:repeat(2,1fr)!important}.section,.card{padding:14px!important}table{font-size:12px!important}}@media (width<=700px){.content{padding:16px}.topbar{padding:12px 16px}.page-header{flex-direction:column;align-items:flex-start}.hub-actions{width:100%}.assignment-form-grid,.set-form-grid{grid-template-columns:1fr}.assignment-create-actions{flex-direction:column;align-items:flex-start}.field.span-2{grid-column:span 1}}.auth-page{justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:32px;display:flex}.auth-card{border:1px solid var(--border);width:100%;max-width:480px;box-shadow:var(--shadow);background:#fff;border-radius:20px;padding:28px}.auth-header h1{margin:0 0 6px}.auth-tabs{grid-template-columns:1fr 1fr;gap:8px;margin:18px 0;display:grid}.tab-button{border:1px solid var(--border);cursor:pointer;background:#f6f7fb;border-radius:999px;padding:8px 12px;font-size:.9rem}.tab-button.active{color:#1d4ed8;background:#eef2ff;border-color:#c7d2fe}.auth-form{gap:12px;display:grid}.field{gap:6px;font-size:.9rem;display:grid}.error-text{color:#dc2626;font-size:.85rem}.auth-demo{gap:8px;margin-top:20px;display:grid}.auth-signed-in{border:1px solid var(--border);background:#f9fafc;border-radius:14px;margin-bottom:16px;padding:16px}.auth-user{font-weight:600}.class-card{justify-content:space-between;align-items:center;gap:16px;display:flex}.class-card-actions{flex-direction:column;align-items:flex-end;gap:10px;display:flex}.class-progress-list{flex-direction:column;gap:16px;display:flex}.class-progress-table{gap:8px;margin-top:12px;display:grid}.class-progress-row{background:#f8fafce6;border:1px solid #0f172a14;border-radius:12px;grid-template-columns:2fr 1fr 1fr;gap:12px;padding:10px 12px;font-size:.92rem;display:grid}.class-progress-row.class-progress-head{color:#475569;background:0 0;border:none;padding:0 4px;font-weight:600}.class-progress-toggle{text-align:left;cursor:pointer;background:0 0;border:0;justify-content:space-between;align-items:center;gap:16px;width:100%;padding:0;display:flex}.class-progress-summary{flex-direction:column;align-items:flex-end;gap:6px;font-size:.9rem;display:flex}.chip.subtle{color:#475569;background:#e2e8f0b3}.roster-table{gap:10px;padding:16px;display:grid}.roster-row{background:#f8fafce6;border:1px solid #0f172a14;border-radius:12px;grid-template-columns:2fr 1fr;gap:12px;padding:10px 12px;font-size:.92rem;display:grid}.roster-row.roster-head{color:#475569;background:0 0;border:none;padding:0 4px;font-weight:600}.class-code{border:1px dashed var(--border);background:#f6f7fb;border-radius:999px;padding:6px 12px;font-size:.9rem}.xp-bar-container{align-items:center;gap:8px;padding:4px 12px;font-size:13px;display:flex}.xp-level-badge{background:var(--accent);color:#fff;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.xp-bar-track{background:var(--border);border-radius:999px;flex:1;min-width:80px;height:8px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg,var(--accent),#6c63ff);border-radius:999px;height:100%;transition:width .5s}.xp-bar-text{color:var(--muted);white-space:nowrap;font-weight:600}.xp-streak{font-weight:600}.xp-toast{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.xp-toast-item{background:var(--accent);color:#fff;border-radius:var(--radius);padding:12px 20px;font-size:16px;font-weight:700;animation:.3s xp-slide-in;box-shadow:0 8px 24px #00000026}.xp-toast-item.level-up{background:linear-gradient(135deg,#f59e0b,#ef4444);padding:16px 24px;font-size:20px}.xp-toast-item.achievement{background:#6c63ff}@keyframes xp-slide-in{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.notif-bell{cursor:pointer;padding:4px;font-size:20px;position:relative}.notif-badge{background:var(--danger);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:18px;height:18px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-6px}.notif-dropdown{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);z-index:100;width:320px;max-height:400px;position:absolute;top:100%;right:0;overflow-y:auto;box-shadow:0 8px 24px #0000001f}.notif-item{border-bottom:1px solid var(--border);padding:10px 14px}.notif-item.unread{background:var(--accent-soft)}.tab-bar{border-bottom:2px solid var(--border);gap:0;margin-bottom:20px;display:flex}.tab-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:14px;font-weight:600}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.join-code{letter-spacing:12px;text-align:center;color:var(--accent);padding:24px 0;font-family:monospace;font-size:4rem;font-weight:800}.live-question{text-align:center;padding:32px 16px;font-size:1.6rem;font-weight:700}.live-answer-grid{grid-template-columns:1fr 1fr;gap:12px;max-width:600px;margin:0 auto;padding:16px;display:grid}.live-answer-btn{border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:center;padding:20px;font-size:1.1rem;font-weight:600}.live-answer-btn:hover{border-color:var(--accent)}.live-answer-btn.correct{border-color:var(--success);background:#dcfce7}.live-answer-btn.wrong{border-color:var(--danger);background:#fee2e2}.live-waiting{text-align:center;color:var(--muted);padding:48px;font-size:1.2rem}.live-score{text-align:center;padding:16px;font-size:2rem;font-weight:800}.live-participants{flex-wrap:wrap;gap:8px;padding:16px;display:flex}.live-participant-chip{background:var(--accent-soft);color:var(--accent);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600}.achievement-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.achievement-card{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);padding:16px}.achievement-card.earned{border-color:var(--success);background:#f0fdf4}.achievement-card.unearned{opacity:.6}.ach-progress{background:var(--border);border-radius:999px;height:6px;margin-top:8px;overflow:hidden}.ach-progress-fill{background:var(--accent);border-radius:999px;height:100%}.skill-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.skill-node{border-radius:var(--radius-sm);border:2px solid var(--border);text-align:center;padding:16px}.skill-node.locked{opacity:.4;background:#f1f5f9}.skill-node.available{border-color:var(--accent);background:var(--accent-soft)}.skill-node.completed{border-color:var(--success);background:#f0fdf4}.skill-node.mastered{background:#fffbeb;border-color:#f59e0b}.lb-table{border-collapse:collapse;width:100%}.lb-table th{text-align:left;border-bottom:2px solid var(--border);color:var(--muted);padding:10px 14px;font-size:13px}.lb-table td{border-bottom:1px solid var(--border);padding:10px 14px}.admin-form{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:16px;display:flex}.admin-list-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.colour-dot{border-radius:999px;width:16px;height:16px;margin-right:8px;display:inline-block}.phase-indicator{text-align:center;color:var(--accent);text-transform:uppercase;letter-spacing:1px;padding:8px;font-size:14px;font-weight:700}.activity-progress{background:var(--border);border-radius:999px;height:6px;margin-bottom:16px;overflow:hidden}.activity-progress-fill{background:var(--accent);border-radius:999px;height:100%;transition:width .3s}.mc-options{grid-template-columns:1fr 1fr;gap:10px;margin:16px 0;display:grid}.mc-option{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;text-align:center;padding:14px;font-size:15px;font-weight:600}.mc-option:hover{border-color:var(--accent)}.mc-option.correct{border-color:var(--success);background:#dcfce7}.mc-option.wrong{border-color:var(--danger);background:#fee2e2}.daily-challenge{border-radius:var(--radius-sm);border:2px solid var(--warning);background:#fffbeb;padding:16px}.parent-view{max-width:800px;margin:40px auto;padding:0 20px}.parent-stat{text-align:center;color:var(--accent);font-size:2rem;font-weight:800}.parent-label{text-align:center;color:var(--muted);font-size:13px}.chunk-table{border-collapse:collapse;width:100%;margin:12px 0}.chunk-table th,.chunk-table td{border-bottom:1px solid var(--border);text-align:left;padding:8px 12px;font-size:14px}.chunk-table th{color:var(--muted);font-weight:600}.lesson-stage{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;padding:14px}.frame-item{background:var(--bg);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;margin-bottom:6px;padding:8px 12px;display:flex}@media (width<=640px){.live-answer-grid,.mc-options{grid-template-columns:1fr}.join-code{letter-spacing:6px;font-size:2.5rem}.achievement-grid{grid-template-columns:1fr}}.mentor-messages{flex-direction:column;gap:12px;padding:8px 0;display:flex}.mentor-bubble{border-radius:var(--radius-sm);max-width:80%;padding:12px 16px;font-size:14px;line-height:1.5}.mentor-bubble.student{background:var(--accent);color:#fff;border-bottom-right-radius:4px;align-self:flex-end}.mentor-bubble.mentor{background:var(--surface);border:1px solid var(--border);border-bottom-left-radius:4px;align-self:flex-start}.bubble-role{opacity:.7;margin-bottom:4px;font-size:11px;font-weight:700}.bubble-thinking{background:var(--accent-soft);border-radius:var(--radius-sm);color:var(--accent);margin-top:8px;padding:8px 12px;font-size:13px;font-style:italic}.high-contrast{--bg:#000;--surface:#111;--text:#fff;--muted:#ff0;--accent:#0ff;--accent-soft:#033;--border:#fff;--success:#0f0;--danger:red;--warning:#ff0}.high-contrast .sidebar{background:#111;border-color:#fff}.high-contrast .topbar{background:#000;border-color:#fff}.high-contrast .surface{background:#111;border-color:#555}.high-contrast .button{border-color:#fff}.high-contrast input,.high-contrast textarea,.high-contrast select{color:#fff;background:#222;border-color:#555}
