:root{--bg: #050905;--panel: #0d150d;--panel-2: #131e13;--border: #233823;--text: #c8e8c8;--muted: #6c8a6c;--accent: #9bf24c;--accent-2: #4cf2b0;--warn: #f2c84c;--bad: #ff6b6b;--hanzi-glow: rgba(155, 242, 76, .55);--font-mono: ui-monospace, "JetBrains Mono", "Fira Code", "Menlo", "Consolas", monospace}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;background:var(--bg);color:var(--text);font-family:var(--font-mono);overflow:hidden;user-select:none}body:before{content:"";position:fixed;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 1px,transparent 3px);z-index:100;mix-blend-mode:overlay}body:after{content:"";position:fixed;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.55) 100%);z-index:99}#app{position:relative;width:100%;height:100%;display:flex;flex-direction:column}.hud{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(155,242,76,.04),transparent);z-index:5}.hud-left{display:flex;align-items:baseline;gap:10px}.logo{margin:0;font-family:var(--font-mono);font-size:18px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--text)}.logo .accent{color:var(--accent)}.badge{font-size:9px;font-weight:800;letter-spacing:.18em;color:var(--accent);border:1px solid var(--accent);padding:2px 6px;border-radius:3px;text-transform:uppercase}.hud-stats{display:flex;gap:22px}.stat{display:flex;flex-direction:column;align-items:flex-end;line-height:1}.stat-label{font-size:9.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}.stat b{font-size:18px;font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums;text-shadow:0 0 6px rgba(155,242,76,.25)}.arena{flex:1;position:relative;overflow:hidden;background:radial-gradient(ellipse at center top,rgba(155,242,76,.07),transparent 65%),var(--panel);outline:none}.enemies{position:absolute;inset:0}.bottom-line{position:absolute;left:0;right:0;bottom:8%;height:2px;background:linear-gradient(90deg,transparent,var(--bad) 20%,var(--bad) 80%,transparent);opacity:.55;pointer-events:none;box-shadow:0 0 12px #ff6b6b59}.screen-flash{position:absolute;inset:0;pointer-events:none;background:#ff3c3c00;transition:background 80ms ease-out}.screen-flash.is-miss{background:#ff3c3c47;animation:screenflash-fade .36s ease-out}@keyframes screenflash-fade{0%{background:#ff3c3c5c}to{background:#ff3c3c00}}.screen-flash.is-good{background:#9bf24c2e;animation:goodflash-fade .28s ease-out}@keyframes goodflash-fade{0%{background:#9bf24c4d}to{background:#9bf24c00}}.screen-flash.is-waveclear{animation:waveclearflash .52s ease-out}@keyframes waveclearflash{0%{background:#9bf24c8c}35%{background:#ffffff52}to{background:#9bf24c00}}.screen-flash.is-bosskill{animation:bosskillflash .72s ease-out}@keyframes bosskillflash{0%{background:#ffe66ea6}20%{background:#ffffff8c}55%{background:#9bf24c52}to{background:#9bf24c00}}.enemy{position:absolute;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;min-width:86px;text-align:center;transform:translate(-50%,-50%);will-change:transform,opacity;transition:border-color .12s,background .12s,box-shadow .12s}.enemy .hanzi{font-size:38px;font-weight:700;line-height:1;color:var(--text);text-shadow:0 0 8px var(--hanzi-glow);letter-spacing:-.02em}.enemy .english{font-size:11px;letter-spacing:.06em;color:var(--muted);text-transform:lowercase;white-space:nowrap}body.hide-pinyin .enemy .pinyin,body.hide-pinyin .enemy .tone-mark{display:none}.enemy.is-targeted{border-color:var(--accent);background:#9bf24c1a;box-shadow:0 0 16px #9bf24c52,inset 0 0 8px #9bf24c1f}.enemy.is-targeted .hanzi{color:var(--accent);text-shadow:0 0 14px rgba(155,242,76,.85)}.enemy.is-targeted{animation:target-pulse .9s ease-in-out infinite}@keyframes target-pulse{0%,to{box-shadow:0 0 16px #9bf24c52,inset 0 0 8px #9bf24c1f}50%{box-shadow:0 0 26px #9bf24c8c,inset 0 0 12px #9bf24c38}}.enemy.destroyed{animation:destroy-pop .28s ease-out forwards;pointer-events:none}@keyframes destroy-pop{0%{transform:translate(-50%,-50%) scale(1);opacity:1;background:#9bf24c8c;border-color:var(--accent)}35%{transform:translate(-50%,-50%) scale(1.18);opacity:1;background:#ffffffa6;border-color:#fff}to{transform:translate(-50%,-50%) scale(.6);opacity:0;background:#9bf24c00}}.enemy.escaped{animation:escaped-fade .32s ease-out forwards;pointer-events:none}@keyframes escaped-fade{0%{opacity:1;background:#ff505073;border-color:var(--bad)}to{opacity:0;transform:translate(-50%,-50%) translateY(20px) scale(.95)}}.dock{border-top:1px solid var(--border);background:linear-gradient(0deg,rgba(155,242,76,.05),transparent);padding:12px 18px 14px;z-index:5}.dock-row{display:flex;align-items:center;gap:14px;justify-content:center;margin-bottom:10px}.buffer-label{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}.buffer{display:inline-block;min-width:200px;text-align:center;font-size:22px;font-weight:700;color:var(--text);letter-spacing:.12em;padding:6px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;font-variant-numeric:tabular-nums;text-shadow:0 0 6px rgba(155,242,76,.15)}.buffer:empty:after{content:"•";color:var(--muted);opacity:.5}.buffer.has-match{color:var(--accent);border-color:var(--accent);background:#9bf24c14;text-shadow:0 0 10px rgba(155,242,76,.55)}.ime-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:720px;margin:0 auto}.ime-slot{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;transition:border-color .12s,transform .12s,background .12s;position:relative}.ime-slot .slot-num{font-size:10px;letter-spacing:.16em;color:var(--muted);font-weight:800}.ime-slot .slot-hanzi{font-size:26px;line-height:1;font-weight:700;color:var(--muted);letter-spacing:-.02em}.ime-slot.is-active{border-color:var(--accent);background:#9bf24c1a}.ime-slot.is-active .slot-num{color:var(--accent)}.ime-slot.is-active .slot-hanzi{color:var(--text);text-shadow:0 0 10px rgba(155,242,76,.45)}.ime-slot.flash-correct{animation:slot-correct .24s ease-out}.ime-slot.flash-wrong{animation:slot-wrong .24s ease-out}@keyframes slot-correct{0%{background:#9bf24c1a}40%{background:#9bf24c8c;transform:scale(1.05)}to{background:#9bf24c1a;transform:scale(1)}}@keyframes slot-wrong{0%{background:#9bf24c1a}40%{background:#ff505073;transform:translate(-3px)}60%{transform:translate(3px)}to{background:#9bf24c1a;transform:translate(0)}}.hint{margin-top:10px;font-size:11px;letter-spacing:.08em;color:var(--muted);text-align:center}.hint code{background:var(--panel-2);border:1px solid var(--border);padding:1px 5px;border-radius:3px;color:var(--accent)}.overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#050905e0;z-index:50;animation:overlay-in .22s ease-out}.overlay[hidden]{display:none}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.overlay-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:30px 36px 26px;max-width:540px;width:90%;text-align:center;box-shadow:0 0 40px #9bf24c1a}.overlay-card h2{margin:0 0 12px;font-size:32px;font-weight:900;letter-spacing:.04em;color:var(--accent);text-transform:uppercase;text-shadow:0 0 18px rgba(155,242,76,.45)}.overlay-card h2 .accent{color:var(--text)}.tagline{margin:0 0 18px;font-size:13px;color:var(--text);line-height:1.55}.rules{margin:0 0 18px;padding-left:22px;text-align:left;font-size:12.5px;line-height:1.6;color:var(--text)}.rules li{margin-bottom:4px}.rules b{color:var(--accent)}.rules code{background:var(--panel-2);border:1px solid var(--border);padding:1px 5px;border-radius:3px;color:var(--accent-2);font-size:11.5px}.overlay-actions{display:flex;gap:10px;justify-content:center;margin-top:4px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;border-radius:6px;cursor:pointer;transition:border-color .12s,background .12s,transform .12s,color .12s}.btn:hover{border-color:var(--accent);color:var(--accent)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:#062006;border-color:var(--accent);box-shadow:0 0 18px #9bf24c4d}.btn-primary:hover{color:#062006;background:#b6f266;border-color:#b6f266}.btn-daily{border-color:var(--accent);color:var(--accent);box-shadow:0 0 10px #9bf24c26}.btn-daily:hover{background:#9bf24c1f;color:var(--accent)}.btn-daily-copy{margin-top:4px}.best-line{margin-top:14px;font-size:11px;letter-spacing:.08em;color:var(--muted)}.best-line b{color:var(--warn);font-variant-numeric:tabular-nums}.end-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 18px;margin:14px 0 18px;text-align:left}.end-stats>div{display:flex;align-items:baseline;justify-content:space-between;border-bottom:1px dashed var(--border);padding-bottom:4px}.end-stats b{color:var(--accent);font-variant-numeric:tabular-nums;font-size:14px}.end-newbest{display:inline-block;margin-bottom:14px;padding:4px 14px;background:#f2c84c1f;border:1px solid var(--warn);border-radius:999px;color:var(--warn);font-weight:800;letter-spacing:.18em;font-size:11px;text-transform:uppercase;animation:newbest-pulse 1.4s ease-in-out infinite}.end-newbest[hidden]{display:none}@keyframes newbest-pulse{0%,to{box-shadow:0 0 12px #f2c84c33}50%{box-shadow:0 0 24px #f2c84c8c}}.popup{position:absolute;font-size:18px;font-weight:800;color:var(--accent);text-shadow:0 0 10px rgba(155,242,76,.65);pointer-events:none;animation:popup-rise .8s ease-out forwards}.popup.combo{font-size:22px;color:var(--warn);text-shadow:0 0 12px rgba(242,200,76,.7)}@keyframes popup-rise{0%{opacity:0;transform:translate(-50%) scale(.7)}20%{opacity:1;transform:translate(-50%,-20px) scale(1.1)}to{opacity:0;transform:translate(-50%,-70px) scale(.95)}}.particles-canvas{position:absolute;inset:0;pointer-events:none;z-index:4}.popup.tone{font-size:16px;font-weight:700;letter-spacing:.04em;color:var(--accent-2);text-shadow:0 0 10px rgba(76,242,176,.6)}.enemy .tone-mark{font-size:13px;font-weight:600;color:var(--accent-2);letter-spacing:.06em;margin-top:1px;text-shadow:0 0 6px rgba(76,242,176,.5);display:none}.enemy.show-tones .tone-mark{display:inline-block}.wave-banner{position:absolute;left:50%;top:38%;transform:translate(-50%,-50%);padding:14px 36px;background:#0d150de0;border:2px solid var(--accent);border-radius:6px;font-weight:900;font-size:22px;letter-spacing:.32em;color:var(--accent);text-transform:uppercase;text-shadow:0 0 18px rgba(155,242,76,.65);box-shadow:0 0 36px #9bf24c73;pointer-events:none;animation:wave-banner-in 1.1s cubic-bezier(.18,.78,.22,1) forwards;z-index:6}.wave-banner[hidden]{display:none}@keyframes wave-banner-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.6);letter-spacing:.1em}18%{opacity:1;transform:translate(-50%,-50%) scale(1.08)}28%{transform:translate(-50%,-50%) scale(1);letter-spacing:.32em}78%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1)}}.combo-banner{position:absolute;left:50%;top:16%;transform:translate(-50%,-50%);padding:6px 18px;font-weight:900;font-size:18px;letter-spacing:.18em;color:var(--warn);text-transform:uppercase;text-shadow:0 0 12px rgba(242,200,76,.7);pointer-events:none;opacity:0;transition:opacity 80ms;z-index:6}.combo-banner.show{animation:combo-banner-pulse .7s ease-out forwards}@keyframes combo-banner-pulse{0%{opacity:0;transform:translate(-50%,-50%) scale(.6)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}60%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(1)}}:root{--heat: 0}#mult-stat b{color:hsl(calc(95deg - var(--heat) * 95deg),calc(70% + var(--heat) * 25%),calc(60% + var(--heat) * 8%));text-shadow:0 0 calc(6px + var(--heat) * 12px) hsla(calc(95deg - var(--heat) * 95deg),90%,60%,calc(.25 + var(--heat) * .55));transition:color .12s,text-shadow .12s}#combo-stat{opacity:0;transition:opacity .18s}#combo-stat.is-live{opacity:1}#combo-stat b{color:var(--warn);text-shadow:0 0 8px rgba(242,200,76,.6)}.arena.is-shaking{animation:screen-shake .32s cubic-bezier(.36,.07,.19,.97)}@keyframes screen-shake{10%,90%{transform:translate(-1px)}20%,80%{transform:translate(2px)}30%,50%,70%{transform:translate(-3px,1px)}40%,60%{transform:translate(3px,-1px)}}.ime-slot .slot-tone{display:block;font-size:10.5px;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-top:2px;height:13px;font-style:italic}.ime-slot.is-active .slot-tone{color:var(--accent-2);text-shadow:0 0 8px rgba(76,242,176,.45)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border);color:var(--text);font-size:16px;border-radius:6px;cursor:pointer;transition:border-color .12s,color .12s,background .12s;margin-left:8px;padding:0}.icon-btn:hover{border-color:var(--accent);color:var(--accent);background:#9bf24c0d}.settings-panel{position:fixed;top:0;right:0;width:min(420px,90vw);height:100%;background:linear-gradient(180deg,var(--panel),var(--bg));border-left:1px solid var(--border);z-index:80;display:flex;flex-direction:column;box-shadow:-10px 0 50px #0009;overflow:hidden;transform:translate(100%);transition:transform .22s ease-out}.settings-panel[hidden]{display:none}.settings-panel.is-open{transform:translate(0)}.settings-scrim{position:fixed;inset:0;background:#0000008c;z-index:75;opacity:0;transition:opacity .22s ease-out}.settings-scrim[hidden]{display:none}.settings-scrim.is-open{opacity:1}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,rgba(155,242,76,.05),transparent)}.settings-header h3{margin:0;font-size:13px;font-weight:800;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}.settings-body{padding:16px 18px 24px;overflow-y:auto;flex:1}.setting-group{margin-bottom:22px;padding-bottom:16px;border-bottom:1px dashed var(--border)}.setting-group:last-child{border-bottom:none;padding-bottom:0}.setting-group h4{margin:0 0 8px;font-size:11px;font-weight:800;letter-spacing:.14em;color:var(--text);text-transform:uppercase;display:flex;align-items:baseline;justify-content:space-between}.setting-value{color:var(--accent);font-size:14px;font-weight:800;font-variant-numeric:tabular-nums}.setting-hint{margin:4px 0 0;font-size:11px;color:var(--muted);letter-spacing:.04em;line-height:1.45}.seg{display:flex;gap:0;border:1px solid var(--border);border-radius:6px;overflow:hidden;background:var(--panel-2)}.seg-btn{flex:1;padding:8px 10px;background:transparent;border:none;border-right:1px solid var(--border);color:var(--muted);font-family:inherit;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .12s,color .12s}.seg-btn:last-child{border-right:none}.seg-btn:hover{color:var(--text)}.seg-btn.is-active{background:var(--accent);color:#062006;text-shadow:0 0 6px rgba(0,0,0,.35);box-shadow:inset 0 0 12px #ffffff2e}.slider{width:100%;-webkit-appearance:none;appearance:none;background:transparent;margin:6px 0 2px;height:28px}.slider:focus{outline:none}.slider::-webkit-slider-runnable-track{height:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:999px}.slider::-moz-range-track{height:4px;background:var(--panel-2);border:1px solid var(--border);border-radius:999px}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;height:16px;width:16px;background:var(--accent);border-radius:50%;border:2px solid var(--bg);margin-top:-7px;box-shadow:0 0 8px #9bf24c8c;cursor:pointer}.slider::-moz-range-thumb{height:16px;width:16px;background:var(--accent);border-radius:50%;border:2px solid var(--bg);box-shadow:0 0 8px #9bf24c8c;cursor:pointer}.cluster-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:4px}.cluster-pill{padding:6px 4px;background:var(--panel-2);border:1px solid var(--border);color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.04em;text-align:center;border-radius:5px;cursor:pointer;transition:all .12s;font-family:var(--font-mono)}.cluster-pill:hover{color:var(--text);border-color:var(--text)}.cluster-pill.is-on{background:#9bf24c1f;border-color:var(--accent);color:var(--accent)}.cluster-actions{display:flex;gap:8px;margin-top:10px}.pack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-top:4px}.pack-pill{padding:6px 4px;background:var(--panel-2);border:1px solid var(--border);color:var(--muted);font-size:12px;font-weight:700;letter-spacing:.04em;text-align:center;border-radius:5px;cursor:pointer;transition:all .12s;font-family:var(--font-mono)}.pack-pill:hover{color:var(--text);border-color:var(--text)}.pack-pill.is-on{background:#9bf24c1f;border-color:var(--accent);color:var(--accent)}.btn-sm{padding:5px 12px;font-size:10.5px}.voice-meta{margin:8px 0 4px;padding:6px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;font-size:10.5px;color:var(--muted);letter-spacing:.02em;font-family:var(--font-mono)}.voice-meta.is-ready{border-color:var(--accent);color:var(--accent)}.voice-meta.is-missing{border-color:var(--bad);color:var(--bad)}.voice-rate-row{display:flex;align-items:center;gap:10px;margin-top:8px}.voice-rate-row label{font-size:10.5px;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;font-weight:700;min-width:40px}.voice-rate-row .slider{flex:1}.voice-rate-row .setting-value{min-width:40px;text-align:right}.checkbox{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text);margin-bottom:8px;cursor:pointer}.checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.practice-tag{display:none;font-size:10px;letter-spacing:.18em;color:var(--accent-2);border:1px solid var(--accent-2);padding:2px 8px;border-radius:3px;margin-left:12px;text-transform:uppercase;font-weight:800}body.is-practice .practice-tag{display:inline-block}@media (prefers-reduced-motion: reduce){body:before{display:none}.enemy.is-targeted{animation:none}.enemy.destroyed,.enemy.escaped{animation-duration:.1s}.ime-slot.flash-correct,.ime-slot.flash-wrong,.end-newbest{animation:none}.popup{animation-duration:.2s}.screen-flash.is-miss,.screen-flash.is-good{animation:none}.wave-banner,.combo-banner.show{animation:none;opacity:1}.arena.is-shaking{animation:none}}.overlay-card--wide{max-width:880px;width:92%;text-align:left;max-height:90vh;overflow-y:auto}.overlay-card--wide h2{text-align:center}.lifetime-summary{margin-top:14px;padding-top:12px;border-top:1px dashed var(--border);font-size:11px;color:var(--muted)}.lt-row{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:baseline;justify-content:center;margin-bottom:6px}.lt-row.big{gap:8px 22px;font-size:12px}.lt-label{font-size:9.5px;font-weight:800;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}.lt-row b{color:var(--accent);font-variant-numeric:tabular-nums;font-size:13px}.lt-row.big b{font-size:16px}.lt-empty{color:var(--muted);font-style:italic}.tier-pill{display:inline-block;padding:2px 9px;border-radius:999px;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;border:1px solid;background:#00000059}.tier-pill.tier-gold{border-color:#f5d23a;color:#f5d23a;text-shadow:0 0 8px rgba(245,210,58,.55);background:#f5d23a1f}.tier-pill.tier-silver{border-color:#d6dee0;color:#d6dee0;text-shadow:0 0 6px rgba(214,222,224,.4);background:#d6dee01a}.tier-pill.tier-bronze{border-color:#d49767;color:#d49767;text-shadow:0 0 6px rgba(212,151,103,.4);background:#d497671a}.tier-pill.tier-none{border-color:var(--border);color:var(--muted)}.mastery-totals{margin:10px 0 18px;padding:12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px}.mastery-subhead{margin:22px 0 4px;font-size:12px;font-weight:800;letter-spacing:.18em;color:var(--accent);text-transform:uppercase}.cluster-mastery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:8px;margin-bottom:8px}.cluster-card{position:relative;padding:10px 12px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;display:flex;flex-direction:column;gap:6px;transition:border-color .12s}.cluster-card.tier-gold{border-color:#f5d23a8c;box-shadow:0 0 12px #f5d23a2e}.cluster-card.tier-silver{border-color:#d6dee073;box-shadow:0 0 8px #d6dee01a}.cluster-card.tier-bronze{border-color:#d4976780}.cluster-name{font-size:18px;font-weight:800;letter-spacing:.04em;color:var(--text);font-family:var(--font-mono)}.cluster-tier{line-height:1}.cluster-numbers{display:flex;gap:14px;margin-top:2px}.cluster-numbers span{display:flex;flex-direction:column;align-items:flex-start;font-size:12px;line-height:1.1;color:var(--accent);font-variant-numeric:tabular-nums}.cluster-numbers i{display:block;font-style:normal;font-size:8.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-top:2px}.cluster-weakest{font-size:10px;color:var(--muted);letter-spacing:.04em}.cluster-weakest b{color:var(--bad);font-size:14px;margin-left:4px;font-weight:700}.weak-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:6px;margin:10px 0 18px}.weak-item{display:grid;grid-template-columns:32px 1fr auto auto;align-items:center;gap:6px;padding:6px 10px;background:var(--panel-2);border:1px solid var(--border);border-radius:5px;font-size:11px}.weak-hanzi{font-size:22px;font-weight:700;color:var(--text);line-height:1;text-shadow:0 0 6px rgba(255,107,107,.35)}.weak-eng{color:var(--muted);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weak-pin{color:var(--accent-2);font-style:italic;font-size:10.5px}.weak-rate{color:var(--bad);font-weight:800;font-variant-numeric:tabular-nums}.weak-empty{color:var(--muted);font-style:italic}.btn-danger{border-color:var(--bad);color:var(--bad)}.btn-danger:hover{background:#ff6b6b24;color:var(--bad);border-color:var(--bad)}body.is-tone-quiz .ime-slot .slot-num{background:#4cf2b02e;border:1px solid var(--accent-2);color:var(--accent-2);border-radius:999px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;text-shadow:0 0 6px rgba(76,242,176,.55)}body.is-tone-quiz .hint:after{content:" · TONE-QUIZ MODE: press 1-4 to commit by tone (5 / 0 = neutral).";color:var(--accent-2);letter-spacing:.04em}.enemy.is-progressive .pinyin{display:none;font-size:12.5px;letter-spacing:.06em;color:var(--accent);text-shadow:0 0 6px rgba(155,242,76,.45);font-style:italic;margin-top:2px}.enemy.is-progressive .tone-mark{display:none}.enemy.is-progressive .hanzi{font-size:24px;filter:blur(8px) brightness(.5);letter-spacing:-.02em;transition:filter .24s ease-out}.enemy.is-progressive[data-progress="0"] .hanzi{visibility:hidden}.enemy.is-progressive[data-progress="1"] .pinyin{display:inline-block}.enemy.is-progressive[data-progress="1"] .hanzi{visibility:visible;filter:blur(7px) brightness(.55)}.enemy.is-progressive[data-progress="2"] .pinyin{display:inline-block}.enemy.is-progressive[data-progress="2"] .tone-mark{display:inline-block;font-size:12.5px;margin-top:2px;color:var(--accent-2)}.enemy.is-progressive[data-progress="2"] .hanzi{filter:blur(3px) brightness(.85)}.enemy.is-progressive[data-progress="3"] .pinyin,.enemy.is-progressive[data-progress="3"] .tone-mark{display:inline-block}.enemy.is-progressive[data-progress="3"] .hanzi{filter:blur(0) brightness(1)}body.is-progressive .hint:after{content:" · PROGRESSIVE: meaning first → pinyin → tones → Hanzi.";color:var(--accent);letter-spacing:.04em}@media (prefers-reduced-motion: reduce){.enemy.is-progressive .hanzi{transition:none}}.ime-slot.is-hidden{display:none}body.is-hard-mode .ime-slot.is-hidden{display:flex}body.hide-gloss .enemy .english{visibility:hidden}body.is-hard-mode .badge{color:var(--warn);border-color:var(--warn)}body.is-hard-mode .badge:after{content:" · HARD";color:var(--bad);font-weight:800;letter-spacing:.18em}.badge-mini{display:inline-block;font-size:9px;font-weight:800;letter-spacing:.18em;color:var(--bad);border:1px solid var(--bad);padding:1px 5px;border-radius:3px;text-transform:uppercase;margin-left:8px;vertical-align:middle}.hard-mode-group{border-left:2px solid var(--warn);padding-left:12px}.enemy.is-word .hanzi{font-size:30px;letter-spacing:-.02em}.enemy.is-word{border-color:var(--accent-2)}.enemy.is-chengyu,.enemy.is-boss{border:2px solid var(--warn);box-shadow:0 0 14px #f2c84c73;background:linear-gradient(180deg,#f2c84c14,#0006)}.enemy.is-chengyu .hanzi,.enemy.is-boss .hanzi{font-size:26px;letter-spacing:-.04em;color:#ffd76a;text-shadow:0 0 10px rgba(242,200,76,.7)}.enemy.is-chengyu .english,.enemy.is-boss .english{color:#ffe4a0}.enemy.is-powerup{border:2px solid #fff04c;box-shadow:0 0 18px #fff04ca6;background:linear-gradient(180deg,#fff04c1f,#0006);animation:pu-pulse 1.4s ease-in-out infinite}.enemy.is-powerup .hanzi{color:#fff04c;text-shadow:0 0 12px rgba(255,240,76,.9)}.enemy.is-powerup .english{color:#fff8a8;font-weight:800;letter-spacing:.18em}@keyframes pu-pulse{0%,to{box-shadow:0 0 18px #fff04c8c}50%{box-shadow:0 0 28px #fff04cf2}}body.is-marathon .badge:before{content:"MARATHON · ";color:var(--accent-2)}body.is-traditional .badge:before{content:"繁 · ";color:var(--accent-2);font-weight:700}@media (prefers-reduced-motion: reduce){.enemy.is-powerup{animation:none}}body.is-reverse .ime-bar{display:none}body.is-reverse .enemy .english{visibility:hidden}body.is-reverse .enemy .hanzi{font-size:36px;text-shadow:0 0 14px rgba(155,242,76,.7)}body.is-reverse .badge:before{content:"REV · ";color:var(--bad);font-weight:800}body.is-reverse .hint:after{content:" · REVERSE: type pinyin from memory — no IME bar.";color:var(--accent-2);letter-spacing:.04em}.display-name-row{margin-top:14px;display:flex;flex-direction:column;gap:4px}.display-name-row label{font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase}.display-name-row input{background:var(--panel);border:1px solid var(--border);color:var(--text);font-family:var(--font-mono);font-size:14px;padding:8px 10px;border-radius:4px;outline:none}.display-name-row input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #9bf24c33}.leaderboard-block{margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}.lb-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.lb-header h3{margin:0;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}.seg-sm .seg-btn{font-size:10px;padding:4px 10px}.lb-list{display:flex;flex-direction:column;gap:4px;max-height:260px;overflow-y:auto;padding-right:4px}.lb-row{display:grid;grid-template-columns:32px 1fr auto auto auto;gap:10px;align-items:center;font-size:12px;padding:4px 6px;border-radius:3px;background:#ffffff05}.lb-row:nth-child(1){color:#ffd76a}.lb-row:nth-child(2){color:#c8d4e0}.lb-row:nth-child(3){color:#d4a07a}.lb-rank{font-weight:800;letter-spacing:.04em}.lb-name{font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-cc{color:var(--muted);font-style:normal;font-size:10px;margin-left:6px}.lb-score{font-weight:800;color:var(--accent)}.lb-meta{color:var(--muted);font-size:10.5px;letter-spacing:.04em}.lb-empty{color:var(--muted);font-style:italic;display:block;padding:12px 0;text-align:center}.lb-chip{display:inline-block;font-size:9.5px;letter-spacing:.06em;text-transform:lowercase;color:var(--muted);background:#9bf24c0f;border:1px solid rgba(155,242,76,.18);border-radius:999px;padding:2px 7px;white-space:nowrap;font-family:var(--font-mono)}.lb-chip--legacy{color:#c8d4e08c;background:#ffffff08;border-color:#ffffff14}.lb-board-row{margin-bottom:10px;flex-wrap:wrap}.end-rank{margin-top:8px;font-size:13px;color:var(--accent-2);text-align:center;letter-spacing:.08em}#app{border-radius:18px;box-shadow:inset 0 0 0 2px #2d462dd9,inset 0 0 0 4px #142314f2,inset 0 0 60px #0000008c,inset 0 0 24px #9bf24c0f;overflow:hidden;animation:crt-poweron .9s ease-out}@keyframes crt-poweron{0%{filter:brightness(0) saturate(0);transform:scaleY(.02)}20%{filter:brightness(.6) saturate(.4);transform:scaleY(1)}60%{filter:brightness(1.18) saturate(1.4)}to{filter:none;transform:scaleY(1)}}body:before{animation:interlace-jitter 4.2s steps(2,end) infinite}@keyframes interlace-jitter{0%,49%{transform:translateY(0);opacity:1}50%,to{transform:translateY(.5px);opacity:.92}}@media (prefers-reduced-motion: reduce){#app{animation:none}body:before{animation:none}}.enemy.is-boss{min-width:138px;padding:14px 20px 12px;border:3px solid var(--warn);background:linear-gradient(180deg,#ffd76424,#140c008c);box-shadow:0 0 22px #f2c84c8c,inset 0 0 14px #ffd7642e;animation:boss-idle 2.4s ease-in-out infinite}.enemy.is-boss .hanzi{font-size:48px;letter-spacing:-.04em;color:#ffd76a;text-shadow:0 0 18px rgba(242,200,76,.85),0 0 4px #fff}.enemy.is-boss .english{font-size:12px;color:#ffe4a0;font-weight:800;letter-spacing:.12em}@keyframes boss-idle{0%,to{box-shadow:0 0 22px #f2c84c8c,inset 0 0 14px #ffd7642e}50%{box-shadow:0 0 36px #f2c84cd9,inset 0 0 22px #ffd7644d}}.enemy.is-boss:before{content:attr(data-boss-hp) "/" attr(data-boss-hp-max);position:absolute;top:-26px;left:50%;transform:translate(-50%);font-size:11px;font-weight:800;letter-spacing:.18em;color:var(--bad);background:#140000b3;padding:2px 10px;border:1px solid var(--bad);border-radius:999px;text-shadow:0 0 6px rgba(255,80,80,.65);white-space:nowrap}.enemy.is-boss.boss-stagger{animation:boss-stagger .28s ease-out,boss-idle 2.4s ease-in-out .28s infinite}@keyframes boss-stagger{0%{transform:translate(-50%,-50%) scale(1);filter:brightness(1)}20%{transform:translate(-52%,-50%) scale(1.06);filter:brightness(2.5) hue-rotate(-12deg)}45%{transform:translate(-49%,-49%) scale(.98);filter:brightness(.6)}70%{transform:translate(-51%,-50%) scale(1.02);filter:brightness(1.4)}to{transform:translate(-50%,-50%) scale(1);filter:brightness(1)}}.enemy.is-boss:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(95deg,transparent 48%,rgba(0,0,0,.55) 49%,transparent 50%) no-repeat,linear-gradient(165deg,transparent 38%,rgba(0,0,0,.45) 39%,transparent 40%) no-repeat,linear-gradient(45deg,transparent 28%,rgba(0,0,0,.4) 29%,transparent 30%) no-repeat;background-size:0% 100%,0% 100%,0% 100%;background-position:left,left,left;mix-blend-mode:multiply;border-radius:8px;opacity:0;transition:opacity .2s}.enemy.is-boss.boss-cracks-1:after{opacity:.7;background-size:100% 100%,0% 100%,0% 100%}.enemy.is-boss.boss-cracks-2:after{opacity:.85;background-size:100% 100%,100% 100%,0% 100%}.enemy.is-boss.boss-cracks-3:after{opacity:1;background-size:100% 100%,100% 100%,100% 100%}.wave-banner{font-size:28px;padding:18px 48px;border-width:3px;box-shadow:0 0 60px #9bf24c8c,inset 0 0 24px #9bf24c2e}@media (prefers-reduced-motion: reduce){.enemy.is-boss,.enemy.is-boss.boss-stagger{animation:none}}.enemy .hanzi .peel-char{display:inline-block;transition:opacity .22s ease-out,filter .22s ease-out,transform .22s ease-out}.enemy.is-boss.boss-kind-peel .peel-char.peeled{text-decoration:line-through;text-decoration-thickness:3px;text-decoration-color:#ff5a5ad9;opacity:.32;filter:grayscale(.7);transform:scale(.92)}@media (prefers-reduced-motion: reduce){.enemy .hanzi .peel-char,.enemy.is-boss.boss-kind-peel .peel-char.peeled{transition:none;transform:none}}.splash-layout{display:flex;gap:28px;align-items:flex-start;max-width:920px;width:94%;max-height:92vh;overflow-y:auto;padding:28px 32px;background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:0 0 60px #9bf24c1a,inset 0 0 2px #9bf24c14}.splash-hero{flex:1;min-width:0;display:flex;flex-direction:column;gap:0}.splash-hanzi-rain{position:relative;height:52px;overflow:hidden;margin-bottom:6px;pointer-events:none}.rain-char{position:absolute;font-size:28px;font-weight:700;color:var(--accent);opacity:0;animation:rain-fall 3.6s ease-in infinite;text-shadow:0 0 14px rgba(155,242,76,.65)}.rc1{left:6%;animation-delay:0s}.rc2{left:19%;animation-delay:.55s}.rc3{left:34%;animation-delay:1.1s}.rc4{left:52%;animation-delay:.28s}.rc5{left:67%;animation-delay:1.65s}.rc6{left:82%;animation-delay:.82s}@keyframes rain-fall{0%{opacity:0;transform:translateY(-28px)}15%{opacity:.8;transform:translateY(0)}75%{opacity:.5;transform:translateY(38px)}to{opacity:0;transform:translateY(52px)}}@media (prefers-reduced-motion: reduce){.rain-char{animation:none;opacity:.25;transform:translateY(12px)}}.splash-wordmark{display:flex;align-items:baseline;gap:12px;margin-bottom:10px}.splash-title{margin:0;font-family:var(--font-mono);font-size:clamp(28px,5vw,40px);font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);text-shadow:0 0 22px rgba(155,242,76,.5);line-height:1}.splash-title .accent{color:var(--text)}.splash-badge{font-size:10px;font-weight:800;letter-spacing:.18em;color:var(--accent-2);border:1px solid var(--accent-2);padding:2px 8px;border-radius:3px;text-transform:uppercase;white-space:nowrap}.splash-hook{margin:0 0 8px;font-size:15px;font-weight:700;color:var(--text);line-height:1.45;letter-spacing:.02em}.splash-sub{margin:0 0 20px;font-size:12px;color:var(--muted);line-height:1.55;letter-spacing:.02em;border-left:2px solid var(--border);padding-left:10px}.splash-tagline{margin:0 0 12px;font-size:13px;color:var(--text);line-height:1.5;letter-spacing:.02em;opacity:.92}.splash-byline{margin:0 0 20px;font-size:12px;color:var(--muted);line-height:1.55;letter-spacing:.02em;border-left:2px solid var(--border);padding-left:10px}.splash-byline em{font-style:italic}.splash-cta-block{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.btn-cta{font-size:15px;padding:12px 28px;letter-spacing:.08em;box-shadow:0 0 28px #9bf24c59}.btn-cta:hover{box-shadow:0 0 40px #9bf24c8c}.splash-rules-details{margin:14px 0 10px;border:1px solid var(--border);border-radius:6px;overflow:hidden}.splash-rules-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);cursor:pointer;list-style:none;user-select:none;transition:color .12s,background .12s}.splash-rules-toggle::-webkit-details-marker{display:none}.splash-rules-toggle:before{content:"▶";font-size:9px;transition:transform .16s}.splash-rules-details[open] .splash-rules-toggle:before{transform:rotate(90deg)}.splash-rules-toggle:hover{color:var(--text);background:#9bf24c0a}.splash-rules-details .rules{margin:0;padding:10px 14px 14px 30px;font-size:12px;border-top:1px solid var(--border)}.splash-about-details{margin:10px 0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.splash-about-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:11px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);cursor:pointer;list-style:none;user-select:none;transition:color .12s,background .12s}.splash-about-toggle::-webkit-details-marker{display:none}.splash-about-toggle:before{content:"▶";font-size:9px;transition:transform .16s}.splash-about-details[open] .splash-about-toggle:before{transform:rotate(90deg)}.splash-about-toggle:hover{color:var(--text);background:#9bf24c0a}.splash-about-body{padding:10px 14px 14px;border-top:1px solid var(--border)}.splash-about-p{margin:0 0 10px;font-size:12px;line-height:1.6;color:var(--muted);letter-spacing:.01em}.splash-about-p:last-child{margin-bottom:0}.splash-about-p em{font-style:italic;color:var(--text)}.splash-secondary-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.splash-footer{margin-top:18px;padding-top:10px;border-top:1px solid color-mix(in oklab,var(--text) 14%,transparent);font-size:11px;line-height:1.4;color:color-mix(in oklab,var(--text) 60%,transparent);letter-spacing:.02em}.splash-footer a{color:var(--accent-2);text-decoration:none;border-bottom:1px dotted color-mix(in oklab,var(--accent-2) 50%,transparent)}.splash-footer a:hover{color:var(--accent);border-bottom-color:var(--accent)}.splash-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;gap:0}.splash-sidebar .display-name-row{margin-top:0;margin-bottom:14px}.splash-sidebar .leaderboard-block{margin-top:0;padding-top:0;border-top:none}@media (max-width: 680px){.overlay:has(.splash-layout){align-items:flex-start;padding:12px 0}.splash-layout{flex-direction:column;gap:20px;padding:20px 18px;max-height:none;width:96%}.splash-sidebar{width:100%}.splash-title{font-size:26px}.splash-hanzi-rain{height:40px}.rain-char{font-size:22px}}.custom-pack-tag{display:none;font-size:10px;letter-spacing:.14em;color:var(--warn);border:1px solid var(--warn);padding:2px 8px;border-radius:3px;margin-left:12px;text-transform:uppercase;font-weight:800;animation:custpack-pulse 2s ease-in-out infinite}body.is-custom-pack .custom-pack-tag{display:inline-block}@keyframes custpack-pulse{0%,to{box-shadow:0 0 6px #f2c84c26}50%{box-shadow:0 0 14px #f2c84c73}}.packs-panel{position:fixed;top:0;right:0;width:min(520px,92vw);height:100%;background:linear-gradient(180deg,var(--panel),var(--bg));border-left:1px solid var(--border);z-index:80;display:flex;flex-direction:column;box-shadow:-10px 0 50px #0009;overflow:hidden;transform:translate(100%);transition:transform .22s ease-out}.packs-panel[hidden]{display:none}.packs-panel.is-open{transform:translate(0)}.packs-body{padding:16px 18px 24px;overflow-y:auto;flex:1}.pack-list-empty{margin:32px 0;text-align:center;color:var(--muted);font-size:12px;letter-spacing:.06em;line-height:1.6}.pack-list-empty .pack-empty-icon{font-size:32px;display:block;margin-bottom:10px;opacity:.5}.pack-list{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}.pack-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;transition:border-color .12s}.pack-item:hover{border-color:var(--accent)}.pack-item.is-active-pack{border-color:var(--warn);background:#f2c84c12}.pack-item-info{flex:1;min-width:0}.pack-item-name{font-size:13px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pack-item-meta{font-size:10.5px;color:var(--muted);margin-top:3px;letter-spacing:.04em}.pack-item-actions{display:flex;gap:6px;flex-shrink:0}.btn-pack-practice{padding:6px 14px;background:var(--accent);color:#062006;border-color:var(--accent);font-size:11px}.btn-pack-practice:hover{background:#b6f266;border-color:#b6f266;color:#062006}.btn-pack-delete{padding:6px 10px;color:var(--bad);border-color:var(--bad);font-size:11px;background:#ff6b6b0f}.btn-pack-delete:hover{background:#ff6b6b26;color:var(--bad)}.pack-upload-zone{border:2px dashed var(--border);border-radius:10px;padding:28px 20px;text-align:center;margin:18px 0;cursor:pointer;transition:border-color .14s,background .14s}.pack-upload-zone:hover,.pack-upload-zone.dragover{border-color:var(--accent);background:#9bf24c0d}.pack-upload-label{font-size:12px;color:var(--muted);line-height:1.55}.pack-upload-label b{color:var(--text)}.pack-upload-label a{color:var(--accent-2);text-decoration:none;cursor:pointer}.pack-upload-label a:hover{text-decoration:underline}.pack-preview-section{margin-top:14px}.pack-preview-title{font-size:11px;font-weight:800;letter-spacing:.16em;color:var(--text);text-transform:uppercase;margin-bottom:8px}.pack-preview-stats{display:flex;gap:14px;margin-bottom:10px;font-size:11px;color:var(--muted)}.pack-preview-stats b{color:var(--accent)}.pack-preview-stats .stat-bad{color:var(--bad)}.pack-preview-stats .stat-warn{color:var(--warn)}.pack-homophone-warn{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;background:#f2c84c14;border:1px solid var(--warn);border-radius:6px;margin-bottom:10px;font-size:11px;color:var(--warn);line-height:1.4}.pack-preview-table-wrap{max-height:260px;overflow-y:auto;border:1px solid var(--border);border-radius:6px;margin-bottom:14px}.pack-preview-table{width:100%;border-collapse:collapse;font-size:11.5px}.pack-preview-table th{position:sticky;top:0;background:var(--panel);padding:7px 10px;text-align:left;font-size:9.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}.pack-preview-table td{padding:6px 10px;border-bottom:1px dashed var(--border);color:var(--text);vertical-align:top}.pack-preview-table tr:last-child td{border-bottom:none}.pack-preview-table tr.row-error td{color:var(--bad);background:#ff6b6b0f}.pack-preview-table tr.row-warn td:last-child{color:var(--warn)}.pack-preview-table .td-warn{color:var(--warn);font-size:10px;line-height:1.35}.pack-preview-table .td-error{color:var(--bad);font-size:10px}.pack-preview-table .td-sentence,.pack-preview-table .td-other{max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted)}.pack-preview-table .td-sentence:hover,.pack-preview-table .td-other:hover{white-space:normal;overflow:visible;color:var(--text)}.pack-name-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}.pack-name-row label{font-size:10.5px;font-weight:800;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;white-space:nowrap}.pack-name-input{flex:1;background:var(--panel-2);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:13px;padding:7px 12px;border-radius:5px;transition:border-color .12s}.pack-name-input:focus{outline:none;border-color:var(--accent)}.pack-action-row{display:flex;gap:8px;margin-top:4px}#packs-body .btn-upload-new{width:100%;justify-content:center;margin-bottom:18px}.packs-section-head{font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:0 0 10px;padding-bottom:6px;border-bottom:1px dashed var(--border)}.streak-indicator{position:fixed;right:20px;top:50%;transform:translateY(-50%);display:none;flex-direction:column;align-items:center;gap:3px;padding:10px 14px;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-family:var(--font-mono);z-index:6;pointer-events:none;transition:border-color .16s,color .16s,background .16s,box-shadow .16s}.streak-indicator.is-visible{display:flex}.streak-indicator.is-tier1{color:var(--accent);border-color:var(--accent);background:#9bf24c1a;box-shadow:0 0 14px #9bf24c47}.streak-indicator.is-tier2{color:var(--warn);border-color:var(--warn);background:#f2c84c1a;box-shadow:0 0 18px #f2c84c66;animation:streak-t2-pulse 1.1s ease-in-out infinite}@keyframes streak-t2-pulse{0%,to{box-shadow:0 0 18px #f2c84c59}50%{box-shadow:0 0 30px #f2c84ca6}}.streak-indicator.is-resetting{color:var(--bad);border-color:var(--bad);background:#ff6b6b26;box-shadow:0 0 14px #ff6b6b59;animation:streak-reset-fade .42s ease-out forwards}@keyframes streak-reset-fade{0%{opacity:1}60%{opacity:.7}to{opacity:0}}@media (prefers-reduced-motion: reduce){.streak-indicator.is-tier2,.streak-indicator.is-resetting{animation:none}}.overlay-card--end{max-width:600px;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column}.end-sentence-panel{margin:12px 0 6px;border:1px solid var(--border);border-radius:6px;overflow:hidden;text-align:left}.end-sentence-panel[hidden]{display:none}.end-sentence-toggle{display:flex;align-items:center;gap:8px;padding:8px 14px;font-size:10.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);cursor:pointer;list-style:none;user-select:none;transition:color .12s,background .12s;background:var(--panel-2)}.end-sentence-toggle::-webkit-details-marker{display:none}.end-sentence-toggle:before{content:"▶";font-size:9px;transition:transform .16s}.end-sentence-panel[open] .end-sentence-toggle:before{transform:rotate(90deg)}.end-sentence-toggle:hover{color:var(--text);background:#9bf24c0d}.end-sentence-list{max-height:220px;overflow-y:auto;padding:8px 0 4px;border-top:1px solid var(--border);background:var(--panel)}.sr-row{display:grid;grid-template-columns:48px 80px 1fr auto;align-items:baseline;gap:8px 12px;padding:5px 14px;border-bottom:1px dashed var(--border);font-size:11.5px}.sr-row:last-child{border-bottom:none}.sr-hanzi{font-size:22px;font-weight:700;color:var(--text);text-shadow:0 0 6px var(--hanzi-glow);line-height:1}.sr-pinyin{color:var(--accent-2);font-style:italic;font-size:11px;letter-spacing:.04em}.sr-english{color:var(--muted);font-size:11px;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-sentence{color:var(--text);font-size:11px;line-height:1.4;opacity:.85;max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sr-sentence:hover{white-space:normal;overflow:visible}@media (prefers-reduced-motion: reduce){.end-sentence-toggle:before{transition:none}}
