:root{--bg-0: #050709;--bg-1: #0a0e16;--bg-2: #0f1421;--bg-3: #161c2b;--bg-4: #1d2538;--border: #1f2738;--border-strong: #2d3650;--fg: #e9edf6;--fg-dim: #a5adc1;--muted: #6c7588;--muted-2: #4d556a;--cyan: #5eead4;--cyan-2: #22d3ee;--cyan-soft: rgba(94, 234, 212, .1);--cyan-glow: rgba(94, 234, 212, .35);--green: #4ade80;--pink: #fb7185;--pink-soft: rgba(251, 113, 133, .12);--gold: #fbbf24;--silver: #cbd5e1;--bronze: #d97706;--content-max: 720px;--content-pad: 1.25rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--font-mono: ui-monospace, "JetBrains Mono", "Fira Code", SFMono-Regular, Menlo, monospace;font-family:var(--font-sans);font-size:16px;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(900px 500px at 10% -10%,rgba(34,211,238,.06) 0%,transparent 60%),radial-gradient(900px 500px at 100% 110%,rgba(167,139,250,.06) 0%,transparent 60%),var(--bg-0);background-attachment:fixed;color:var(--fg);-webkit-tap-highlight-color:transparent;min-height:100%}::selection{background:var(--cyan-soft);color:var(--cyan)}.app{min-height:100vh;min-height:100svh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:20;background:#050709b8;backdrop-filter:blur(12px) saturate(160%);-webkit-backdrop-filter:blur(12px) saturate(160%);border-bottom:1px solid var(--border);padding-top:env(safe-area-inset-top)}.app-header-inner{max-width:var(--content-max);margin:0 auto;padding-inline:max(env(safe-area-inset-left),var(--content-pad)) max(env(safe-area-inset-right),var(--content-pad));height:60px;display:flex;align-items:center;justify-content:space-between;gap:1rem}.app-header-inner.wide{max-width:1080px}.app-header-right{display:flex;align-items:center;gap:.75rem;min-width:0}.app-main{max-width:var(--content-max);margin:0 auto;padding:2rem max(env(safe-area-inset-right),var(--content-pad)) calc(4rem + env(safe-area-inset-bottom)) max(env(safe-area-inset-left),var(--content-pad));width:100%;flex:1}.app-main.wide{max-width:1080px}.brand{font-family:var(--font-mono);font-size:1.05rem;font-weight:600;letter-spacing:-.01em;color:var(--fg);text-decoration:none;display:inline-flex;align-items:baseline;gap:0}.brand:hover{text-decoration:none}.brand-text{color:var(--fg)}.brand-dot{color:var(--cyan);text-shadow:0 0 12px var(--cyan-glow);margin-left:1px}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-family:var(--font-mono);font-weight:700;flex-shrink:0}.student-chip-group{display:inline-flex;align-items:center;gap:.75rem}.student-chip{display:inline-flex;align-items:center;gap:.55rem;padding:.3rem .7rem .3rem .3rem;background:var(--bg-2);border:1px solid var(--border);border-radius:999px;color:var(--fg);font-size:.9rem;font-weight:500}.student-chip-name{font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:14ch}.parent-chip{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);background:var(--cyan-soft);border:1px solid rgba(94,234,212,.3);padding:.3rem .65rem;border-radius:999px}.parent-chip-group{display:inline-flex;align-items:center;gap:.75rem}.header-link{font-family:var(--font-mono);font-size:.85rem;color:var(--muted);padding:.4rem .6rem;border-radius:8px;transition:color .12s ease,background .12s ease}.header-link:hover{color:var(--fg);background:var(--bg-2);text-decoration:none}.eyebrow{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin:0 0 .5rem}.hero-title,.page-title{font-family:var(--font-mono);font-weight:600;letter-spacing:-.025em;line-height:1.05;margin:0}.hero-title{font-size:clamp(2.25rem,6.5vw,3.25rem)}.page-title{font-size:1.75rem}.hero{margin-bottom:2rem}.page-head{margin-bottom:1.5rem}.page-head-row{display:flex;align-items:center;gap:.85rem;margin-top:.5rem}.section-title{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:0 0 .85rem}.back-link{font-family:var(--font-mono);font-size:.85rem;color:var(--muted);display:inline-block}.back-link:hover{color:var(--fg);text-decoration:none}.muted{color:var(--muted)}.small{font-size:.875rem}.center{text-align:center}.error{color:var(--pink)}.ok{color:var(--green)}.cta-link{color:var(--cyan);font-family:var(--font-mono)}a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}.card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1rem}.empty-state{padding:3rem 1rem;text-align:center;background:var(--bg-1);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);color:var(--muted)}.empty-state p{margin:0 0 .75rem}.student-grid{list-style:none;padding:0;margin:0;display:grid;gap:.75rem}@media(min-width:540px){.student-grid{grid-template-columns:repeat(2,1fr)}}.student-card{width:100%;display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--fg);cursor:pointer;text-align:left;transition:border-color .12s ease,transform .12s ease,background .12s ease}.student-card:hover{border-color:var(--border-strong);background:var(--bg-2);transform:translateY(-1px)}.student-card:active{transform:translateY(0)}.student-card-name{flex:1;font-family:var(--font-mono);font-size:1.35rem;font-weight:500;letter-spacing:-.01em}.student-card-arrow{color:var(--muted);font-size:1.2rem}.buckets{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:.75rem}.bucket{padding:1rem .5rem;border-radius:var(--radius-md);text-align:center;border:1px solid var(--border);background:var(--bg-2)}.bucket-count{font-family:var(--font-mono);font-size:2.5rem;font-weight:600;line-height:1;letter-spacing:-.03em}.bucket-label{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.45rem}.bucket-mastered{color:var(--cyan);border-color:#5eead44d;background:var(--cyan-soft)}.bucket-learning{color:var(--gold);border-color:#fbbf244d;background:#fbbf240f}.bucket-unknown{color:var(--fg-dim)}.start-quiz{width:100%;display:inline-flex;align-items:center;justify-content:center;gap:.85rem;font-family:var(--font-mono);font-size:1.25rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:1.15rem 1rem;background:var(--cyan);color:#03110d;border:none;border-radius:var(--radius-md);cursor:pointer;box-shadow:0 0 0 1px #ffffff0f inset,0 8px 30px -8px var(--cyan-glow);transition:transform 80ms ease,box-shadow .12s ease}.start-quiz:hover{transform:translateY(-1px);box-shadow:0 0 0 1px #ffffff14 inset,0 12px 40px -8px var(--cyan-glow)}.start-quiz:active{transform:translateY(0)}.start-quiz:disabled{background:var(--bg-3);color:var(--muted);box-shadow:none;cursor:not-allowed}.kbd-hint{font-size:.7rem;font-weight:500;letter-spacing:.15em;padding:.15rem .5rem;background:#03110d2e;border-radius:999px}.quiz-progressbar{height:3px;background:var(--bg-2);border-radius:999px;overflow:hidden;margin-bottom:1.25rem}.quiz-progressbar-fill{height:100%;background:var(--cyan);box-shadow:0 0 12px var(--cyan-glow);transition:width .22s ease}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.quiz-progress{font-family:var(--font-mono);font-size:.95rem;color:var(--fg-dim)}.quiz-progress-num{color:var(--cyan);font-weight:600}.quiz-progress-sep{color:var(--muted);margin:0 .25rem}.dev-toggle{font-size:.75rem;color:var(--muted);display:flex;align-items:center;gap:.35rem}.dev-hint{color:var(--muted);font-size:.85rem;margin:.25rem 0}.dev-hint code{font-family:var(--font-mono);background:var(--bg-2);padding:.05rem .4rem;border-radius:4px}.audio-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1.25rem}.audio-button{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-sans);font-size:.92rem;font-weight:500;padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-1);color:var(--fg);cursor:pointer;text-align:left;transition:border-color .12s ease,background .12s ease}.audio-button:hover:not(:disabled){border-color:var(--border-strong);background:var(--bg-2)}.audio-button.primary{grid-column:1 / -1;font-size:1.05rem;padding:1.1rem 1.25rem;border-color:#5eead440;background:linear-gradient(180deg,rgba(94,234,212,.05),var(--bg-1))}.audio-button.primary:hover:not(:disabled){border-color:var(--cyan);box-shadow:0 0 0 1px var(--cyan-soft)}.audio-button.playing{border-color:var(--cyan);color:var(--cyan);box-shadow:0 0 16px -4px var(--cyan-glow)}.audio-button:disabled{color:var(--muted);cursor:not-allowed;opacity:.55}.audio-icon{color:var(--cyan)}.audio-button:disabled .audio-icon{color:var(--muted-2)}.audio-tap-prompt{display:flex;align-items:center;justify-content:center;gap:.6rem;width:100%;font-family:var(--font-mono);font-size:1rem;font-weight:600;letter-spacing:.04em;padding:.9rem 1rem;margin-bottom:1rem;background:var(--cyan);color:#03110d;border:none;border-radius:var(--radius-md);cursor:pointer;box-shadow:0 0 24px -8px var(--cyan-glow)}.audio-tap-prompt:hover{filter:brightness(1.05)}.hint-slot{min-height:3.5rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.hint-letters{display:inline-flex;align-items:center;gap:.4em;font-family:var(--font-mono);font-size:1.9rem;font-weight:500;color:var(--cyan)}.hint-revealed{letter-spacing:.15em}.hint-line{display:inline-block;width:2.5em;height:4px;background:currentColor;border-radius:2px}.hint-full{display:flex;flex-direction:column;align-items:center;gap:.4rem}.hint-full-note{font-size:.9rem;font-family:var(--font-sans);margin:0}.hint-full-note strong{font-family:var(--font-mono);color:var(--cyan);font-weight:600}.quiz-form{display:flex;gap:.5rem;margin-bottom:.75rem}.quiz-form input{flex:1;font-family:var(--font-mono);font-size:1.7rem;font-weight:500;padding:1rem 1.25rem;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg);text-transform:lowercase;transition:border-color .12s ease,box-shadow .12s ease}.quiz-form input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-soft),0 0 24px -8px var(--cyan-glow)}.quiz-form button{font-family:var(--font-mono);font-size:1.5rem;padding:0 1.5rem;background:var(--cyan);color:#03110d;border:none;border-radius:var(--radius-md);cursor:pointer;min-width:4rem;box-shadow:0 0 24px -8px var(--cyan-glow)}.quiz-form button:disabled{background:var(--bg-3);color:var(--muted);box-shadow:none;cursor:not-allowed}.feedback-slot{min-height:2rem}.feedback{font-family:var(--font-mono);font-size:1rem;margin:0}.feedback.right{color:var(--green)}.feedback.wrong{color:var(--pink)}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-5px)}40%,80%{transform:translate(5px)}}.shake{animation:shake .32s ease-in-out;border-color:var(--pink)!important;box-shadow:0 0 0 3px var(--pink-soft)!important}.result-score-block{text-align:center;margin-bottom:2.5rem;padding:1.5rem 1rem}.result-score{font-family:var(--font-mono);font-size:clamp(4.5rem,16vw,7rem);font-weight:700;line-height:1;letter-spacing:-.04em;color:var(--cyan);text-shadow:0 0 40px var(--cyan-glow)}.result-score .muted{font-weight:400;font-size:.45em;margin-left:.25em;text-shadow:none}.star-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.85rem;letter-spacing:.18em;padding:.55rem 1.1rem;border-radius:999px;border:1px solid;margin-top:1rem}.star-emoji{font-size:1.1rem;line-height:1}.star-badge.tier-gold{color:var(--gold);border-color:#fbbf2480;background:#fbbf2414}.star-badge.tier-silver{color:var(--silver);border-color:#cbd5e166;background:#cbd5e10d}.star-badge.tier-bronze{color:var(--bronze);border-color:#d9770680;background:#d9770614}.result-list{list-style:none;padding:0;margin:0 0 1.5rem;display:grid;gap:.35rem}.result-list li{display:flex;justify-content:space-between;align-items:center;padding:.7rem .95rem;border-radius:var(--radius-sm);background:var(--bg-1);border:1px solid var(--border);border-left-width:3px}.result-list li.right{border-left-color:var(--green)}.result-list li.wrong{border-left-color:var(--pink)}.result-word{font-family:var(--font-mono);font-size:1rem;font-weight:500}.result-mark{font-size:.85rem;color:var(--muted)}.word-detail-list{list-style:none;padding:0;margin:0 0 1rem;display:grid;gap:.4rem}.word-detail-list li{padding:.7rem .95rem;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius-sm);border-left-width:3px}.word-detail-list li.right{border-left-color:var(--green)}.word-detail-list li.wrong{border-left-color:var(--pink)}.word-detail-head{display:flex;justify-content:space-between;align-items:baseline}.word-tries{margin:.6rem 0 0 1.2rem;padding:0;font-size:.9rem;color:var(--fg-dim)}.word-tries code{font-family:var(--font-mono);background:var(--bg-2);padding:.05rem .4rem;border-radius:4px;color:var(--fg)}.student-admin-list{list-style:none;padding:0;margin:0 0 1rem;display:grid;gap:.4rem}.student-admin-list li{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.student-row{flex:1;display:flex;align-items:center;gap:.7rem;color:var(--fg);padding:.3rem 0}.student-row:hover{color:var(--cyan);text-decoration:none}.student-row-name{font-family:var(--font-mono);font-size:1rem;flex:1}.student-row-arrow{color:var(--muted)}.passcode-form{display:grid;gap:.75rem;max-width:360px}.passcode-form input{width:100%;font-family:var(--font-mono);font-size:1.75rem;letter-spacing:.4em;text-align:center;padding:.95rem 1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg)}.passcode-form input::placeholder{letter-spacing:.4em;color:var(--muted-2)}.passcode-form input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-soft)}.passcode-form button,.inline-form button{font-family:var(--font-mono);font-size:.85rem;letter-spacing:.1em;text-transform:uppercase;padding:.85rem 1rem;background:var(--cyan);color:#03110d;border:none;border-radius:var(--radius-md);cursor:pointer}.passcode-form button:disabled,.inline-form button:disabled{background:var(--bg-3);color:var(--muted);cursor:not-allowed}.inline-form{display:flex;gap:.5rem}.inline-form input{flex:1;font-size:.95rem;padding:.65rem .85rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg)}.inline-form input:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 2px var(--cyan-soft)}.link-button{background:none;border:none;color:var(--cyan);cursor:pointer;font:inherit;padding:0;font-size:.85rem}.link-button.danger{color:var(--pink)}.link-button:hover{text-decoration:underline}.plain-list{list-style:none;padding:0;margin:0}.plain-list li{padding:.3rem 0}.list-name{font-family:var(--font-mono)}.quiz-timeline{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}.quiz-timeline a{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg)}.quiz-timeline a:hover{border-color:var(--border-strong);text-decoration:none}.quiz-date{color:var(--muted);font-size:.9rem}.quiz-score{font-family:var(--font-mono);font-weight:600;color:var(--cyan)}.progress-card{margin-bottom:1.5rem}.progress-tree{display:flex;flex-direction:column;gap:.35rem}.pt-row{display:flex;flex-direction:column}.pt-header{display:flex;align-items:center;gap:.6rem;padding:.5rem .7rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--fg);font:inherit;text-align:left;cursor:pointer;width:100%}.pt-header:hover{background:var(--bg-3);border-color:var(--border-strong)}.pt-caret{display:inline-block;color:var(--muted);transition:transform .12s ease;width:.9rem}.pt-caret.open{transform:rotate(90deg)}.pt-name{font-family:var(--font-mono);font-size:.9rem;min-width:5.5rem}.pt-boxes{display:inline-flex;flex-wrap:wrap;gap:3px;flex:1}.pt-box{width:12px;height:12px;border-radius:3px;background:var(--bg-3)}.pt-box-mastered{background:var(--cyan);box-shadow:0 0 4px var(--cyan-glow)}.pt-box-learning{background:var(--gold)}.pt-box-unknown{background:var(--muted-2);opacity:.55}.pt-child{margin-left:1.5rem;margin-top:.3rem}.pt-words{list-style:none;padding:.5rem 0 0;margin:0 0 0 1.5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.3rem .6rem;font-family:var(--font-mono);font-size:.85rem}.pt-word{display:inline-flex;align-items:center;gap:.4rem;color:var(--fg-dim)}.pt-word.pt-word-mastered{color:var(--fg)}.pt-word.pt-word-unknown{color:var(--muted-2)}.pt-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pt-dot-mastered{background:var(--cyan)}.pt-dot-learning{background:var(--gold)}.pt-dot-unknown{background:var(--muted-2);opacity:.6}.nav-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg)}.nav-card:hover{border-color:var(--border-strong);background:var(--bg-3);text-decoration:none}.nav-card-title{font-family:var(--font-mono);font-size:1rem;font-weight:600;margin-bottom:.2rem}.nav-card-sub{color:var(--muted);font-size:.85rem}.nav-card-arrow{color:var(--muted);font-size:1.2rem}.drill-grid{list-style:none;padding:0;margin:1rem 0 0;display:grid;gap:.5rem}@media(min-width:540px){.drill-grid{grid-template-columns:repeat(2,1fr)}}.drill-card{display:block;padding:1rem 1.1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--fg)}.drill-card:hover{border-color:var(--border-strong);background:var(--bg-3);text-decoration:none}.drill-card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.6rem}.drill-card-name{font-family:var(--font-mono);font-size:1.1rem;font-weight:600;letter-spacing:-.01em}.drill-card-arrow{color:var(--muted)}.drill-card-meta{font-family:var(--font-mono);font-size:.8rem;color:var(--muted);margin-top:.5rem}.drill-progress{height:4px;background:var(--bg-3);border-radius:999px;overflow:hidden}.drill-progress-fill{display:block;height:100%;background:var(--gold);border-radius:999px;transition:width .22s ease}.drill-progress-fill.ready{background:var(--cyan);box-shadow:0 0 8px var(--cyan-glow)}.drill-progress-pro{position:absolute;inset-block:0;height:100%;background:#a78bfae6;border-radius:999px;box-shadow:0 0 8px #a78bfa80}.drill-progress-pro-hd{position:absolute;inset-block:0;height:100%;background:#f472b6e6;border-radius:999px;box-shadow:0 0 8px #f472b680}.drill-progress{position:relative}.meta-pro{color:#a78bfa}.meta-pro-hd{color:#f472b6}.badge-ready{color:var(--cyan);font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;font-size:.7rem}.badge-ready.big{font-size:.75rem;padding:.3rem .65rem;background:var(--cyan-soft);border:1px solid rgba(94,234,212,.4);border-radius:999px}.word-record-list{list-style:none;padding:0;margin:0;display:grid;gap:.4rem}.word-record-list li a{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);border-left-width:3px;color:var(--fg)}.word-record-list li a:hover{border-color:var(--border-strong);text-decoration:none}.word-record-list li.ready a{border-left-color:var(--cyan)}.word-record-list li.partial a{border-left-color:var(--gold)}.word-record-list li.empty a{border-left-color:var(--muted-2)}.word-record-text{font-family:var(--font-mono);font-size:1rem;font-weight:500}.word-record-meta{display:inline-flex;align-items:center;gap:.6rem}.word-record-marks{display:inline-flex;gap:.25rem}.source-tag{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;padding:.15rem .5rem;border-radius:999px;border:1px solid}.source-tag.source-openai-nova{color:#a78bfa;border-color:#a78bfa73;background:#a78bfa1a}.source-tag.source-openai-nova-hd{color:#f472b6;border-color:#f472b673;background:#f472b61a}.source-tag.source-samantha-local{color:var(--muted);border-color:var(--border)}.source-tag.source-manual{color:var(--cyan);border-color:#5eead466}.mark{font-family:var(--font-mono);font-size:.9rem}.mark.on{color:var(--cyan)}.mark.off{color:var(--muted-2)}.recorder-stack{display:grid;gap:.85rem}.recorder{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.1rem}.recorder-recording{border-color:var(--pink)}.recorder-recorded{border-color:var(--cyan)}.recorder-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.75rem}.recorder-label{font-family:var(--font-mono);font-size:.95rem;font-weight:500}.recorder-status{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase}.recorded-status{color:var(--cyan)}.empty-status{color:var(--muted)}.pending-status{color:var(--gold)}.recorder-body{display:grid;gap:.6rem}.recorder-audio{width:100%;height:36px;background:var(--bg-3);border-radius:8px;filter:invert(.92) sepia(.1) saturate(1.1)}.recorder-actions{display:flex;gap:.5rem;align-items:center}.suggestion{margin:.5rem 0 0;padding:.55rem .8rem;background:var(--bg-3);border-left:3px solid var(--gold);border-radius:6px;font-style:italic;color:var(--fg-dim);font-size:.9rem}.recorder-record{justify-self:start}.recorder-live{display:flex;align-items:center;gap:.75rem}.recording-dot{width:12px;height:12px;border-radius:50%;background:var(--pink);box-shadow:0 0 12px var(--pink);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.recording-time{font-family:var(--font-mono);font-size:1.1rem;color:var(--pink)}.btn{font-family:var(--font-mono);font-size:.85rem;letter-spacing:.06em;padding:.55rem .95rem;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;background:var(--bg-3);color:var(--fg)}.btn:hover{background:var(--bg-4)}.btn-primary{background:var(--cyan);color:#03110d;font-weight:600;text-transform:uppercase}.btn-primary:hover{background:var(--cyan);filter:brightness(1.08)}.btn-secondary{background:var(--bg-3);border-color:var(--border)}.btn-stop{background:var(--pink);color:#18060a;font-weight:600}.btn-stop:hover{filter:brightness(1.08)}.btn-danger-link{background:none;color:var(--pink);padding:.55rem .5rem}.btn-danger-link:hover{background:var(--pink-soft)}@media(max-width:540px){.app-main{padding-top:1.25rem;padding-bottom:calc(2.5rem + env(safe-area-inset-bottom))}.app-header-inner{gap:.5rem}.hero{margin-bottom:1.25rem}.hero-title{font-size:clamp(1.85rem,8vw,2.5rem)}.page-title{font-size:clamp(1.4rem,6vw,1.6rem)}.card{padding:1.1rem}.bucket{padding:.85rem .3rem}.bucket-count{font-size:clamp(1.7rem,9vw,2.5rem)}.bucket-label{font-size:.6rem;letter-spacing:.14em}.quiz-header{margin-bottom:.9rem}.quiz-form input{font-size:clamp(1.25rem,6vw,1.7rem);padding:.85rem 1rem}.quiz-form button{font-size:1.25rem;min-width:3.25rem;padding:0 1rem}.hint-slot{min-height:2.75rem}.hint-letters{font-size:clamp(1.3rem,7vw,1.9rem)}.hint-line{width:1.75em}.audio-row{gap:.4rem;margin-bottom:1rem}.audio-button{padding:.75rem .85rem;font-size:.9rem}.audio-button.primary{padding:.95rem 1rem;font-size:1rem}.start-quiz{font-size:1.1rem;padding:1rem .85rem;flex-wrap:wrap;gap:.5rem .85rem;letter-spacing:.02em}.drill-card{padding:.85rem 1rem}.drill-card-name{font-size:1rem}.drill-card-meta{font-size:.75rem}.pt-header{padding:.5rem .55rem;gap:.45rem}.pt-name{min-width:4.5rem;font-size:.85rem}.pt-box{width:10px;height:10px}.pt-child{margin-left:1rem}.pt-words{margin-left:1rem;font-size:.8rem}.result-score{font-size:clamp(3.8rem,18vw,6rem)}.recorder{padding:.85rem .95rem}.recorder-head{margin-bottom:.55rem}}@media(max-width:380px){.student-chip{padding:.2rem;gap:0}.student-chip-name{display:none}.buckets{gap:.35rem}}@media(max-height:500px){.app-header-inner{height:48px}.app-main{padding-top:.85rem}.hero{margin-bottom:.85rem}}@media(prefers-reduced-motion:reduce){.shake,.recording-dot{animation:none}.quiz-progressbar-fill,.drill-progress-fill,.student-card,.drill-card,.audio-button,.nav-card,.start-quiz{transition:none}}
