: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}}.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}.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}.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}.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}}
