:root{--fs-2xs: .64rem;--fs-xs: .72rem;--fs-sm: .82rem;--fs-md: .95rem;--fs-lg: 1.08rem;--fs-xl: 1.3rem;--fs-2xl: 1.75rem;--fs-3xl: 2.4rem;--fs-4xl: clamp(2.2rem, 5vw, 3.4rem);--fs-words: clamp(1.45rem, 2.4vw, 1.9rem);--lh-words: 1.55;--reader-font: "Lexend", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--reader-lines: 3;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 24px;--s-6: 32px;--s-7: 48px;--s-8: 72px;--r-xs: 4px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 20px;--r-2xl: 28px;--r-full: 9999px;--tr-fast: .12s cubic-bezier(.4,0,.2,1);--tr-base: .18s cubic-bezier(.4,0,.2,1);--tr-slow: .32s cubic-bezier(.4,0,.2,1);--accent-h: 245;--accent-s: 72%;--accent-l: 62%;--accent: hsl(var(--accent-h) var(--accent-s) var(--accent-l));--accent-hi: hsl(calc(var(--accent-h) + 12) var(--accent-s) calc(var(--accent-l) + 5%));--accent-soft: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / .14);--accent-border: hsl(var(--accent-h) var(--accent-s) var(--accent-l) / .3);--grad: linear-gradient(135deg, var(--accent), var(--accent-hi));--ok: #34d399;--warn: #fbbf24;--err: #f87171;--font-body: "Lexend", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;--font-mono: ui-monospace, "SF Mono", Consolas, "DejaVu Sans Mono", monospace;--col-narrow: 1400px;--col-wide: 1640px;--glass-blur: saturate(140%) blur(18px)}:root,[data-theme=dark]{--bg: #060609;--bg-2: #0a0a0f;--surface: #101016;--surface-2: #16161e;--surface-hov: #1c1c26;--text: #f2f3f7;--text-dim: #d2d6e2;--muted: #a3a9ba;--border: rgba(255,255,255,.06);--border-mid: rgba(255,255,255,.1);--border-strong:rgba(255,255,255,.18);--hairline: rgba(255,255,255,.04);--shadow-sm: 0 1px 4px rgba(0,0,0,.45);--shadow-md: 0 6px 18px rgba(0,0,0,.55);--shadow-lg: 0 20px 50px rgba(0,0,0,.65);--glow: radial-gradient(ellipse at 50% -10%, hsl(var(--accent-h) var(--accent-s) 70% / .1), transparent 60%);color-scheme:dark}[data-theme=midnight]{--accent-h: 230;--accent-s: 78%;--accent-l: 66%;--bg: #050815;--bg-2: #0a0e23;--surface: #0e1530;--surface-2: #131b3e;--surface-hov: #1a234d;--text: #e8ecff;--text-dim: #cbd5f6;--muted: #9ca9cf;--border: rgba(170,190,255,.08);--border-mid: rgba(170,190,255,.14);--border-strong:rgba(170,190,255,.22);--hairline: rgba(170,190,255,.05);--shadow-sm: 0 1px 4px rgba(0,0,12,.5);--shadow-md: 0 6px 22px rgba(0,0,12,.6);--shadow-lg: 0 20px 52px rgba(0,0,12,.7);--glow: radial-gradient(ellipse at 50% -10%, rgba(120,140,255,.16), transparent 65%);color-scheme:dark}[data-theme=obsidian]{--accent-h: 172;--accent-s: 66%;--accent-l: 58%;--bg: #000000;--bg-2: #050507;--surface: #0b0b0d;--surface-2: #111115;--surface-hov: #17171d;--text: #e8eef0;--text-dim: #ccd5db;--muted: #9ea8b0;--border: rgba(255,255,255,.05);--border-mid: rgba(255,255,255,.1);--border-strong:rgba(255,255,255,.2);--hairline: rgba(255,255,255,.03);--shadow-sm: 0 1px 4px rgba(0,0,0,.65);--shadow-md: 0 6px 24px rgba(0,0,0,.7);--shadow-lg: 0 20px 60px rgba(0,0,0,.8);--glow: radial-gradient(ellipse at 50% 100%, hsl(var(--accent-h) var(--accent-s) 55% / .1), transparent 55%);color-scheme:dark}[data-theme=glass]{--accent-h: 280;--accent-s: 72%;--accent-l: 70%;--bg: #0b0b18;--bg-2: #131326;--surface: rgba(255,255,255,.055);--surface-2: rgba(255,255,255,.085);--surface-hov: rgba(255,255,255,.12);--text: #f4f4fa;--text-dim: #e4e7f4;--muted: #aeb6cf;--border: rgba(255,255,255,.14);--border-mid: rgba(255,255,255,.22);--border-strong:rgba(255,255,255,.34);--hairline: rgba(255,255,255,.07);--shadow-sm: 0 2px 10px rgba(0,0,0,.4);--shadow-md: 0 8px 26px rgba(0,0,0,.55);--shadow-lg: 0 24px 60px rgba(0,0,0,.65);--glow: radial-gradient(ellipse at 20% 0%, hsl(var(--accent-h) 80% 70% / .3), transparent 45%), radial-gradient(ellipse at 80% 90%, hsl(200 80% 60% / .25), transparent 55%), radial-gradient(ellipse at 50% 50%, hsl(320 70% 60% / .12), transparent 60%);color-scheme:dark}[data-theme=glass] body{background:var(--bg)}[data-theme=light]{--bg: #ffffff;--bg-2: #f6f7fb;--surface: #f6f7fb;--surface-2: #eceef5;--surface-hov: #e0e3ed;--text: #17181c;--text-dim: #4a4c5a;--muted: #7a7c8c;--border: rgba(0,0,0,.09);--border-mid: rgba(0,0,0,.14);--border-strong:rgba(0,0,0,.22);--hairline: rgba(0,0,0,.04);--shadow-sm: 0 1px 3px rgba(20,20,30,.06);--shadow-md: 0 4px 14px rgba(20,20,30,.08);--shadow-lg: 0 10px 30px rgba(20,20,30,.14);--glow: radial-gradient(ellipse at 50% -10%, hsl(var(--accent-h) var(--accent-s) var(--accent-l) / .08), transparent 60%);--char-correct: #16a34a;--char-wrong: #dc2626;color-scheme:light}[data-theme=paper]{--accent-h: 22;--accent-s: 82%;--accent-l: 52%;--bg: #f7f3e9;--bg-2: #efe7d2;--surface: #ffffff;--surface-2: #f2e9d5;--surface-hov: #eadfbf;--text: #2a2621;--text-dim: #5a5149;--muted: #887e6f;--border: rgba(70,50,20,.12);--border-mid: rgba(70,50,20,.2);--border-strong:rgba(70,50,20,.32);--hairline: rgba(70,50,20,.06);--shadow-sm: 0 1px 3px rgba(80,60,30,.07);--shadow-md: 0 4px 14px rgba(80,60,30,.1);--shadow-lg: 0 10px 30px rgba(80,60,30,.15);--glow: none;--char-correct: #15803d;--char-wrong: #b91c1c;color-scheme:light}body.dark-mode{color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-body);font-weight:400;font-size:var(--fs-md);line-height:1.55;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;position:relative}body:before{content:"";position:fixed;inset:0;background:var(--glow);pointer-events:none;z-index:0}body>*{position:relative;z-index:1}button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}input,select,textarea{font:inherit;color:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}kbd{font-family:var(--font-mono);font-size:.78em;font-weight:600;background:var(--surface);border:1px solid var(--border);border-bottom-width:2px;padding:1px 6px;border-radius:var(--r-sm);color:var(--text-dim)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}::selection{background:var(--accent-soft);color:var(--text)}.page{display:grid;grid-template-columns:minmax(0,120px) minmax(0,1fr) minmax(0,120px);gap:var(--s-5);max-width:var(--col-wide);margin:0 auto;padding:var(--s-4) var(--s-5)}.page>.sidebar-ad{min-width:0}.wrap{grid-column:2;width:100%;max-width:var(--col-narrow);margin:0 auto;min-width:0;display:flex;flex-direction:column}.typing-zone{min-height:72vh;display:flex;flex-direction:column;justify-content:flex-start}.sidebar-ad{position:sticky;top:var(--s-5);height:fit-content;opacity:.92}.sidebar-ad.left{grid-column:1}.sidebar-ad.right{grid-column:3}.sidebar-ad ins{display:block;min-width:120px;min-height:600px;background:transparent!important}.sidebar-ad:not(:has(ins[data-ad-status=filled])){opacity:0;pointer-events:none}.adsbygoogle:not([data-ad-status=filled]){background:transparent!important}.bottom-ad-mobile{display:none;margin:var(--s-5) 0;text-align:center;min-height:100px}.topnav{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) 0;border-bottom:1px solid var(--hairline);margin-bottom:var(--s-5)}.topnav-brand{display:inline-flex;align-items:center;gap:6px;font-weight:800;font-size:var(--fs-lg);letter-spacing:-.02em;cursor:pointer;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;flex-shrink:0;margin-right:var(--s-2)}.topnav-brand:before{content:"⚡";-webkit-text-fill-color:initial;color:var(--accent);margin-right:2px}.topnav-left{display:flex;align-items:center;gap:2px}.topnav-right{display:flex;align-items:center;gap:4px;margin-left:auto}.topnav-tools,.topnav-utils{display:none}.nav-btn--primary{background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent)!important}.nav-btn--primary:hover{background:var(--accent);color:#fff!important;border-color:transparent}.nav-btn-chev{width:12px;height:12px;opacity:.65;transition:transform var(--tr-fast)}.nav-btn[aria-expanded=true] .nav-btn-chev{transform:rotate(180deg)}.nav-popover--profile{min-width:220px}.profile-item{display:flex;align-items:center;gap:var(--s-3);width:100%;padding:9px var(--s-3);border-radius:var(--r-md);text-align:left;transition:background var(--tr-fast)}.profile-item:hover{background:var(--surface-2)}.profile-item i,.profile-item .tf-lucide{width:16px;height:16px;color:var(--accent);flex-shrink:0}.profile-item--minor{opacity:.75}.profile-item--minor:hover{opacity:1}.profile-item-text{display:flex;flex-direction:column;gap:1px;min-width:0}.pit-name{font-size:var(--fs-sm);font-weight:700;color:var(--text);line-height:1.2}.pit-sub{font-size:var(--fs-2xs);color:var(--muted);font-weight:500}.pit-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:var(--r-full);background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent);font-size:var(--fs-2xs);font-weight:800;letter-spacing:.04em;text-transform:uppercase;align-self:flex-start}.profile-divider{height:1px;background:var(--hairline);margin:4px calc(-1 * var(--s-3))}.pref-select{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:var(--fs-xs);font-weight:600;padding:4px 8px;cursor:pointer;min-width:130px}.pref-select:focus{outline:none;border-color:var(--accent)}.settings-row-sep{width:1px;height:18px;background:var(--hairline);flex-shrink:0;margin:0 2px}.nav-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 11px;border-radius:var(--r-md);color:var(--text-dim);font-size:var(--fs-xs);font-weight:600;transition:background var(--tr-fast),color var(--tr-fast);white-space:nowrap}.nav-btn:hover{background:var(--surface);color:var(--text)}.nav-btn .nav-btn-icon{display:inline-flex;width:1em;height:1em;opacity:.75}.nav-btn .tf-lucide{width:1em;height:1em}.nav-btn.icon-only{padding:7px;gap:0;width:34px;height:34px;justify-content:center}.nav-popover-wrap{position:relative}.nav-popover{position:absolute;top:calc(100% + 6px);right:0;z-index:80;min-width:220px;padding:var(--s-3);background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);display:none}.nav-popover.open{display:block}.nav-popover--wide{min-width:320px;max-width:420px}[data-theme=glass] .nav-popover{backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);background:#14141ea6}.popover-title{font-size:var(--fs-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:var(--s-2)}.popover-row{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);padding:6px 2px}.popover-row+.popover-row{border-top:1px solid var(--hairline)}.popover-row-label{font-size:var(--fs-sm);color:var(--text);font-weight:600}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.theme-swatch{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);text-align:left;transition:border-color var(--tr-fast),background var(--tr-fast)}.theme-swatch:hover{border-color:var(--border-mid);background:var(--surface-hov)}.theme-swatch.active{border-color:var(--accent);background:var(--accent-soft)}.theme-swatch-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0;border:1px solid rgba(255,255,255,.15)}.theme-swatch-name{font-size:var(--fs-sm);font-weight:700;color:var(--text)}.modes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.mode-card{display:flex;flex-direction:column;align-items:flex-start;gap:3px;padding:11px 13px;background:var(--surface);border:1.5px solid var(--border-mid);border-radius:var(--r-md);text-align:left;transition:border-color var(--tr-fast),background var(--tr-fast),transform var(--tr-fast),box-shadow var(--tr-fast)}.mode-card:hover{border-color:var(--accent-border);background:var(--surface-2);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.mode-card.active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 18%,transparent)}.mode-card i,.mode-card .tf-lucide{width:20px;height:20px;color:var(--accent);margin-bottom:4px}.mode-card .mc-name{font-size:var(--fs-sm);font-weight:800;color:var(--text);line-height:1.15}.mode-card .mc-sub{font-size:var(--fs-2xs);color:var(--text-dim);font-weight:500;line-height:1.35}.seg-ctl{display:inline-flex;padding:2px;gap:0;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md)}.seg-ctl .seg-btn{padding:4px 8px;border-radius:var(--r-sm);font-size:var(--fs-2xs);font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;transition:color var(--tr-fast),background var(--tr-fast);min-width:28px}.seg-ctl .seg-btn:hover{color:var(--text)}.seg-ctl .seg-btn.active{background:var(--grad);color:#fff}.active-mode-tag{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--r-md);background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--text);font-weight:700;font-size:var(--fs-sm);cursor:pointer;transition:background var(--tr-fast),border-color var(--tr-fast)}.active-mode-tag:hover{background:var(--surface-hov)}.active-mode-tag i,.active-mode-tag .tf-lucide{width:14px;height:14px;color:var(--accent)}.active-mode-tag .chev{opacity:.65}.theme-dot-dark{background:linear-gradient(135deg,#101016 55%,#818cf8)}.theme-dot-midnight{background:linear-gradient(135deg,#0a0e23 55%,#6080ff)}.theme-dot-obsidian{background:linear-gradient(135deg,#000 55%,#4fd1c5)}.theme-dot-glass{background:linear-gradient(135deg,#fff3 55%,#c77dff);backdrop-filter:blur(6px)}.theme-dot-light{background:linear-gradient(135deg,#eceef5 55%,#818cf8)}.theme-dot-paper{background:linear-gradient(135deg,#f2e9d5 55%,#e08f3b)}.switch{position:relative;display:inline-block;width:34px;height:19px;flex-shrink:0}.switch input{opacity:0;width:0;height:0;position:absolute}.switch-slider{position:absolute;inset:0;background:var(--surface-2);border:1px solid var(--border-mid);border-radius:var(--r-full);transition:background var(--tr-fast),border-color var(--tr-fast);cursor:pointer}.switch-slider:before{content:"";position:absolute;top:2px;left:2px;width:13px;height:13px;background:var(--text);border-radius:50%;transition:transform var(--tr-base)}.switch input:checked+.switch-slider{background:var(--grad);border-color:transparent}.switch input:checked+.switch-slider:before{transform:translate(15px);background:#fff}.settings-row{display:flex;align-items:center;gap:var(--s-3);padding:6px var(--s-3);margin-bottom:var(--s-3);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);flex-wrap:wrap}[data-theme=glass] .settings-row{backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.settings-row>*{min-width:0}.settings-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:var(--r-md);font-size:var(--fs-xs);font-weight:600;color:var(--text-dim);transition:color var(--tr-fast),background var(--tr-fast)}.settings-chip:hover{color:var(--text);background:var(--surface-2)}.lang-select{appearance:none;background:transparent;color:var(--text);font-weight:600;font-size:var(--fs-sm);padding:6px 22px 6px 10px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 12px) calc(50% - 2px),calc(100% - 7px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}.lang-select:hover{background-color:var(--surface-2)}.lang-select:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.lang-select option{background:var(--surface);color:var(--text)}.mode-rail{display:flex;align-items:center;gap:2px;flex:1;justify-content:center;flex-wrap:wrap;margin:0 var(--s-2)}.mode-rail .mode-chip{padding:5px 10px;border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:600;color:var(--text-dim);transition:color var(--tr-fast),background var(--tr-fast);white-space:nowrap}.mode-rail .mode-chip:hover{color:var(--text);background:var(--surface-2)}.mode-rail .mode-chip.active-nav{color:var(--text);background:var(--accent-soft);box-shadow:inset 0 -2px 0 var(--accent)}.mode-rail .sep{width:1px;height:14px;background:var(--border);margin:0 2px}.diff-group{display:flex;gap:0;padding:2px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md)}.diff-group .sel-btn{padding:4px 10px;border-radius:var(--r-sm);font-size:var(--fs-2xs);font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;transition:color var(--tr-fast),background var(--tr-fast)}.diff-group .sel-btn:hover{color:var(--text)}.diff-group .sel-btn.active{background:var(--grad);color:#fff}.settings-spacer{flex:1;min-width:0}.settings-timer{font-variant-numeric:tabular-nums;font-weight:700;font-size:var(--fs-sm);color:var(--text);letter-spacing:.04em}.icon-btn{width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-md);color:var(--text-dim);transition:color var(--tr-fast),background var(--tr-fast)}.icon-btn:hover{color:var(--text);background:var(--surface-2)}.icon-btn .tf-lucide{width:16px;height:16px}.session-meta{display:inline-flex;align-items:center;gap:var(--s-2);flex-wrap:wrap}.session-meta-item{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-2xs);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.session-meta-lbl{white-space:nowrap}.session-select{appearance:none;padding:4px 22px 4px 8px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);color:var(--text);font-size:var(--fs-xs);font-weight:600;cursor:pointer;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 8px) 50%,calc(100% - 4px) 50%;background-size:4px 4px,4px 4px;background-repeat:no-repeat}.stats-strip{display:flex;align-items:center;justify-content:center;gap:var(--s-4);padding:var(--s-2) var(--s-3);margin-bottom:var(--s-1);min-height:44px;flex-wrap:wrap}.stat-card{display:inline-flex;align-items:baseline;gap:6px;padding:4px 8px;border-radius:var(--r-md);background:transparent}.stat-card .stat-label{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-2xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.stat-card .stat-label i,.stat-card .stat-label .tf-lucide{width:12px;height:12px;color:var(--accent);opacity:.9}.stat-card .stat-value{font-variant-numeric:tabular-nums;font-size:var(--fs-xl);font-weight:800;color:var(--text);line-height:1}#statBest .stat-value,#statWpm .stat-value{color:var(--accent)}.progress-bar-container{width:100%;height:3px;background:var(--border);border-radius:var(--r-full);overflow:hidden;margin-bottom:var(--s-3)}.progress-bar{height:100%;background:var(--grad);transition:width 1s linear}.words-card{position:relative;background:transparent;border:1px solid transparent;border-radius:var(--r-xl);padding:var(--s-5) var(--s-2);margin-bottom:var(--s-1);overflow:visible;cursor:text;transition:background var(--tr-base),border-color var(--tr-base)}.words-card.typing-active{border-color:transparent}.words-card-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;background:transparent;color:var(--text-dim);font-size:var(--fs-md);letter-spacing:.02em;border-radius:inherit;transition:opacity var(--tr-base);z-index:5}.words-card-hint.hidden{display:none}body.input-box-on .words-card{background:var(--surface);border-color:var(--border);padding:var(--s-6) var(--s-5)}body.input-box-on .words-card.typing-active{border-color:var(--accent-border)}[data-theme=glass] body.input-box-on .words-card{backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border-color:var(--border-mid)}#words{user-select:none;font-family:var(--reader-font);font-size:var(--fs-words);line-height:var(--lh-words);letter-spacing:.01em;font-weight:500;color:var(--muted);height:calc(var(--fs-words) * var(--lh-words) * var(--reader-lines));min-height:calc(var(--fs-words) * var(--lh-words) * 1);overflow:hidden;transition:height .16s ease}body[data-size=sm]{--fs-words: 1.25rem;--lh-words: 1.5}body[data-size=md]{--fs-words: clamp(1.45rem, 2.4vw, 1.9rem);--lh-words: 1.55}body[data-size=lg]{--fs-words: clamp(1.75rem, 2.8vw, 2.25rem);--lh-words: 1.6}body[data-size=xl]{--fs-words: clamp(2.1rem, 3.2vw, 2.75rem);--lh-words: 1.6}body[data-reader-font=sans]{--reader-font: "Lexend", "Inter", system-ui, -apple-system, sans-serif}body[data-reader-font=serif]{--reader-font: "Iowan Old Style", "Palatino Linotype", Georgia, "Times New Roman", serif}body[data-reader-font=mono]{--reader-font: "JetBrains Mono", "Fira Code", "SF Mono", Menlo, Consolas, monospace}body[data-reader-font=dyslexic]{--reader-font: "Lexend", "Comic Neue", system-ui, sans-serif;letter-spacing:.03em}.live-wpm-float{position:absolute;transform:translate(-50%,-160%);padding:2px 6px;border-radius:var(--r-sm);background:var(--surface-2);color:var(--text-dim);font-size:var(--fs-xs);font-weight:600;letter-spacing:.02em;pointer-events:none;white-space:nowrap;display:inline-flex;align-items:baseline;gap:4px;opacity:0;transition:opacity .25s ease,transform .16s ease;z-index:40;visibility:hidden;min-width:auto;justify-content:center;border:1px solid var(--border-mid)}.live-wpm-float.visible{opacity:.85;visibility:visible;transform:translate(-50%,-180%)}.live-wpm-float small{display:none}.live-wpm-float:after{display:none}[data-theme=light] .live-wpm-float,[data-theme=paper] .live-wpm-float{color:color-mix(in srgb,var(--accent) 75%,#111);text-shadow:0 1px 2px rgba(255,255,255,.75)}.char{display:inline}.char--correct{color:var(--char-correct, #22c55e)}.char--wrong{color:var(--char-wrong, #ef4444);background:#ef444426;border-radius:2px}.char--pending{color:var(--muted)}.char--cursor{position:relative;color:var(--text)}.char--cursor:before{display:none}.char--overflow{color:#fff;background:var(--char-wrong, #ef4444);border-radius:2px;opacity:.9}[data-theme=light] .char--overflow,[data-theme=paper] .char--overflow{color:#fff;background:var(--char-wrong);opacity:1}.word.current{background:transparent!important;box-shadow:none!important}.word-line--active .word{color:var(--muted)}.word-line{display:flex;flex-wrap:nowrap;overflow:hidden;gap:6px}.word{padding:1px 2px;border-radius:2px;flex-shrink:0;color:var(--muted)}.word.current{background:transparent;box-shadow:none;color:var(--muted)}.word.done{color:var(--muted)}.word-line--active .word{opacity:1}.word-line--next .word{opacity:.78}.word-line--upcoming .word{opacity:.58}.ctx-tip-root{min-height:0}.ctx-tip-open{margin:var(--s-2) 0 var(--s-3)}.ctx-tip{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s-2);padding:var(--s-3) var(--s-4);background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:var(--r-lg);font-size:var(--fs-sm);color:var(--text);max-width:100%}.ctx-tip-dismiss{flex-shrink:0;padding:6px 14px;border-radius:var(--r-md);border:1px solid var(--border-mid);background:var(--surface);color:var(--text);font-weight:700;font-size:var(--fs-xs);cursor:pointer}.ctx-tip-dismiss:hover{background:var(--surface-2)}.input-container{margin-bottom:var(--s-2)}.input-wrapper{display:flex;gap:var(--s-2);align-items:center;justify-content:center}#typeInput{position:fixed;top:-9999px;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none;border:none;padding:0;margin:0;background:transparent;color:transparent}.btn-restart{display:inline-flex;align-items:center;gap:8px;min-height:40px;padding:0 16px;border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:700;background:var(--surface-2);color:var(--text);border:1px solid var(--border-mid);transition:background var(--tr-fast),border-color var(--tr-fast);white-space:nowrap}.btn-restart:hover{background:var(--surface-hov);border-color:var(--accent);color:var(--accent)}.btn-restart:active{transform:scale(.98)}.btn-restart-glyph{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em;font-size:1rem;line-height:1}.hint{text-align:center;color:var(--muted);font-size:var(--fs-xs);margin-top:6px}.results-card{background:var(--surface);border:1px solid var(--accent-border);border-radius:var(--r-xl);padding:var(--s-5);margin-bottom:var(--s-3);scroll-margin-top:var(--s-3)}[data-theme=glass] .results-card{backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.results-title{font-size:var(--fs-sm);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:var(--s-3)}.results-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--s-3);margin-bottom:var(--s-3)}.result-item{padding:var(--s-3);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);text-align:left}.result-label{font-size:var(--fs-2xs);font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.result-value{font-variant-numeric:tabular-nums;font-size:var(--fs-2xl);font-weight:800;color:var(--accent);line-height:1.1}.result-value-small{font-size:var(--fs-md);font-weight:700;color:var(--text);display:flex;gap:6px;flex-wrap:wrap}.result-sublabel{font-size:var(--fs-2xs);color:var(--muted);margin-top:2px}.keystroke-correct,.word-correct{color:var(--ok)}.keystroke-incorrect,.word-incorrect{color:var(--err)}.results-actions{display:flex;justify-content:flex-end;gap:var(--s-2);margin-top:var(--s-3)}.btn-share{padding:8px 16px;border-radius:var(--r-md);font-size:var(--fs-xs);font-weight:700;background:var(--surface-2);color:var(--text);border:1px solid var(--border-mid);transition:background var(--tr-fast),border-color var(--tr-fast)}.btn-share:hover{background:var(--surface-hov);border-color:var(--accent);color:var(--accent)}.loading-indicator{padding:var(--s-6);text-align:center}.loading-spinner{width:28px;height:28px;border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;margin:0 auto var(--s-3);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.results-ad-slot.tf-ad-results{min-height:90px;margin-top:var(--s-4);border-radius:var(--r-md);border:1px dashed var(--border);background:var(--hairline)}.welcome-banner{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-3);background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:var(--r-md);margin-bottom:var(--s-3);font-size:var(--fs-xs);color:var(--text)}.streak-bar{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#fbbf2414;border:1px solid rgba(251,191,36,.2);border-radius:var(--r-full);cursor:pointer;transition:background var(--tr-fast),border-color var(--tr-fast)}.streak-bar:hover{background:#fbbf2424;border-color:#fbbf2459}.streak-flame{display:inline-flex}.streak-flame-icon{width:14px;height:14px;color:var(--warn)}.streak-info{display:inline-flex;gap:4px;align-items:baseline}.streak-count{font-size:var(--fs-xs);font-weight:800;color:var(--warn);font-variant-numeric:tabular-nums}.streak-label{font-size:var(--fs-2xs);color:var(--muted)}.sd-banner,.mode-banner{display:flex;justify-content:center;align-items:center;gap:6px;text-align:center;padding:6px var(--s-3);border-radius:var(--r-md);margin-bottom:var(--s-3);font-weight:700;font-size:var(--fs-xs)}.sd-banner .tf-lucide,.mode-banner .tf-lucide{width:14px;height:14px}.sd-banner{background:#f8717114;border:1px solid rgba(248,113,113,.2);color:var(--err)}.ghost-banner{background:var(--accent-soft);border:1px solid var(--accent-border);color:var(--accent)}.memory-banner{background:#fbbf2414;border:1px solid rgba(251,191,36,.2);color:var(--warn)}.zen-message{text-align:center;color:var(--muted);font-size:var(--fs-sm);font-style:italic;margin-bottom:var(--s-3)}.ghost-track{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-2) var(--s-3);margin-bottom:var(--s-3)}.track-header{display:flex;justify-content:space-between;font-size:var(--fs-xs);margin-bottom:4px}.track-header .label{color:var(--muted)}.track-header .pb{color:var(--accent);font-weight:700}.track-bar{position:relative;height:24px;background:var(--bg-2);border-radius:var(--r-sm);overflow:hidden}.track-indicator{position:absolute;top:50%;transform:translateY(-50%);font-size:.95rem;transition:left .15s linear;z-index:2}.track-indicator.ghost-ind{z-index:1;opacity:.5}.track-finish{position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:.8rem}.marathon-controls{display:flex;gap:var(--s-2);align-items:center;flex-wrap:wrap;margin-bottom:var(--s-3)}.marathon-controls select{padding:6px 10px;border-radius:var(--r-md);border:1px solid var(--border-mid);background:var(--surface);color:var(--text);font-size:var(--fs-xs);font-weight:600;cursor:pointer}.marathon-progress{margin-bottom:var(--s-3);display:flex;align-items:center;gap:var(--s-2)}.marathon-bar{flex:1;height:4px;background:var(--border);border-radius:var(--r-full);overflow:hidden}.marathon-fill{height:100%;background:var(--grad);transition:width .3s}.marathon-pct{font-size:var(--fs-xs);font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}#fallingCanvas{width:100%;border-radius:var(--r-lg);background:var(--surface);border:1px solid var(--border);display:block;margin-bottom:var(--s-3)}.lives-display{display:flex;gap:4px;justify-content:center;margin-bottom:var(--s-2);font-size:1.1rem}.lives-display .heart.lost{opacity:.16}.bomb-area{margin-bottom:var(--s-3)}.bomb-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4);text-align:center;overflow:hidden}.bomb-header{display:flex;justify-content:center;gap:var(--s-5);margin-bottom:var(--s-4);flex-wrap:wrap}.bomb-stat{text-align:center}.bomb-stat-label{display:block;font-size:var(--fs-2xs);text-transform:uppercase;color:var(--text-dim);font-weight:800;letter-spacing:.06em}.bomb-stat-value{font-size:var(--fs-xl);font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums}.bomb-visual{display:flex;align-items:center;justify-content:center;gap:var(--s-3);margin-bottom:var(--s-3);flex-wrap:wrap}.bomb-fuse-track{flex:1;max-width:240px;height:5px;background:var(--border);border-radius:var(--r-full);overflow:hidden}.bomb-fuse{height:100%;width:100%;background:linear-gradient(90deg,#f87171,#fbbf24,#34d399)}.bomb-emoji{font-size:2.4rem}.bomb-emoji.exploding{animation:explode .5s ease-out forwards}@keyframes explode{0%{transform:scale(1)}40%{transform:scale(2.4)}to{transform:scale(3);opacity:0}}.bomb-timer{font-size:var(--fs-xl);font-weight:900;color:var(--warn);min-width:52px;font-variant-numeric:tabular-nums}.bomb-timer.bomb-warning{color:#f59e0b;text-shadow:0 0 10px rgba(245,158,11,.35)}.bomb-timer.bomb-critical{color:var(--err);text-shadow:0 0 12px rgba(248,113,113,.45);animation:bombTimerPulse .45s ease-in-out infinite alternate}.bomb-fuse.bomb-fuse-critical{filter:saturate(130%) brightness(1.15)}@keyframes bombTimerPulse{0%{transform:scale(1)}to{transform:scale(1.08)}}.bomb-word{display:inline-block;min-width:160px;padding:12px var(--s-4);border-radius:var(--r-md);background:color-mix(in srgb,var(--accent-soft) 55%,var(--surface));border:2px solid var(--accent);font-size:var(--fs-2xl);font-weight:800;letter-spacing:.06em;color:var(--text);text-shadow:0 1px 0 rgba(0,0,0,.18)}.bomb-word.bomb-wrong{border-color:var(--err);background:color-mix(in srgb,var(--err) 18%,var(--surface))}.bomb-char{display:inline}.bomb-char--ok{color:var(--char-correct, var(--ok))}.bomb-char--bad{color:var(--char-wrong, var(--err));background:color-mix(in srgb,var(--char-wrong, var(--err)) 22%,transparent);border-radius:2px}.bomb-char--pending{color:var(--text-dim)}.bomb-char--cursor{position:relative;color:var(--text)}.bomb-char--cursor:before{content:"";position:absolute;left:-1px;top:50%;transform:translateY(-50%);width:2px;height:1.05em;background:var(--accent);border-radius:1px}.bomb-char--overflow{color:#fff;background:var(--char-wrong, var(--err));border-radius:2px}.bomb-hint{font-size:var(--fs-xs);color:var(--text-dim);margin-top:var(--s-3);font-weight:600}.bomb-lives{font-size:1rem}.musical-area{margin-bottom:var(--s-3)}.musical-container{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4)}.musical-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--s-3)}.musical-melody-name{font-size:var(--fs-sm);font-weight:800;color:var(--accent);background:color-mix(in srgb,var(--accent-soft) 48%,var(--surface));border:1px solid var(--accent-border);padding:3px 10px;border-radius:var(--r-sm)}.musical-score-display{font-size:var(--fs-sm);color:var(--text-dim);font-weight:700}.musical-notes-track{display:flex;gap:4px;padding:var(--s-3);background:var(--bg-2);border:1px solid var(--border-mid);border-radius:var(--r-md);margin-bottom:var(--s-3);min-height:48px;align-items:center;flex-wrap:wrap}.musical-note{padding:5px 10px;border-radius:var(--r-sm);font-weight:700;font-size:var(--fs-sm);background:var(--surface);color:var(--text-dim);border:1px solid var(--border-mid);flex-shrink:0}.musical-note.current-note{background:var(--grad);color:#fff}.musical-note.played{color:var(--char-correct, var(--ok));border-color:color-mix(in srgb,var(--char-correct, var(--ok)) 40%,var(--border));opacity:.85}.musical-keyboard{display:flex;flex-direction:column;gap:4px;align-items:center}.musical-key-row{display:flex;gap:3px}.m-key{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--r-sm);background:var(--bg-2);border:1px solid var(--border-mid);font-weight:700;font-size:var(--fs-sm);color:var(--text)}.m-key small{font-size:.52rem;color:var(--text-dim);font-weight:700}.m-key.active{background:var(--grad);color:#fff}body.memory-active .word.mem-1{opacity:.4}body.memory-active .word.mem-2{opacity:.18}body.memory-active .word.mem-3{opacity:.06}body.memory-active .word.mem-hidden{opacity:0}.practice-banner{margin:var(--s-2) 0 var(--s-3);padding:var(--s-2) var(--s-3);border-radius:var(--r-md);background:var(--accent-soft);border:1px solid var(--accent-border)}.practice-banner.hidden{display:none}.practice-banner-inner{display:flex;flex-wrap:wrap;align-items:center;gap:var(--s-2);justify-content:center}.practice-banner-label{font-size:var(--fs-2xs);font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--accent)}.practice-banner-keys{font-size:var(--fs-xs);color:var(--text-dim);flex:1;min-width:160px;text-align:center}.practice-banner-exit{padding:5px 12px;border-radius:var(--r-sm);border:1px solid var(--border-mid);background:var(--surface);color:var(--text);font-size:var(--fs-2xs);font-weight:700}.practice-banner-exit:hover{border-color:var(--accent);color:var(--accent)}.panel-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:var(--s-3);background:#040408b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.panel{background:var(--surface);border:1px solid var(--border-mid);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);max-width:720px;width:100%;max-height:88vh;overflow-y:auto;padding:var(--s-5);position:relative}[data-theme=glass] .panel{background:#14141ebf;backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur)}.panel-close{position:absolute;top:8px;right:10px;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;color:var(--muted);font-size:1.3rem;border-radius:var(--r-md);line-height:1}.panel-close:hover{color:var(--text);background:var(--surface-2)}.panel h2{font-size:var(--fs-xl);font-weight:800;margin-bottom:var(--s-3);color:var(--text);letter-spacing:-.01em}.panel h3{font-size:var(--fs-md);font-weight:700;margin:var(--s-4) 0 var(--s-2);color:var(--text)}.panel-stats-wide{max-width:860px}.tut-overlay{position:fixed;inset:0;z-index:200;background:#040408e6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--s-4)}.tut-card{max-width:620px;width:100%;text-align:center}.tut-close{position:fixed;top:var(--s-4);right:var(--s-4);color:var(--muted);font-size:1.5rem;z-index:201}.tut-close:hover{color:#fff}.tut-step-bar{display:flex;gap:4px;justify-content:center;margin-bottom:var(--s-5)}.tut-step-dot{width:38px;height:4px;border-radius:var(--r-full);background:#ffffff29}.tut-step-dot.active{background:var(--accent)}.tut-step-dot.done{background:var(--ok)}.tut-title{font-size:var(--fs-2xl);font-weight:900;color:#fff;margin-bottom:var(--s-2);letter-spacing:-.02em}.tut-body{font-size:var(--fs-md);color:#ffffffb8;line-height:1.65;margin-bottom:var(--s-4);max-width:500px;margin-left:auto;margin-right:auto}.tut-keyboard{display:flex;flex-direction:column;gap:5px;align-items:center;margin:var(--s-4) 0}.tut-kb-row{display:flex;gap:4px;justify-content:center}.tut-key{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--r-md);font-size:var(--fs-md);font-weight:700;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);color:#ffffff73;transition:all .2s}.tut-key.highlight{border-color:transparent;color:#fff;transform:scale(1.08)}.tut-key.pressed{background:#fff!important;color:#000!important;transform:scale(.92)}.tut-space{width:220px;font-size:var(--fs-xs)}.tut-finger-guide{margin:var(--s-4) 0 var(--s-3)}.tut-finger-guide-title{font-size:var(--fs-2xs);text-transform:uppercase;letter-spacing:.08em;color:#fff6;margin-bottom:var(--s-2)}.tut-finger-rows{display:flex;justify-content:center;gap:var(--s-5);flex-wrap:wrap}.tut-finger-hand{display:flex;flex-direction:column;align-items:center;gap:6px}.tut-finger-hand-label{font-size:var(--fs-2xs);font-weight:700;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.tut-finger-chips{display:flex;gap:5px}.tut-finger-chip{display:flex;flex-direction:column;align-items:center;gap:3px}.tut-finger-chip-dot{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.58rem;font-weight:800;color:#fff}.tut-finger-chip-label{font-size:.62rem;color:#ffffff8c;font-weight:600}.tut-finger-legend{font-size:var(--fs-2xs);margin-top:var(--s-2);display:flex;gap:var(--s-3);justify-content:center;flex-wrap:wrap;color:#fff9}.tut-practice{margin:var(--s-5) auto;max-width:500px}.tut-practice-label{font-size:var(--fs-xs);color:#ffffff80;margin-bottom:6px}.tut-practice-word{font-family:var(--font-mono);font-size:var(--fs-lg);font-weight:700;color:#fff;background:#ffffff0d;padding:14px var(--s-4);border-radius:var(--r-md);margin-bottom:10px;letter-spacing:.1em;border:1px solid rgba(255,255,255,.12);word-break:break-all}.tut-input{width:100%;padding:14px var(--s-4);border-radius:var(--r-md);border:2px solid rgba(255,255,255,.16);background:#ffffff0a;color:#fff;font-family:var(--font-mono);font-size:var(--fs-md);text-align:center}.tut-input:focus{outline:none;border-color:var(--accent)}.tut-success{color:var(--ok);font-weight:700;font-size:var(--fs-sm);margin-top:var(--s-2)}.tut-nav{display:flex;gap:var(--s-2);justify-content:center;margin-top:var(--s-4)}.tut-btn{padding:10px 22px;border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:700;transition:opacity var(--tr-fast)}.tut-btn-primary{background:var(--grad);color:#fff}.tut-btn-secondary{background:#ffffff14;color:#ffffffb3}.tut-btn:hover{opacity:.85}.streak-popup-overlay{position:fixed;inset:0;z-index:190;display:flex;align-items:center;justify-content:center;background:#040408cc;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.streak-popup{text-align:center;padding:var(--s-7) var(--s-5);max-width:380px;width:100%;background:var(--surface);border:1px solid var(--border-mid);border-radius:var(--r-2xl);box-shadow:var(--shadow-sm);position:relative}.streak-popup-close{position:absolute;top:8px;right:10px;color:var(--muted);font-size:1.2rem}.streak-popup-flame{font-size:4rem;margin-bottom:var(--s-2);display:block}.streak-popup-count{font-size:3rem;font-weight:900;color:var(--warn);margin-bottom:2px;font-variant-numeric:tabular-nums}.streak-popup-label{font-size:var(--fs-lg);font-weight:700;color:var(--text);margin-bottom:6px}.streak-popup-msg{font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--s-5)}.streak-popup-cta{background:var(--grad);color:#fff;padding:12px var(--s-6);border-radius:var(--r-md);font-weight:700;font-size:var(--fs-md)}.streak-popup-cta:hover{opacity:.9}.heatmap-legend{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:var(--s-3);line-height:1.5}.heatmap-board{margin-bottom:var(--s-2)}.kb-row{display:flex;justify-content:center;gap:4px;margin-bottom:4px;position:relative;flex-wrap:wrap}.kb-key{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:700;border:1px solid var(--border);text-transform:uppercase;position:relative}button.kb-key{color:var(--text);transition:transform .12s ease,filter .12s ease}.kb-key-interactive:hover{filter:brightness(1.08);transform:translateY(-1px)}.kb-key-interactive:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.kb-key-space-display{min-width:200px;flex:1;max-width:420px;text-transform:none;font-size:var(--fs-2xs);font-weight:600;color:var(--text-dim);padding:0 var(--s-3)}.kb-row-extra .kb-key{min-width:36px}.kb-key.space{width:220px}.kb-key[data-tooltip]:hover:after{content:attr(data-tooltip);position:absolute;bottom:110%;left:50%;transform:translate(-50%);background:var(--bg-2);color:var(--text);padding:3px 8px;border-radius:var(--r-sm);font-size:var(--fs-2xs);white-space:nowrap;z-index:10;border:1px solid var(--border);font-weight:400}.stat-rows{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:6px;margin:var(--s-3) 0}.stat-box{background:var(--bg-2);padding:var(--s-3);border-radius:var(--r-md);text-align:center;border:1px solid var(--border);position:relative}.stat-box .val{font-size:var(--fs-xl);font-weight:800;color:var(--accent);font-variant-numeric:tabular-nums}.stat-box .lbl{font-size:var(--fs-2xs);text-transform:uppercase;color:var(--muted);margin-top:2px;letter-spacing:.04em}.stat-box[data-info]{cursor:help}.stat-box[data-info]:hover:after{content:attr(data-info);position:absolute;bottom:110%;left:50%;transform:translate(-50%);background:var(--bg-2);color:var(--text);padding:4px 10px;border-radius:var(--r-sm);font-size:var(--fs-2xs);white-space:nowrap;z-index:10;border:1px solid var(--border)}.stats-heatmap-intro{font-size:var(--fs-xs);color:var(--text-dim);margin-bottom:var(--s-3);line-height:1.5}.stats-practice-actions{margin:var(--s-3) 0 var(--s-4);padding:var(--s-3);border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-2);text-align:center}.btn-improvement{padding:10px 22px;border-radius:var(--r-md);font-weight:800;font-size:var(--fs-sm);background:var(--grad);color:#fff}.btn-improvement:hover{opacity:.9}.stats-practice-hint{font-size:var(--fs-xs);color:var(--muted);margin-top:var(--s-2);line-height:1.5}.typing-tips-panel{font-size:var(--fs-sm);color:var(--text-dim);line-height:1.6}.typing-tips-panel .tips-heading{font-size:var(--fs-md);font-weight:700;color:var(--text);margin-bottom:var(--s-2)}.typing-tips-panel .tips-os-title{font-size:var(--fs-sm);font-weight:700;color:var(--text);margin:var(--s-3) 0 6px}.typing-tips-panel .tips-muted{font-size:var(--fs-sm);margin-bottom:var(--s-2)}.typing-tips-panel .tips-list{margin-left:20px;margin-bottom:var(--s-2)}.typing-tips-panel .tips-list li{margin-bottom:6px}.key-breakdown-scroll{max-height:240px;overflow-y:auto}.stats-tab-bar{display:flex;gap:2px;border-bottom:2px solid var(--border);margin:var(--s-3) 0 var(--s-4);overflow-x:auto;scrollbar-width:none}.stats-tab-bar::-webkit-scrollbar{display:none}.stats-tab{padding:8px var(--s-4);border:none;background:none;color:var(--muted);font-size:var(--fs-sm);font-weight:700;cursor:pointer;border-radius:var(--r-sm) var(--r-sm) 0 0;white-space:nowrap;transition:color var(--tr-fast);position:relative;bottom:-2px;border-bottom:2px solid transparent;letter-spacing:.01em}.stats-tab:hover{color:var(--text-dim)}.stats-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.stats-tab-pane{display:block}.stats-tab-pane.hidden{display:none}.stats-section{padding:var(--s-4) 0}.stats-section-header{display:flex;align-items:center;gap:var(--s-2);margin-bottom:var(--s-3)}.stats-section-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--accent-soft);border-radius:var(--r-md);flex-shrink:0}.stats-section-icon .tf-lucide{width:16px;height:16px;color:var(--accent)}.stats-section-title{font-size:var(--fs-md);font-weight:800;color:var(--text);letter-spacing:-.01em;margin:0}.stats-section-divider{height:1px;background:var(--border);margin:0 calc(var(--s-3) * -1)}.stats-subsection-title{font-size:var(--fs-sm);font-weight:700;color:var(--text-dim);margin:var(--s-4) 0 var(--s-2)}.heatmap-drill-banner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--s-2);background:var(--accent-glow, color-mix(in srgb, var(--accent) 12%, transparent));border:1px solid var(--accent-border);border-radius:var(--r-md);padding:var(--s-2) var(--s-3);margin-bottom:var(--s-3);font-size:var(--fs-sm);color:var(--text)}.heatmap-drill-banner button{padding:5px var(--s-3);border-radius:var(--r-sm);background:var(--accent);color:#fff;border:none;font-size:var(--fs-xs);font-weight:700;cursor:pointer;white-space:nowrap}.heatmap-drill-banner.hidden{display:none}@keyframes kb-key-pulse{0%,to{box-shadow:0 0 color-mix(in srgb,var(--err) 55%,transparent)}50%{box-shadow:0 0 0 6px transparent}}.kb-key-pulse{animation:kb-key-pulse 1.4s ease infinite;border-color:var(--err)!important}.heatmap-first-tip{background:var(--surface);border:1px solid var(--accent-border);border-radius:var(--r-md);padding:var(--s-2) var(--s-3);font-size:var(--fs-xs);color:var(--text-dim);text-align:center;margin-bottom:var(--s-3)}.trends-chart-block{margin-bottom:var(--s-5)}.trends-chart-label{font-size:var(--fs-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:var(--s-2)}.trends-canvas{display:block;width:100%;height:160px;border-radius:var(--r-md)}.trends-canvas--short{height:110px}.trends-empty{text-align:center;padding:var(--s-6) 0;color:var(--muted);font-size:var(--fs-sm)}.trends-empty.hidden{display:none}.stats-export-row{display:flex;gap:var(--s-2);justify-content:flex-end;padding-top:var(--s-4);margin-top:var(--s-4);border-top:1px solid var(--border)}.btn-export,.btn-clear-data{padding:7px var(--s-3);border-radius:var(--r-sm);font-size:var(--fs-xs);font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--bg-2);color:var(--text);transition:background var(--tr-fast)}.btn-export:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-clear-data{color:var(--err);border-color:var(--err)}.btn-clear-data:hover{background:var(--err);color:#fff}.hs-tabs{display:flex;gap:3px;margin-bottom:var(--s-3);flex-wrap:wrap}.hs-table{width:100%;border-collapse:collapse;margin-top:var(--s-2)}.hs-table th,.hs-table td{padding:7px var(--s-2);text-align:left;font-size:var(--fs-sm);border-bottom:1px solid var(--hairline)}.hs-table th{color:var(--muted);font-weight:700;text-transform:uppercase;font-size:var(--fs-2xs);letter-spacing:.05em}.hs-empty{text-align:center;padding:var(--s-5);color:var(--muted);font-size:var(--fs-sm)}.badges-summary{text-align:center;font-size:var(--fs-sm);color:var(--muted);margin-bottom:var(--s-3);font-weight:600}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:6px}.badge-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);padding:var(--s-3) var(--s-2);text-align:center}.badge-card.unlocked{border-color:var(--accent-border)}.badge-card.locked{opacity:.35}.badge-icon{font-size:1.5rem;margin-bottom:4px}.badge-icon-wrap{display:flex;align-items:center;justify-content:center;margin-bottom:var(--s-2);min-height:36px}.badge-lucide{width:34px!important;height:34px!important;stroke:var(--accent);color:var(--accent)}.badge-card.locked .badge-lucide{stroke:var(--muted);color:var(--muted)}.badge-name{font-size:var(--fs-xs);font-weight:700;color:var(--text);margin-bottom:2px}.badge-desc{font-size:var(--fs-2xs);color:var(--muted)}.badge-toast{position:fixed;bottom:var(--s-4);right:var(--s-4);z-index:210;background:var(--surface);border:1px solid var(--accent-border);border-radius:var(--r-md);padding:var(--s-2) var(--s-3);display:flex;gap:var(--s-2);align-items:center;box-shadow:var(--shadow-sm);transform:translate(120%);transition:transform .4s cubic-bezier(.4,0,.2,1);max-width:300px}.badge-toast.show{transform:translate(0)}.badge-toast-icon{font-size:1.6rem;flex-shrink:0}.badge-toast-icon-svg{flex-shrink:0;display:flex;align-items:center;justify-content:center}.badge-toast-icon-svg svg,.badge-toast-icon-svg .tf-lucide{width:30px;height:30px;stroke:var(--accent);color:var(--accent)}.badge-toast strong{color:var(--text);font-size:var(--fs-sm)}.badge-toast small{color:var(--muted);font-size:var(--fs-xs)}.lesson-card{display:flex;align-items:center;gap:var(--s-2);padding:var(--s-2) var(--s-3);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:5px}.lesson-card.completed{border-color:#34d39940}.lesson-num{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--grad);color:#fff;font-weight:800;font-size:var(--fs-sm);flex-shrink:0}.lesson-card.completed .lesson-num{background:var(--ok)}.lesson-info{flex:1;min-width:0}.lesson-name{font-weight:700;font-size:var(--fs-sm)}.lesson-desc{font-size:var(--fs-xs);color:var(--muted)}.lesson-stats{font-size:var(--fs-2xs);color:var(--accent);font-weight:600}.lesson-start{padding:6px 12px;border-radius:var(--r-sm);font-weight:700;font-size:var(--fs-xs);background:var(--grad);color:#fff}.lesson-words-area{display:flex;flex-wrap:wrap;gap:5px;padding:var(--s-3);background:var(--bg-2);border-radius:var(--r-md);margin-bottom:var(--s-2);min-height:50px;justify-content:center;border:1px solid var(--border)}.lesson-word{padding:3px 7px;border-radius:var(--r-xs);font-size:var(--fs-md);font-weight:600;color:var(--muted)}.lesson-word.current{background:var(--grad);color:#fff}.lesson-word.done{color:var(--ok)}.lesson-input{width:100%;padding:10px;border-radius:var(--r-md);border:2px solid var(--border-mid);background:var(--surface);color:var(--text);font-size:var(--fs-md);text-align:center}.lesson-input:focus{outline:none;border-color:var(--accent)}.lesson-result{text-align:center;margin-top:var(--s-2);padding:var(--s-2);background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:var(--r-sm);color:var(--ok);font-size:var(--fs-sm)}.a11y-options{display:flex;flex-direction:column;gap:var(--s-2)}.a11y-option{display:flex;justify-content:space-between;align-items:center;padding:var(--s-3);background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:600;color:var(--text);cursor:pointer}.a11y-option input{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}body.dyslexia-font,body.dyslexia-font *{font-family:Lexend,OpenDyslexic,sans-serif!important}body.large-text #words{font-size:1.85rem}body.large-text .word{padding:5px 8px}body.reduced-motion,body.reduced-motion *{animation-duration:0s!important;transition-duration:0s!important}.page-content{margin-top:var(--s-5);padding-top:var(--s-5);border-top:1px solid var(--hairline)}.pc-section{margin-bottom:var(--s-6)}.pc-section:last-child{margin-bottom:0}.pc-h2{font-size:var(--fs-xl);font-weight:800;color:var(--text);margin-bottom:var(--s-3);letter-spacing:-.01em}.pc-p{font-size:var(--fs-md);color:var(--text-dim);line-height:1.7;margin-bottom:var(--s-3)}.pc-how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s-3);margin-top:var(--s-3)}.pc-how-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:var(--s-4);display:flex;gap:var(--s-3);align-items:flex-start}.pc-how-num{width:28px;height:28px;background:var(--grad);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:var(--fs-xs);flex-shrink:0}.pc-how-text{font-size:var(--fs-sm);color:var(--text-dim);line-height:1.6}.pc-how-text strong{color:var(--text)}.pc-faq{display:flex;flex-direction:column;gap:6px;margin-top:var(--s-3)}.pc-faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}.pc-faq-item summary{padding:var(--s-3) var(--s-4);font-size:var(--fs-md);font-weight:600;color:var(--text);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between}.pc-faq-item summary::-webkit-details-marker{display:none}.pc-faq-item summary:after{content:"+";color:var(--muted);font-size:var(--fs-lg);font-weight:300;width:18px;text-align:center}.pc-faq-item[open] summary:after{content:"−"}.pc-faq-item p{padding:0 var(--s-4) var(--s-3);font-size:var(--fs-sm);color:var(--text-dim);line-height:1.7}.footer{margin-top:var(--s-7);padding:var(--s-4) 0 var(--s-3);border-top:1px solid var(--hairline);text-align:center;color:var(--muted);font-size:var(--fs-xs)}.footer-links{display:flex;gap:var(--s-4);justify-content:center;flex-wrap:wrap;margin-bottom:6px}.footer a{color:var(--text-dim);font-weight:600}.footer a:hover{color:var(--accent);text-decoration:none}.hidden{display:none!important}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.tf-lucide,.badge-lucide{width:1.15em;height:1.15em;stroke:currentColor;color:inherit;flex-shrink:0}.error-flash{animation:errorFlash .28s ease-out}@keyframes errorFlash{0%,to{box-shadow:0 0 0 0 transparent}30%{box-shadow:0 0 0 4px #f8717180,inset 0 0 20px #f8717114}70%{box-shadow:0 0 0 3px #f871714d,inset 0 0 12px #f871710d}}@media (max-width: 1200px){.page{grid-template-columns:1fr;padding:var(--s-3) var(--s-4)}.sidebar-ad{display:none}.wrap{grid-column:1}.typing-zone{min-height:64vh}.bottom-ad-mobile{display:block}}@media (max-width: 760px){.page{padding:var(--s-2) var(--s-3)}.topnav{flex-wrap:wrap;gap:var(--s-2);padding:var(--s-2) 0;margin-bottom:var(--s-3)}.topnav-brand{font-size:var(--fs-md)}.topnav-left{flex:1}.topnav-right{gap:2px}.nav-btn-label{display:none}.nav-btn--primary .nav-btn-label{display:inline}.nav-btn--primary{padding:7px 10px}.nav-btn-chev{display:none}.settings-row{flex-direction:column;align-items:stretch;gap:var(--s-2);padding:var(--s-2)}.lang-select{width:100%;text-align:left;background-position:calc(100% - 12px) calc(50% - 2px),calc(100% - 7px) calc(50% - 2px)}.settings-spacer{display:none}.mode-rail{width:100%;justify-content:flex-start;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;-webkit-overflow-scrolling:touch;margin:0}.mode-rail::-webkit-scrollbar{display:none}.mode-rail .mode-chip{flex:0 0 auto}.diff-group{align-self:flex-start}.settings-timer{align-self:flex-end;margin-left:0}.stats-strip{gap:var(--s-3);padding:var(--s-2) 0;flex-wrap:wrap;justify-content:center}.stat-card .stat-value{font-size:var(--fs-lg)}.stat-card .stat-label{font-size:var(--fs-2xs)}.words-card{padding:var(--s-4) var(--s-3)}#words{font-size:1.2rem;line-height:1.85}.btn-restart{padding:12px var(--s-4)}.results-grid{grid-template-columns:repeat(2,1fr)}.pc-how-grid{grid-template-columns:1fr}.pc-h2{font-size:var(--fs-lg)}.tut-key{width:38px;height:38px;font-size:var(--fs-sm)}.kb-key{width:30px;height:30px;font-size:.6rem}.panel{padding:var(--s-4) var(--s-3);max-height:92vh}.panel h2{font-size:var(--fs-xl)}.nav-popover{min-width:200px;right:0}.theme-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.topnav-brand{font-size:var(--fs-sm)}.topnav-brand:before{margin-right:0}.nav-btn{padding:6px 8px}.mode-rail .mode-chip{padding:5px 8px}.diff-btn{padding:5px 10px;font-size:var(--fs-2xs)}.stats-strip{gap:var(--s-2)}.stat-card{min-width:0}.bomb-header{gap:var(--s-3)}.streak-popup{padding:var(--s-5) var(--s-4)}.results-grid{grid-template-columns:1fr 1fr}.panel{padding:var(--s-3) var(--s-2)}.theme-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.smooth-caret{position:absolute;width:2px;height:1.5rem;background:var(--accent);border-radius:1px;transition:transform .1s cubic-bezier(.2,0,0,1);pointer-events:none;z-index:10;opacity:1}.smooth-caret.hidden{opacity:0}@keyframes caret-pulse{0%,to{opacity:1}50%{opacity:.3}}body.idle .smooth-caret{animation:caret-pulse 1.2s ease-in-out infinite}
