:root{--radius:14px;--font-display:"Space Grotesk",ui-sans-serif,system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;color-scheme:dark;--bg:oklch(0.15 0.0067 271);--panel:oklch(0.204 0.0129 264.2);--panel-2:oklch(0.234 0.0129 264.2);--line:oklch(0.284 0.0203 260.6);--line-2:oklch(0.334 0.0203 260.6);--text:oklch(0.957 0.0074 260.7);--muted:oklch(0.64 0.0259 256.1);--untyped:oklch(0.798 0.0259 256.1);--accent:oklch(0.812 0.1704 76.4);--accent-soft:oklch(0.912 0.1619 76.4);--accent-dim:oklch(0.812 0.1704 76.4/0.16);--accent-line:oklch(0.812 0.1704 76.4/0.4);--on-accent:oklch(0.2 0.05 76.4);--key-edge:oklch(0.154 0.0129 264.2);--hit:oklch(0.825 0.1361 155.8);--miss:oklch(0.712 0.1812 22.8);--slow-key-color:oklch(0.712 0.1812 22.8);--fast-key-color:oklch(0.825 0.1361 155.8);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.812 0.1704 76.4/0.1);--glow-2:oklch(0.825 0.1361 155.8/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=dracula]{color-scheme:dark;--bg:oklch(0.288 0.0221 277.5);--panel:oklch(0.34 0.0266 276);--panel-2:oklch(0.37 0.0266 276);--line:oklch(0.403 0.0322 277.8);--line-2:oklch(0.453 0.0322 277.8);--text:oklch(0.977 0.0079 106.5);--muted:oklch(0.56 0.0803 270.1);--untyped:oklch(0.769 0.0803 270.1);--accent:oklch(0.742 0.1485 301.9);--accent-soft:oklch(0.842 0.1411 301.9);--accent-dim:oklch(0.742 0.1485 301.9/0.16);--accent-line:oklch(0.742 0.1485 301.9/0.4);--on-accent:oklch(0.2 0.05 301.9);--key-edge:oklch(0.29 0.0266 276);--hit:oklch(0.871 0.2195 148);--miss:oklch(0.682 0.2063 24.4);--slow-key-color:oklch(0.682 0.2063 24.4);--fast-key-color:oklch(0.871 0.2195 148);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.742 0.1485 301.9/0.1);--glow-2:oklch(0.871 0.2195 148/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=tokyo-night]{color-scheme:dark;--bg:oklch(0.226 0.0214 280.5);--panel:oklch(0.282 0.0355 274.7);--panel-2:oklch(0.312 0.0355 274.7);--line:oklch(0.409 0.0546 274.3);--line-2:oklch(0.459 0.0546 274.3);--text:oklch(0.846 0.0611 274.8);--muted:oklch(0.496 0.0682 274.4);--untyped:oklch(0.671 0.0682 274.4);--accent:oklch(0.719 0.1322 264.2);--accent-soft:oklch(0.819 0.1256 264.2);--accent-dim:oklch(0.719 0.1322 264.2/0.16);--accent-line:oklch(0.719 0.1322 264.2/0.4);--on-accent:oklch(0.2 0.05 264.2);--key-edge:oklch(0.232 0.0355 274.7);--hit:oklch(0.795 0.1395 130.1);--miss:oklch(0.723 0.1589 10.3);--slow-key-color:oklch(0.723 0.1589 10.3);--fast-key-color:oklch(0.795 0.1395 130.1);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.719 0.1322 264.2/0.1);--glow-2:oklch(0.795 0.1395 130.1/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=nord]{color-scheme:dark;--bg:oklch(0.324 0.0229 264.2);--panel:oklch(0.379 0.029 266.5);--panel-2:oklch(0.409 0.029 266.5);--line:oklch(0.416 0.0324 264.1);--line-2:oklch(0.466 0.0324 264.1);--text:oklch(0.899 0.0164 262.7);--muted:oklch(0.564 0.0318 263.3);--untyped:oklch(0.732 0.0318 263.3);--accent:oklch(0.775 0.0622 217.5);--accent-soft:oklch(0.875 0.0591 217.5);--accent-dim:oklch(0.775 0.0622 217.5/0.16);--accent-line:oklch(0.775 0.0622 217.5/0.4);--on-accent:oklch(0.2 0.05 217.5);--key-edge:oklch(0.329 0.029 266.5);--hit:oklch(0.768 0.0749 131.1);--miss:oklch(0.606 0.1206 15.3);--slow-key-color:oklch(0.606 0.1206 15.3);--fast-key-color:oklch(0.768 0.0749 131.1);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.775 0.0622 217.5/0.1);--glow-2:oklch(0.768 0.0749 131.1/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=catppuccin-mocha]{color-scheme:dark;--bg:oklch(0.243 0.0304 283.9);--panel:oklch(0.293 0.0345 281.7);--panel-2:oklch(0.323 0.0345 281.7);--line:oklch(0.404 0.032 280.2);--line-2:oklch(0.454 0.032 280.2);--text:oklch(0.879 0.0426 272.3);--muted:oklch(0.618 0.0367 276);--untyped:oklch(0.748 0.0367 276);--accent:oklch(0.787 0.1187 304.8);--accent-soft:oklch(0.887 0.1127 304.8);--accent-dim:oklch(0.787 0.1187 304.8/0.16);--accent-line:oklch(0.787 0.1187 304.8/0.4);--on-accent:oklch(0.2 0.05 304.8);--key-edge:oklch(0.243 0.0345 281.7);--hit:oklch(0.858 0.1092 142.7);--miss:oklch(0.756 0.1297 2.8);--slow-key-color:oklch(0.756 0.1297 2.8);--fast-key-color:oklch(0.858 0.1092 142.7);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.787 0.1187 304.8/0.1);--glow-2:oklch(0.858 0.1092 142.7/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=one-dark]{color-scheme:dark;--bg:oklch(0.293 0.0157 264.3);--panel:oklch(0.332 0.0173 262.3);--panel-2:oklch(0.362 0.0173 262.3);--line:oklch(0.37 0.0153 259.8);--line-2:oklch(0.42 0.0153 259.8);--text:oklch(0.762 0.0202 263);--muted:oklch(0.498 0.0225 262.9);--untyped:oklch(0.63 0.0225 262.9);--accent:oklch(0.73 0.1213 245.3);--accent-soft:oklch(0.83 0.1152 245.3);--accent-dim:oklch(0.73 0.1213 245.3/0.16);--accent-line:oklch(0.73 0.1213 245.3/0.4);--on-accent:oklch(0.2 0.05 245.3);--key-edge:oklch(0.282 0.0173 262.3);--hit:oklch(0.768 0.1103 133);--miss:oklch(0.671 0.1448 17);--slow-key-color:oklch(0.671 0.1448 17);--fast-key-color:oklch(0.768 0.1103 133);--on-confidence:oklch(0.16 0.012 265);--glow-1:oklch(0.73 0.1213 245.3/0.1);--glow-2:oklch(0.768 0.1103 133/0.08);--grain-opacity:0.04;--board-shadow:0 18px 42px -26px rgba(0,0,0,.55),inset 0 1px 0 hsla(0,0%,100%,.04)}[data-theme=paper]{color-scheme:light;--bg:oklch(0.939 0.0282 86.6);--panel:oklch(0.968 0.0196 87.5);--panel-2:oklch(0.988 0.0196 87.5);--line:oklch(0.887 0.0367 87.8);--line-2:oklch(0.837 0.0367 87.8);--text:oklch(0.353 0.029 81.8);--muted:oklch(0.592 0.0426 83.7);--untyped:oklch(0.472 0.0426 83.7);--accent:oklch(0.619 0.1187 66.8);--accent-soft:oklch(0.539 0.1127 66.8);--accent-dim:oklch(0.619 0.1187 66.8/0.18);--accent-line:oklch(0.619 0.1187 66.8/0.4);--on-accent:oklch(0.985 0.012 66.8);--key-edge:oklch(0.918 0.0196 87.5);--hit:oklch(0.586 0.1215 132.8);--miss:oklch(0.578 0.1457 33.9);--slow-key-color:oklch(0.578 0.1457 33.9);--fast-key-color:oklch(0.586 0.1215 132.8);--on-confidence:oklch(0.99 0 0);--glow-1:oklch(0.619 0.1187 66.8/0.05);--glow-2:oklch(0.586 0.1215 132.8/0.04);--grain-opacity:0.02;--board-shadow:0 12px 28px -20px rgba(0,0,0,.13)}[data-theme=solarized-light]{color-scheme:light;--bg:oklch(0.974 0.0261 90.1);--panel:oklch(0.931 0.026 92.4);--panel-2:oklch(0.951 0.026 92.4);--line:oklch(0.863 0.0306 92.3);--line-2:oklch(0.813 0.0306 92.3);--text:oklch(0.309 0.0518 219.7);--muted:oklch(0.698 0.0159 196.8);--untyped:oklch(0.504 0.0159 196.8);--accent:oklch(0.615 0.1394 244.9);--accent-soft:oklch(0.535 0.1324 244.9);--accent-dim:oklch(0.615 0.1394 244.9/0.18);--accent-line:oklch(0.615 0.1394 244.9/0.4);--on-accent:oklch(0.985 0.012 244.9);--key-edge:oklch(0.881 0.026 92.4);--hit:oklch(0.644 0.1508 118.6);--miss:oklch(0.586 0.2064 27.1);--slow-key-color:oklch(0.586 0.2064 27.1);--fast-key-color:oklch(0.644 0.1508 118.6);--on-confidence:oklch(0.99 0 0);--glow-1:oklch(0.615 0.1394 244.9/0.05);--glow-2:oklch(0.644 0.1508 118.6/0.04);--grain-opacity:0.02;--board-shadow:0 12px 28px -20px rgba(0,0,0,.13)}[data-theme=github-light]{color-scheme:light;--bg:oklch(1 0 89.9);--panel:oklch(0.978 0.0034 247.9);--panel-2:oklch(0.998 0.0034 247.9);--line:oklch(0.876 0.0123 248);--line-2:oklch(0.826 0.0123 248);--text:oklch(0.254 0.0111 254);--muted:oklch(0.531 0.0172 251.3);--untyped:oklch(0.393 0.0172 251.3);--accent:oklch(0.54 0.1906 257.5);--accent-soft:oklch(0.46 0.1811 257.5);--accent-dim:oklch(0.54 0.1906 257.5/0.18);--accent-line:oklch(0.54 0.1906 257.5/0.4);--on-accent:oklch(0.985 0.012 257.5);--key-edge:oklch(0.928 0.0034 247.9);--hit:oklch(0.524 0.1401 148);--miss:oklch(0.552 0.2051 24.5);--slow-key-color:oklch(0.552 0.2051 24.5);--fast-key-color:oklch(0.524 0.1401 148);--on-confidence:oklch(0.99 0 0);--glow-1:oklch(0.54 0.1906 257.5/0.05);--glow-2:oklch(0.524 0.1401 148/0.04);--grain-opacity:0.02;--board-shadow:0 12px 28px -20px rgba(0,0,0,.13)}[data-theme=catppuccin-latte]{color-scheme:light;--bg:oklch(0.958 0.0058 264.5);--panel:oklch(0.933 0.0087 264.5);--panel-2:oklch(0.953 0.0087 264.5);--line:oklch(0.857 0.0145 268.5);--line-2:oklch(0.807 0.0145 268.5);--text:oklch(0.435 0.043 279.3);--muted:oklch(0.654 0.0269 278.1);--untyped:oklch(0.545 0.0269 278.1);--accent:oklch(0.555 0.2503 297);--accent-soft:oklch(0.475 0.2378 297);--accent-dim:oklch(0.555 0.2503 297/0.18);--accent-line:oklch(0.555 0.2503 297/0.4);--on-accent:oklch(0.985 0.012 297);--key-edge:oklch(0.883 0.0087 264.5);--hit:oklch(0.625 0.1772 140.4);--miss:oklch(0.55 0.2155 19.8);--slow-key-color:oklch(0.55 0.2155 19.8);--fast-key-color:oklch(0.625 0.1772 140.4);--on-confidence:oklch(0.99 0 0);--glow-1:oklch(0.555 0.2503 297/0.05);--glow-2:oklch(0.625 0.1772 140.4/0.04);--grain-opacity:0.02;--board-shadow:0 12px 28px -20px rgba(0,0,0,.13)}*,:after,:before{box-sizing:border-box}#root,body,html{height:100%;margin:0}body{position:relative;font-family:var(--font-display);color:var(--text);background-color:var(--bg);background-image:radial-gradient(900px 520px at 10% -10%,var(--glow-1),transparent 60%),radial-gradient(1000px 620px at 100% -6%,var(--glow-2),transparent 55%),radial-gradient(760px 760px at 50% 118%,var(--glow-1),transparent 62%);background-attachment:fixed;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .24s ease,color .24s ease}body:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:var(--grain-opacity);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}#root{position:relative;z-index:1}::selection{background:var(--accent-dim)}.app{max-width:960px;margin:0 auto;padding:30px 22px 64px;display:flex;flex-direction:column;gap:24px}@media (prefers-reduced-motion:no-preference){.app>*{animation:rise .62s cubic-bezier(.2,.7,.2,1) both}.app>:first-child{animation-delay:40ms}.app>:nth-child(2){animation-delay:.11s}.app>:nth-child(3){animation-delay:.18s}.app>:nth-child(4){animation-delay:.25s}}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.brand{font-size:26px;font-weight:700;letter-spacing:-.5px;display:inline-flex;align-items:baseline;gap:2px}.brand .caret{color:var(--accent);font-family:var(--font-mono);font-weight:800}@media (prefers-reduced-motion:no-preference){.brand .caret{animation:caret-blink 1.1s steps(1) infinite}}@keyframes caret-blink{50%{opacity:0}}.brand .tag{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--accent);background:var(--accent-dim);border-radius:999px;padding:3px 9px;margin-left:10px;align-self:center}.viewtoggle{display:inline-flex;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:4px;gap:4px}.viewtoggle button{background:transparent;color:var(--muted);border:0;border-radius:8px;padding:7px 16px;font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:color .14s ease,background .14s ease}.viewtoggle button:hover{color:var(--text)}.viewtoggle button.active{background:var(--accent);color:var(--on-accent)}.theme-select{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:7px 10px;font-family:var(--font-display);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .14s ease}.theme-select:hover{border-color:var(--accent-line)}.header-right{gap:12px}.controls,.header-right{display:flex;align-items:center;flex-wrap:wrap}.controls{gap:18px;font-size:13px;color:var(--muted)}.controls .rng{display:flex;flex-direction:column;gap:4px;font-family:var(--font-mono);font-size:12px;letter-spacing:.3px}.controls input[type=range]{accent-color:var(--accent);width:150px}.controls input[type=checkbox]{accent-color:var(--accent)}.controls .chk{display:inline-flex;align-items:center;gap:7px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.controls button{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:8px 14px;font-family:var(--font-display);font-size:13px;font-weight:500;cursor:pointer;transition:border-color .14s ease,color .14s ease,transform .14s ease}.controls button:hover{border-color:var(--accent-line);transform:translateY(-1px)}.controls button.danger:hover{border-color:var(--miss);color:var(--miss)}.practice-instrument,.stage{display:flex;flex-direction:column;gap:18px}.stage{align-items:center}.board{position:relative;width:100%;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:18px;padding:40px 34px;min-height:120px;font-family:var(--font-board,var(--font-mono));font-size:var(--board-size,32px);line-height:1.85;letter-spacing:.5px;white-space:pre-wrap;word-break:break-word;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:var(--board-shadow)}.board:before{content:"";position:absolute;inset:0 0 auto 0;height:2px;border-radius:18px 18px 0 0;background:linear-gradient(90deg,transparent,var(--accent-line),transparent)}.ch{color:var(--untyped);transition:color 90ms linear}.ch.hit{color:var(--hit)}.ch.cursor{position:relative}.ch.cursor-underline{color:var(--text);-webkit-text-decoration:underline solid var(--accent);text-decoration:underline solid var(--accent);text-decoration-thickness:2px;text-underline-offset:3px}.ch.cursor-underline.err{-webkit-text-decoration-color:var(--miss);text-decoration-color:var(--miss)}.ch.cursor-box{color:var(--text)}.ch.cursor-box:before{content:"";position:absolute;pointer-events:none;left:-.1em;right:-.1em;top:50%;height:1.18em;transform:translateY(-50%);border:2px solid var(--accent);border-radius:5px}.ch.cursor-box.err:before{border-color:var(--miss)}.ch.cursor-bar{color:var(--text)}.ch.cursor-bar:before{content:"";position:absolute;pointer-events:none;left:-.05em;top:50%;height:1.18em;width:2px;transform:translateY(-50%);background:var(--accent);border-radius:1px}.ch.cursor-bar.err:before{background:var(--miss)}.ch.cursor-block{color:var(--on-accent);background:var(--accent);border-radius:4px}.ch.cursor-block.err{color:var(--on-confidence);background:var(--miss)}.keyboard{flex-direction:column;align-items:center}.keyboard,.krow{display:flex;gap:9px}.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}.key{width:48px;height:50px;display:grid;place-items:center;border-radius:11px;font-family:var(--font-mono);font-size:17px;font-weight:700;text-transform:uppercase;color:var(--text);background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-bottom:2px solid var(--key-edge);box-shadow:inset 0 1px 0 color-mix(in oklch,var(--text) 6%,transparent);transition:transform .11s ease,filter .11s ease}.key:hover{transform:translateY(-1px);filter:brightness(1.08)}.key.excluded{color:var(--muted);opacity:.6;background:linear-gradient(180deg,var(--panel),var(--bg));box-shadow:none}.key.focus{outline:2px solid var(--accent);outline-offset:2px}.hint{margin:0;color:var(--muted);font-size:13.5px;text-align:center}.hint b{color:var(--accent-soft);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.5px}.hint-left{text-align:left}.hint .dim{opacity:.7}.practice-coach{display:grid;grid-template-columns:1fr 300px;grid-gap:18px;gap:18px;align-items:start}.coach-main{display:flex;flex-direction:column;gap:18px;min-width:0;justify-content:center}@media (max-width:780px){.practice-coach{grid-template-columns:1fr}}.coachrail{display:flex;flex-direction:column;gap:14px}.coach-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px}.coach-h{margin:0 0 12px;font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--muted)}.coach-bigram{display:flex;align-items:center;justify-content:center;gap:12px;font-family:var(--font-mono);font-weight:700}.coach-glyph{font-size:34px;line-height:1;color:var(--accent-soft)}.coach-arrow{font-size:22px;color:var(--muted)}.coach-ring{width:132px;height:132px;margin:14px auto 0;border-radius:50%;display:grid;place-items:center}.coach-ring-inner{width:104px;height:104px;border-radius:50%;background:var(--panel);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.coach-ring-val{font-family:var(--font-mono);font-size:30px;font-weight:700;line-height:1;color:var(--text)}.coach-ring-label{font-size:9.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}.coach-weak{display:flex;flex-direction:column;gap:10px}.coach-weakrow{display:flex;align-items:center;gap:12px}.coach-key{width:16px;font-family:var(--font-mono);font-weight:700;text-transform:uppercase;color:var(--accent-soft)}.coach-track{flex:1 1;height:9px;background:var(--panel-2);border:1px solid var(--line);border-radius:999px;overflow:hidden}.coach-fill{height:100%;border-radius:999px}.coach-val{width:34px;text-align:right;font-family:var(--font-mono);font-size:11.5px;color:var(--muted)}.coach-note{margin:0;font-size:13px;line-height:1.55;color:var(--muted)}.coach-note-center{margin-top:14px;text-align:center}.coach-note b{color:var(--text);font-weight:600}.coach-mono{font-family:var(--font-mono)}.zen{min-height:100vh;flex-direction:column;gap:24px;padding:22px 28px 28px}.zen,.zen-top{display:flex;justify-content:space-between}.zen-top{flex:0 0 auto;align-items:center;gap:16px}.zen-exit{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:9px;padding:7px 14px;font-family:var(--font-display);font-size:13px;cursor:pointer;transition:color .14s ease,border-color .14s ease}.zen-exit:hover{color:var(--text);border-color:var(--accent-line)}.zen-center{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:40px;padding:0 clamp(24px,6vw,80px)}.zen-center:focus{outline:none}.zen-eyebrow{font-family:var(--font-mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}.zen-eyebrow b{color:var(--accent-soft);font-weight:700}.zen-text{max-width:60ch;font-family:var(--font-board,var(--font-mono));font-size:var(--board-size,32px);line-height:1.8;letter-spacing:.5px;text-align:center;white-space:pre-wrap;word-break:break-word;-webkit-user-select:none;-moz-user-select:none;user-select:none}.zen-progress{width:min(640px,70%);height:3px;border-radius:999px;background:var(--panel);overflow:hidden}.zen-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-soft));transition:width .16s linear}.zen-gauges{display:flex;gap:40px;opacity:.92}.zen-gauge{display:flex;flex-direction:column;align-items:center;gap:3px}.zen-gauge-val{font-family:var(--font-mono);font-size:30px;font-weight:700;line-height:1;color:var(--text)}.zen-gauge-val.accent{color:var(--accent)}.zen-gauge-val.hit{color:var(--hit)}.zen-gauge-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted)}.zen-delta{font-family:var(--font-mono);font-size:10px}.zen-delta.up{color:var(--hit)}.zen-delta.down{color:var(--miss)}.zen-bottom{flex:0 0 auto}.zen-bottom .goal{max-width:520px;margin:0 auto}@media (prefers-reduced-motion:no-preference){.zen-center>*{animation:rise .62s cubic-bezier(.2,.7,.2,1) both}}.stats{display:flex;flex-direction:column;gap:14px}.cards{display:grid;grid-template-columns:repeat(8,1fr);grid-gap:11px;gap:11px}@media (max-width:780px){.cards{grid-template-columns:repeat(4,1fr)}}.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 13px;display:flex;flex-direction:column;gap:5px;transition:border-color .14s ease}.card:hover{border-color:var(--line-2)}.card-label{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.card-value{font-family:var(--font-mono);font-size:19px;font-weight:700}.goal{display:flex;align-items:center;gap:12px}.goalbar{flex:1 1;height:8px;background:var(--panel);border-radius:999px;overflow:hidden;border:1px solid var(--line)}.goalfill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-soft));transition:width .22s ease}.goaltext{font-family:var(--font-mono);font-size:12px;color:var(--muted);white-space:nowrap}.chart{display:block;width:100%}.actions{display:flex;align-items:center;gap:10px}.actions-target{font-family:var(--font-mono);font-size:12px;color:var(--muted)}.actions .spacer{flex:1 1}.actions button{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:9px;padding:7px 16px;font-family:var(--font-display);font-size:13px;cursor:pointer;transition:border-color .14s ease}.actions button:hover{border-color:var(--accent-line)}.settings-twopane{display:grid;grid-template-columns:210px 1fr;grid-gap:22px;gap:22px;align-items:start}.settings-twopane>.settings-title{grid-column:1/-1;margin-bottom:-6px}.settings-nav{display:flex;flex-direction:column;gap:3px;padding-top:6px}.settings-navbtn{text-align:left;background:transparent;border:0;color:var(--muted);font-family:var(--font-display);font-size:14px;font-weight:500;padding:11px 14px;border-radius:10px;cursor:pointer;transition:background .14s ease,color .14s ease}.settings-navbtn:hover{color:var(--text)}.settings-navbtn.active{background:var(--accent-dim);color:var(--accent);font-weight:600}.settings-pane{gap:16px;min-width:0}.settings-pane,.settings-single{display:flex;flex-direction:column}.settings-single{gap:20px;max-width:680px;margin:0 auto}.settings-title{margin:0;font-size:22px;letter-spacing:-.3px}.settings-preview-wrap{padding:6px 0 14px}.sgroup{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);padding:6px 20px 14px;margin:0}.sgroup legend{padding:0 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--accent)}.srow{display:flex;align-items:center;gap:20px;padding:15px 2px;border-top:1px solid var(--line)}.sgroup .srow:first-of-type{border-top:0}.slabel{display:flex;flex-direction:column;gap:3px;flex:1 1;min-width:0}.sname{font-size:14.5px;font-weight:600}.sdesc{font-size:12.5px;color:var(--muted);line-height:1.5}.sctrl{flex:0 0 auto}.rangewrap{display:flex;align-items:center;gap:14px}.rangewrap input[type=range]{width:190px;accent-color:var(--accent)}.rangeval{font-family:var(--font-mono);font-size:13px;width:62px;text-align:right;color:var(--text)}.srow-block{flex-direction:column;align-items:stretch;gap:10px}.settings-textarea{width:100%;min-height:84px;resize:vertical;background:var(--panel-2);color:var(--text);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-family:var(--font-display);font-size:13px;line-height:1.5}.settings-textarea:focus{outline:none;border-color:var(--accent-line)}.settings-textarea::placeholder{color:var(--muted)}.switch{position:relative;width:44px;height:26px;border-radius:999px;border:1px solid var(--line);background:var(--panel-2);cursor:pointer;transition:background .16s ease,border-color .16s ease;flex:0 0 auto;padding:0}.switch .knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:var(--muted);transition:transform .16s ease,background .16s ease}.switch.on{background:var(--accent-dim);border-color:var(--accent-line)}.switch.on .knob{transform:translateX(18px);background:var(--accent)}.segmented{display:inline-flex;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:3px;gap:3px}.segmented .seg{background:transparent;color:var(--muted);border:0;border-radius:7px;padding:7px 14px;font-family:var(--font-display);font-size:13px;font-weight:500;cursor:pointer;transition:color .14s ease,background .14s ease}.segmented .seg:hover{color:var(--text)}.segmented .seg.active{background:var(--accent);color:var(--on-accent)}.settings-preview{display:flex;align-items:center;text-align:center;font-size:var(--board-size,32px);padding:28px 20px;min-height:calc(var(--board-size, 32px) * 1.85 * 2 + 56px)}.settings-preview-line{width:100%}.confirm-row{display:inline-flex;align-items:center;gap:8px}.confirm-row .seg{background:var(--panel-2);color:var(--muted);border:1px solid var(--line);border-radius:8px;padding:7px 14px}.confirm-row .seg,.danger-btn{font-family:var(--font-display);font-size:13px;cursor:pointer}.danger-btn{background:var(--miss);color:#fff;border:1px solid var(--miss);border-radius:8px;padding:8px 16px;font-weight:600;transition:filter .14s ease}.danger-btn:hover{filter:brightness(1.08)}.danger-btn.ghost{background:transparent;color:var(--miss)}@media (max-width:680px){.srow{flex-direction:column;align-items:flex-start;gap:10px}}.dash{flex-direction:column;width:100%;max-width:1160px;margin:0 auto}.dash,.pagehead{display:flex;gap:16px}.pagehead{align-items:flex-end;justify-content:space-between;flex-wrap:wrap}.pagehead h2{margin:0;font-size:clamp(22px,3vw,30px);font-weight:700;letter-spacing:-.8px}.pagehead p{margin:4px 0 0;color:var(--muted);font-size:13.5px}.dash-actions{display:flex;gap:8px}.dash-actions button{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:10px;padding:8px 14px;font-family:var(--font-display);font-size:12.5px;font-weight:600;cursor:pointer;transition:border-color .14s ease}.dash-actions button:hover{border-color:var(--line-2)}.kpis{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:12px;gap:12px}@media (max-width:900px){.kpis{grid-template-columns:repeat(3,1fr)}}@media (max-width:540px){.kpis{grid-template-columns:repeat(2,1fr)}}.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px 15px;display:flex;flex-direction:column;gap:7px;position:relative;overflow:hidden}.kpi .kl{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}.kpi .kv{font-family:var(--font-mono);font-size:25px;font-weight:700;line-height:1;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.kpi .kv .u{font-size:12px;color:var(--muted);font-weight:500;margin-left:3px}.kpi .kd{font-family:var(--font-mono);font-size:10.5px;display:flex;align-items:center;gap:4px}.kpi .kd.up{color:var(--hit)}.kpi .kd.down{color:var(--miss)}.kpi .kd.flat{color:var(--muted)}.kpi.hero{background:linear-gradient(160deg,var(--accent-dim),transparent 70%);border-color:var(--accent-line)}.kpi.hero .kv{color:var(--accent)}.spark{position:absolute;right:0;bottom:0;opacity:.5}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px}.panel>.ph{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 16px;flex-wrap:wrap}.panel .ph h3{margin:0;font-size:13px;font-weight:700;letter-spacing:.3px}.panel .ph .sub{font-size:11px}.legend,.panel .ph .sub{font-family:var(--font-mono);color:var(--muted)}.legend{display:flex;gap:14px;font-size:10.5px;flex-wrap:wrap}.legend i{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:5px;vertical-align:-1px}.grid2{grid-template-columns:1fr 1fr;grid-gap:16px}.grid-keys,.grid2{display:grid;gap:16px}.grid-keys{grid-template-columns:1.45fr 1fr;grid-gap:16px}@media (max-width:860px){.grid-keys,.grid2{grid-template-columns:1fr}}.chart-grid{stroke:var(--line);stroke-width:1}.chart-axis-label{font-family:var(--font-mono);font-size:10px;fill:var(--muted)}.chart-goal{stroke:var(--hit);stroke-width:1.5;stroke-dasharray:5 4;opacity:.7}.dtable{width:100%;border-collapse:collapse;font-family:var(--font-mono);font-size:12.5px}.dtable th{text-align:left;font-weight:500;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px;padding:0 0 9px}.dtable td,.dtable th{border-bottom:1px solid var(--line)}.dtable td{padding:9px 0}.dtable tbody tr:last-child td{border-bottom:0}.dtable .tdr{text-align:right;color:var(--muted)}.kc{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 5px;border-radius:6px;background:var(--panel-2);border:1px solid var(--line);font-weight:700;color:var(--text);text-transform:uppercase}.bg{color:var(--accent-soft)}.minitrack{height:7px;border-radius:999px;background:var(--panel-2);border:1px solid var(--line);overflow:hidden;min-width:60px}.minifill{height:100%;border-radius:999px}.note{font-size:12px;color:var(--muted);font-family:var(--font-mono)}.kbnote{text-align:center;margin:10px 0 0}.calnote{margin:12px 0 0}.cal{display:flex;gap:12px;align-items:flex-start;overflow-x:auto;padding-bottom:4px}.calmonths{display:grid;grid-template-columns:repeat(26,13px);grid-gap:3px;gap:3px;font-family:var(--font-mono);font-size:9.5px;color:var(--muted);margin-bottom:4px}.calmonths span{white-space:nowrap}.calgrid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,1fr);grid-gap:3px;gap:3px}.cell{width:13px;height:13px;border-radius:3px;background:var(--panel-2);border:1px solid color-mix(in oklch,var(--line) 60%,transparent)}.caldays{display:grid;grid-template-rows:repeat(7,1fr);grid-gap:3px;gap:3px;font-family:var(--font-mono);font-size:9px;color:var(--muted)}.caldays span{height:13px;line-height:13px}.callegend{display:flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:10px;color:var(--muted)}.callegend .cell{width:11px;height:11px}.kb-heatmap{align-items:center;padding:6px 0}.kb-heatmap .key{position:relative}.kb-heatmap .key .mini{position:absolute;bottom:2px;right:4px;font-size:7px;font-weight:500;opacity:.85}.madeby{display:inline-flex;align-items:center;gap:8px;margin:8px 2px 0;color:var(--muted);font-size:12.5px;text-decoration:none;opacity:.85;transition:opacity .14s ease}.madeby:hover{opacity:1;color:var(--text)}.madeby img{border-radius:50%;display:block}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/space-grotesk-latin-400-normal.5977941d.woff2) format("woff2"),url(/_next/static/media/space-grotesk-latin-400-normal.73004868.woff) format("woff")}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:500;src:url(/_next/static/media/space-grotesk-latin-500-normal.31250b26.woff2) format("woff2"),url(/_next/static/media/space-grotesk-latin-500-normal.3d793272.woff) format("woff")}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:600;src:url(/_next/static/media/space-grotesk-latin-600-normal.d7cc7ee6.woff2) format("woff2"),url(/_next/static/media/space-grotesk-latin-600-normal.b60aff3d.woff) format("woff")}@font-face{font-family:Space Grotesk;font-style:normal;font-display:swap;font-weight:700;src:url(/_next/static/media/space-grotesk-latin-700-normal.46d978a2.woff2) format("woff2"),url(/_next/static/media/space-grotesk-latin-700-normal.f67e63c9.woff) format("woff")}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/jetbrains-mono-latin-400-normal.db9d659a.woff2) format("woff2"),url(/_next/static/media/jetbrains-mono-latin-400-normal.b0c7be19.woff) format("woff")}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:700;src:url(/_next/static/media/jetbrains-mono-latin-700-normal.9545a3d1.woff2) format("woff2"),url(/_next/static/media/jetbrains-mono-latin-700-normal.c9484cde.woff) format("woff")}@font-face{font-family:JetBrains Mono;font-style:normal;font-display:swap;font-weight:800;src:url(/_next/static/media/jetbrains-mono-latin-800-normal.93e25f31.woff2) format("woff2"),url(/_next/static/media/jetbrains-mono-latin-800-normal.3308794c.woff) format("woff")}@font-face{font-family:Cascadia Code;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/cascadia-code-latin-400-normal.7af4159a.woff2) format("woff2"),url(/_next/static/media/cascadia-code-latin-400-normal.7f8ae8ea.woff) format("woff")}@font-face{font-family:Source Code Pro;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/source-code-pro-latin-400-normal.838d3b90.woff2) format("woff2"),url(/_next/static/media/source-code-pro-latin-400-normal.4c1c2cf6.woff) format("woff")}@font-face{font-family:Atkinson Hyperlegible;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/atkinson-hyperlegible-latin-400-normal.93c18311.woff2) format("woff2"),url(/_next/static/media/atkinson-hyperlegible-latin-400-normal.e5e00de5.woff) format("woff")}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/inter-latin-400-normal.ef6d3f52.woff2) format("woff2"),url(/_next/static/media/inter-latin-400-normal.2c7a775c.woff) format("woff")}@font-face{font-family:Lexend;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/lexend-latin-400-normal.69a7a64f.woff2) format("woff2"),url(/_next/static/media/lexend-latin-400-normal.09059bb4.woff) format("woff")}@font-face{font-family:Literata;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/literata-latin-400-normal.bbb8fdf3.woff2) format("woff2"),url(/_next/static/media/literata-latin-400-normal.69c6d4af.woff) format("woff")}@font-face{font-family:Merriweather;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/merriweather-latin-400-normal.3195b999.woff2) format("woff2"),url(/_next/static/media/merriweather-latin-400-normal.12fe85d4.woff) format("woff")}@font-face{font-family:Lora;font-style:normal;font-display:swap;font-weight:400;src:url(/_next/static/media/lora-latin-400-normal.1245abf6.woff2) format("woff2"),url(/_next/static/media/lora-latin-400-normal.4ca3a8d1.woff) format("woff")}