:root,:root[data-theme=dark]{--bg-0:#0b0b14;--bg-1:#14132a;--bg-2:#1d1538;--ink:#e7e8f3;--ink-soft:#b3b6cf;--ink-mute:#6d7099;--accent:#a78bfa;--accent-2:#38bdf8;--accent-warm:#fb7185;--good:#4ade80;--bad:#fb7185;--glass-bg:#ffffff0a;--glass-bg-strong:#ffffff12;--glass-border:#ffffff14;--glass-hi:#ffffff2e;--shadow:0 12px 40px #00000073, 0 2px 6px #00000059;--panel-bg:#14132aeb;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme=light]{--bg-0:#f5f4fb;--bg-1:#ecebf6;--bg-2:#e0def0;--ink:#1a1830;--ink-soft:#4b4960;--ink-mute:#8a8aa3;--accent:#7c3aed;--accent-2:#0284c7;--accent-warm:#e11d48;--good:#16a34a;--bad:#e11d48;--glass-bg:#ffffff8c;--glass-bg-strong:#ffffffc7;--glass-border:#14132a14;--glass-hi:#14132a2e;--shadow:0 12px 40px #7c3aed24, 0 2px 6px #14132a14;--panel-bg:#fffffff0;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-cb="1"]{--good:#009688;--bad:#f57c00;--accent-warm:#f57c00}:root[data-theme=contrast]{--bg-0:#000;--bg-1:#000;--bg-2:#000;--ink:#fff;--ink-soft:#e5e7eb;--ink-mute:#9ca3af;--accent:#ffea00;--accent-2:#00e5ff;--accent-warm:#f57;--good:#0f8;--bad:#f56;--glass-bg:#ffffff0a;--glass-bg-strong:#ffffff1a;--glass-border:#ffffff8c;--glass-hi:#ffffffd9;--shadow:none;--panel-bg:#000;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root{--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;--sans:-apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", Roboto, sans-serif;color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}*{box-sizing:border-box}html,body,#root{height:100%}html,body{overscroll-behavior:none}body{background:radial-gradient(1200px 800px at 80% -10%, #a78bfa2e, transparent 60%), radial-gradient(900px 700px at -10% 110%, #38bdf826, transparent 60%), linear-gradient(180deg, var(--bg-0), var(--bg-1) 60%, var(--bg-2));background-attachment:fixed;min-height:100svh;margin:0;overflow-x:hidden}:root[data-theme=light] body{background:radial-gradient(1200px 800px at 80% -10%, #7c3aed1f, transparent 60%), radial-gradient(900px 700px at -10% 110%, #0284c71a, transparent 60%), linear-gradient(180deg, var(--bg-0), var(--bg-1) 60%, var(--bg-2))}:root[data-theme=contrast] body{background:#000}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}::selection{background:#a78bfa4d}.app{flex-direction:column;gap:20px;max-width:1200px;min-height:100svh;margin:0 auto;padding:20px 32px;display:flex}@media (width<=640px){.app{gap:14px;padding:14px}}.app.focus-mode .topbar,.app.focus-mode .stats,.app.focus-mode .kb,.app.focus-mode .finger-hint,.app.focus-mode .hint{display:none}.app.focus-mode .main{grid-template-columns:1fr}.app.focus-mode .stage{padding:56px 36px 24px}.topbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}@media (width<=640px){.topbar-actions{gap:6px}.btn-ghost{padding:6px 10px;font-size:12px}}.brand{letter-spacing:.5px;align-items:center;gap:10px;margin:0;font-size:18px;font-weight:600;display:flex}.brand-mark{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0b0b14;border-radius:10px;place-items:center;width:34px;height:34px;font-size:18px;display:inline-grid;box-shadow:0 6px 18px #a78bfa59}.brand-name{font-family:var(--mono);color:var(--ink);font-size:18px}.logo-mark{overflow:hidden}.logo-blink{animation:1.05s steps(2,jump-none) infinite logo-blink;display:inline-block}@keyframes logo-blink{0%,50%{opacity:1}50.01%,to{opacity:0}}@media (prefers-reduced-motion:reduce){.logo-blink{animation:none}}.ach-pill{box-sizing:border-box;min-height:34px;color:var(--ink);line-height:1;font-family:var(--mono);letter-spacing:.4px;cursor:pointer;background:#facc151a;border:1px solid #facc154d;border-radius:999px;align-items:center;gap:6px;padding:3px 10px 3px 4px;font-size:12px;transition:background .16s,border-color .16s;display:inline-flex}.ach-pill:hover{background:#facc152e;border-color:#facc1580}.ach-pill-icon{justify-content:center;align-items:center;width:22px;height:22px;font-size:12px;line-height:1;display:inline-flex}.ach-pill-num{font-weight:600}.ach-pill-total{opacity:.55;margin-left:1px;font-weight:400}.streak-chip{box-sizing:border-box;min-height:34px;color:var(--ink);line-height:1;font-family:var(--mono);letter-spacing:.4px;cursor:pointer;background:#fb71851f;border:1px solid #fb718552;border-radius:999px;align-items:center;gap:6px;padding:3px 10px 3px 4px;font-size:12px;transition:background .2s,border-color .2s;display:inline-flex}.streak-chip:hover{background:#fb71852e;border-color:#fb71857a}.streak-chip-goal:hover{background:#4ade8033;border-color:#4ade808c}.streak-chip-goal{background:#4ade8024;border-color:#4ade8073}.streak-chip-risk{animation:2.4s ease-in-out infinite streak-pulse}@keyframes streak-pulse{0%,to{box-shadow:0 0 #fb718500}50%{box-shadow:0 0 0 5px #fb71852e}}@media (prefers-reduced-motion:reduce){.streak-chip-risk{animation:none;box-shadow:0 0 0 3px #fb71852e}.idle-pill,.celebration-card{animation:none}.toast{opacity:1;animation:none}.stream-cursor-overlay{transition:none;animation:none}.stream-cursor-block .stream-cursor-overlay{opacity:1}}.streak-ring{place-items:center;width:22px;height:22px;display:inline-grid;position:relative}.streak-ring svg{position:absolute;inset:0}.streak-ring-bg{fill:none;stroke:#ffffff1a;stroke-width:2px}.streak-ring-fg{fill:none;stroke:var(--bad);stroke-width:2px;stroke-linecap:round;transition:stroke-dashoffset .4s,stroke .2s}.streak-chip-goal .streak-ring-fg{stroke:var(--good)}.streak-flame{font-size:12px;line-height:1;position:relative}.streak-num{font-weight:600}.level-badge-button{appearance:none;color:inherit;cursor:pointer;transition:transform .12s,box-shadow .2s,border-color .12s}.level-badge-button:hover{border-color:#a78bfad9;transform:translateY(-1px);box-shadow:0 0 0 1px #a78bfa52,0 8px 20px #a78bfa47}.level-badge-button:active{transform:translateY(0)}.level-badge-button:focus-visible{outline-offset:2px;outline:2px solid #a78bfa8c}.level-board-next{align-items:baseline;gap:8px;margin:4px 0 12px;font-size:13px;display:flex}.level-board-next-label{color:var(--ink);font-weight:600}.level-board-next-progress{color:var(--ink-mute);font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.level-board-list{flex-direction:column;gap:4px;max-height:56vh;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.level-board-row{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:8px;grid-template-columns:30px 36px 110px 80px 1fr;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:grid}.level-board-badge{background:#0003;border:1px solid #ffffff0f;border-radius:50%;place-items:center;width:24px;height:24px;font-size:14px;display:inline-grid}.level-board-row.is-reached .level-board-badge{background:linear-gradient(135deg,#a78bfa4d,#38bdf838);border-color:#a78bfa8c}.level-board-row.is-next .level-board-badge{background:#7dd3fc2e;border-color:#7dd3fc80}.level-board-row.is-reached{background:linear-gradient(135deg,#a78bfa1a,#38bdf80f);border-color:#a78bfa66}.level-board-row.is-next{background:#7dd3fc0d;border-color:#7dd3fc80}.level-board-rank{font-family:var(--mono);color:var(--ink);font-weight:700}.level-board-title{color:var(--ink)}.level-board-floor{font-family:var(--mono);color:var(--ink-mute);font-size:11px}.level-board-unlocks{font-family:var(--mono);color:var(--ink-mute);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.level-board-foot{color:var(--ink-mute);text-align:center;margin-top:12px;font-size:11px}.profile-share-url{border:1px dashed var(--glass-border);background:#a78bfa0a;border-radius:10px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.profile-share-url-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);font-size:10px}.profile-share-url-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.profile-share-url-value{font-family:var(--mono);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink);border-radius:6px;padding:4px 8px;font-size:13px}.profile-share-url-status{font-family:var(--mono);color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.profile-share-url-prefix{font-family:var(--mono);color:var(--ink-mute);font-size:12px}.leaderboard-preview{flex-direction:column;gap:8px;display:flex}.leaderboard-preview-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);font-size:10px}.leaderboard-row{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:10px;grid-template-columns:28px 36px 1fr auto;align-items:center;gap:12px;padding:10px 12px;display:grid}.leaderboard-row-self{background:linear-gradient(135deg,#a78bfa1a,#38bdf80f);border-color:#a78bfa73}.leaderboard-rank{font-family:var(--mono);color:var(--ink-mute);text-align:center;font-size:13px}.leaderboard-avatar{background:var(--panel-bg);border:1px solid var(--glass-border);border-radius:50%;place-items:center;width:32px;height:32px;font-size:18px;display:grid;overflow:hidden}.leaderboard-avatar img{object-fit:cover;width:100%;height:100%}.leaderboard-name{flex-direction:column;gap:2px;min-width:0;display:flex}.leaderboard-name-main{white-space:nowrap;text-overflow:ellipsis;font-weight:600;overflow:hidden}.leaderboard-stat{font-family:var(--mono);color:var(--ink);font-size:13px}.leaderboard-stat strong{font-size:16px}.leaderboard-list{flex-direction:column;gap:4px;max-height:40vh;margin:8px 0 0;padding:0;list-style:none;display:flex;overflow-y:auto}.leaderboard-empty{text-align:center;color:var(--ink-mute);padding:16px 8px;font-size:13px}.challenges-list{flex-direction:column;gap:10px;max-height:60vh;margin:0;padding:0;list-style:none;display:flex;overflow-y:auto}.challenge-item{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:10px;flex-direction:column;gap:6px;padding:10px 12px;display:flex}.challenge-item.is-locked{opacity:.55}.challenge-item.is-passed{background:linear-gradient(135deg,#a78bfa1a,#38bdf80f);border-color:#a78bfa73}.challenge-head{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.challenge-name{align-items:center;gap:6px;font-weight:600;display:inline-flex}.challenge-badge{color:#fbbf24e6;font-size:11px}.challenge-criteria{font-family:var(--mono);color:var(--ink-mute);text-transform:uppercase;letter-spacing:.06em;font-size:11px}.challenge-desc{color:var(--ink-mute);font-size:12px}.challenge-text{font-family:var(--mono);color:var(--ink-soft);border:1px solid var(--glass-border);white-space:pre-wrap;background:#ffffff08;border-radius:6px;padding:8px 10px;font-size:12px}.challenge-actions{justify-content:flex-end;align-items:center;display:flex}.challenge-lock{color:var(--ink-mute);font-size:11px;font-family:var(--mono)}.lesson-replay-text{font-family:var(--mono);background:var(--glass-bg);border:1px solid var(--glass-border);white-space:pre-wrap;word-break:break-word;border-radius:12px;min-height:7em;max-height:40vh;margin:12px 0;padding:16px 20px;font-size:18px;line-height:1.6;overflow-y:auto}.lesson-replay-typed{color:var(--ink)}.lesson-replay-cursor{color:var(--ink);background:#a78bfa52;border-radius:3px}.lesson-replay-rest{color:var(--ink-mute)}.lesson-replay-controls{justify-content:center;align-items:center;gap:8px;padding-top:4px;display:flex}.profile-share-title{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--ink);background:linear-gradient(135deg,#a78bfa2e,#38bdf824);border:1px solid #a78bfa73;border-radius:999px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:600}.avatar-picker{z-index:10;background:var(--panel-bg);border:1px solid var(--glass-border);box-shadow:var(--shadow);border-radius:12px;grid-template-columns:repeat(8,1fr);gap:4px;max-width:min(360px,100vw - 32px);padding:8px;display:grid;position:absolute;top:64px;left:0}.avatar-picker-cell{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;place-items:center;width:32px;height:32px;padding:0;font-size:20px;line-height:1;transition:background .1s,border-color .1s;display:inline-grid}.avatar-picker-cell:hover{background:var(--glass-bg-strong)}.avatar-picker-cell.is-selected{background:#a78bfa2e;border-color:#a78bfa8c}.avatar-picker-clear{border:1px solid var(--glass-border);color:var(--ink-mute);font-family:var(--sans);cursor:pointer;background:0 0;border-radius:6px;grid-column:1/-1;margin-top:4px;padding:4px 8px;font-size:11px}.avatar-picker-clear:hover{color:var(--ink);background:var(--glass-bg)}.nickname-input{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink);font-family:var(--mono);border-radius:6px;width:22ch;padding:4px 8px;font-size:13px;transition:border-color .12s,background .12s}.nickname-input:focus{background:#a78bfa14;border-color:#a78bfa8c;outline:none}.streak-freeze-count{color:var(--ink);letter-spacing:.02em;background:#7dd3fc2e;border-radius:999px;align-items:center;gap:1px;margin-left:4px;padding:0 5px;font-size:10px;display:inline-flex}.streak-inline-sep{opacity:.45}.streak-inline-stat{font-weight:500}@keyframes streak-panel-exit{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-24px)scale(.92)}}.streak-panel-exiting{pointer-events:none;animation:.65s cubic-bezier(.4,0,.6,1) forwards streak-panel-exit}@keyframes streak-chip-text-in{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.streak-chip-text-in{animation:.35s ease-out .45s both streak-chip-text-in}@media (prefers-reduced-motion:reduce){.streak-panel-exiting{opacity:0;animation:none}.streak-chip-text-in{animation:none}}:root[data-theme=light] .streak-ring-bg{stroke:#14132a1f}.topbar-actions{gap:8px;display:flex}.btn-ghost{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-soft);letter-spacing:.3px;border-radius:10px;padding:8px 14px;font-size:13px;transition:background .12s,color .12s,transform 80ms}.btn-ghost:hover:not(:disabled){background:var(--glass-bg-strong);color:var(--ink)}.btn-ghost:active:not(:disabled){transform:translateY(1px)}.btn-ghost:disabled{opacity:.4;cursor:not-allowed}.btn-icon{place-items:center;width:34px;height:34px;padding:0;display:inline-grid}.btn-icon.on{color:var(--ink);background:#a78bfa38;border-color:#a78bfa80}.btn-danger{color:var(--bad);letter-spacing:.3px;background:#fb71851f;border:1px solid #fb718566;border-radius:10px;padding:8px 14px;font-size:13px;transition:background .12s}.btn-danger:hover{background:#fb71852e}.btn-primary{background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0b0b14;letter-spacing:.3px;border:none;border-radius:10px;padding:8px 16px;font-size:13px;font-weight:500;transition:filter .12s,transform 80ms}.btn-primary:hover{filter:brightness(1.05)}.btn-primary:active{transform:translateY(1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.4)}.feedback-fineprint{color:var(--ink-mute);letter-spacing:.4px;text-align:right;margin:0 0 4px;font-size:11px}.history-modal{width:min(560px,100vw - 32px)}.history-toolbar{justify-content:space-between;align-items:center;gap:8px;display:flex}.history-count{font-family:var(--mono);color:var(--ink-mute);letter-spacing:.4px;font-size:11px}.history-list{flex-direction:column;gap:4px;max-height:400px;margin:8px 0 0;padding:0;list-style:none;display:flex;overflow-y:auto}.history-row{border:1px solid var(--glass-border);font-family:var(--mono);color:var(--ink-soft);background:#0000002e;border-radius:8px;grid-template-columns:130px 80px 70px 50px 32px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;display:grid}:root[data-theme=light] .history-row{background:#14132a0a}.history-ts{color:var(--ink-mute)}.history-mode{color:var(--ink)}.history-wpm{text-align:right}.history-acc{text-align:right;color:var(--ink-mute)}.history-empty{text-align:center;color:var(--ink-mute);letter-spacing:.4px;text-transform:uppercase;border:1px dashed var(--glass-border);background:#0000002e;border-radius:10px;margin-top:8px;padding:24px;font-size:12px}:root[data-theme=light] .history-empty{background:#14132a0a}.cp{flex-direction:column;width:min(560px,100vw - 32px);padding:0;display:flex;overflow:hidden}.cp-input{border:none;border-bottom:1px solid var(--glass-border);width:100%;color:var(--ink);font-family:var(--mono);background:0 0;outline:none;padding:16px 20px;font-size:15px}.cp-input::placeholder{color:var(--ink-mute)}.cp-list{max-height:360px;margin:0;padding:6px;list-style:none;overflow-y:auto}.cp-item{font-family:var(--mono);color:var(--ink-soft);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:baseline;gap:12px;padding:8px 12px;font-size:13px;display:flex}.cp-item.on{color:var(--ink);background:linear-gradient(135deg,#a78bfa33,#38bdf824)}.cp-label{align-items:baseline;gap:8px;min-width:0;display:inline-flex}.cp-group{letter-spacing:.6px;text-transform:uppercase;color:var(--ink-mute);background:var(--glass-bg);border-radius:4px;padding:2px 6px;font-size:10px}.cp-hint{color:var(--ink-mute);font-size:11px}.cp-empty{text-align:center;color:var(--ink-mute);letter-spacing:.5px;padding:18px 12px;font-size:12px}.cp-foot{border-top:1px solid var(--glass-border);color:var(--ink-mute);letter-spacing:.3px;justify-content:flex-end;align-items:center;gap:12px;padding:8px 14px;font-size:11px;display:flex}.cp-foot kbd{font-family:var(--mono);background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-soft);border-radius:4px;margin-right:4px;padding:2px 5px;font-size:10px}.cheatsheet{width:min(420px,100vw - 32px)}.cheatsheet-list{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.cheatsheet-row{border:1px solid var(--glass-border);color:var(--ink);background:#0000002e;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:13px;display:flex}:root[data-theme=light] .cheatsheet-row{background:#14132a0a}.cheatsheet-keys{gap:4px;display:inline-flex}.cheatsheet-key{font-family:var(--mono);border:1px solid var(--glass-hi);color:var(--ink);text-align:center;background:#ffffff1a;border-radius:6px;min-width:20px;padding:2px 7px;font-size:12px}:root[data-theme=light] .cheatsheet-key{background:#14132a14}.help-panel{width:min(480px,100vw - 32px)}.help-tagline{color:var(--ink-soft);margin:4px 0 10px;font-size:14px;line-height:1.55}.help-section{margin-top:16px}.help-list{grid-template-columns:1fr auto;gap:4px 16px;margin:6px 0 0;padding:0;font-size:13px;list-style:none;display:grid}.help-list li{display:contents}.help-list li span{color:var(--ink-mute)}.help-list li strong{color:var(--ink);justify-self:end;font-weight:600}.help-next{color:var(--ink-soft);margin:6px 0 0;font-size:14px;line-height:1.5}.help-tips{color:var(--ink-soft);margin:6px 0 0;padding-left:20px;font-size:13px;line-height:1.55}.help-tips li{margin-bottom:4px}.help-tips kbd{background:var(--glass-bg);border:1px solid var(--glass-border);font-family:var(--mono);color:var(--ink);border-radius:4px;padding:1px 6px;font-size:11px;display:inline-block}.help-footer{border-top:1px solid var(--glass-border);font-family:var(--mono);color:var(--ink-mute);justify-content:center;align-items:center;gap:10px;margin-top:18px;padding-top:14px;font-size:12px;display:flex}.help-footer a{color:var(--ink-soft);text-decoration:none}.help-footer a:hover{color:var(--accent)}.help-footer-link{font:inherit;color:var(--ink-soft);cursor:pointer;background:0 0;border:0;margin:0;padding:0}.help-footer-link:hover{color:var(--accent)}.app-footer{font-family:var(--mono);color:var(--ink-mute);flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 12px;padding:16px 0 4px;font-size:12px;display:flex}.app-footer a{color:var(--ink-mute);white-space:nowrap;text-decoration:none;transition:color .16s}.app-footer a:hover{color:var(--accent)}.app-footer .sep{opacity:.5}.app-footer-link{font:inherit;color:var(--ink-mute);cursor:pointer;white-space:nowrap;background:0 0;border:0;margin:0;padding:0;transition:color .16s}.app-footer-link:hover{color:var(--accent)}.app.focus-mode .app-footer{display:none}.custom-edit-btn{align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.custom-edit-btn .custom-edit-name{color:var(--ink-mute);font-family:var(--mono);font-size:11px}.app-footer-more{align-items:center;display:inline-flex;position:relative}.app-footer-more-btn{white-space:nowrap}.app-footer-more-caret{opacity:.7;margin-left:2px;font-size:9px;display:inline-block}.app-footer-more-popover{background:var(--panel-bg);border:1px solid var(--glass-border);z-index:50;text-transform:none;letter-spacing:0;border-radius:10px;flex-direction:column;gap:2px;min-width:160px;padding:6px;display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 8px 24px #00000040}.app-footer-more-btn[aria-expanded=true]+.app-footer-more-popover{display:flex}.app-footer-more-popover a{color:var(--ink-mute);white-space:nowrap;border-radius:6px;padding:6px 10px;font-size:12px;text-decoration:none}.app-footer-more-popover a:hover{background:var(--glass-hi);color:var(--ink)}.onboarding{width:min(480px,100vw - 32px)}.onboarding-hero{text-align:center;padding:4px 0 6px}.onboarding-mark{border-radius:16px;width:56px;height:56px;margin:0 auto 12px;font-size:28px}.onboarding-hero h2{margin:0 0 6px;font-size:22px;font-weight:600}.onboarding-sub{color:var(--ink-soft);margin:0;font-size:14px;line-height:1.5}.onboarding-list{flex-direction:column;gap:10px;margin:12px 0 4px;padding:0;list-style:none;display:flex}.onboarding-list li{border:1px solid var(--glass-border);background:#0000002e;border-radius:12px;grid-template-columns:26px 1fr;align-items:start;gap:12px;padding:10px 12px;display:grid}:root[data-theme=light] .onboarding-list li{background:#14132a0a}.onboarding-list li>div{flex-direction:column;gap:2px;display:flex}.onboarding-list strong{color:var(--ink);font-size:13px;font-weight:500}.onboarding-help{color:var(--ink-mute);font-size:12px;line-height:1.5}.onboarding-bullet{background:linear-gradient(135deg, var(--accent), var(--accent-2));border-radius:9px;place-items:center;width:28px;height:28px;font-size:15px;line-height:1;display:inline-grid;box-shadow:inset 0 1px #ffffff1f,0 6px 14px #a78bfa2e}.onboarding-showcase{border:1px solid var(--glass-border);background:linear-gradient(135deg,#a78bfa1a,#60a5fa14);border-radius:14px;flex-direction:column;gap:8px;margin:14px 0 6px;padding:12px 14px 10px;display:flex}.onboarding-showcase-row{grid-template-columns:100px 1fr;align-items:center;gap:10px;display:grid}.onboarding-showcase-label{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);font-size:10px}.onboarding-showcase-arc{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.onboarding-showcase-cell{align-items:center;gap:6px;display:inline-flex}.onboarding-showcase-emoji{background:#00000047;border:1px solid #ffffff1a;border-radius:50%;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:15px;line-height:1;display:inline-grid}:root[data-theme=light] .onboarding-showcase-emoji{background:#14132a0f;border-color:#14132a1a}.onboarding-showcase-arrow{color:var(--ink-mute);font-size:12px}.onboarding-showcase-caption{text-align:center;color:var(--ink-mute);letter-spacing:.02em;margin:2px 0 0;font-size:11px}@media (width<=480px){.onboarding-showcase-row{grid-template-columns:1fr;gap:4px}}.seg{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:10px;gap:2px;padding:3px;display:inline-flex}.seg-btn{color:var(--ink-mute);letter-spacing:.4px;text-transform:lowercase;background:0 0;border-radius:8px;padding:6px 12px;font-size:12px;transition:background .12s,color .12s}.seg-btn:hover:not(:disabled):not(.on){color:var(--ink-soft)}.seg-btn.on{color:var(--ink);background:linear-gradient(135deg,#a78bfa40,#38bdf82e);box-shadow:inset 0 0 0 1px #a78bfa59}.seg-btn:disabled{opacity:.4;cursor:not-allowed}.tooltip-portal{background:var(--panel-bg);color:var(--ink);border:1px solid var(--glass-border);font-family:var(--sans);letter-spacing:.15px;white-space:normal;width:max-content;max-width:320px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);border-radius:8px;padding:7px 11px;font-size:12px;font-weight:500;line-height:1.35}.tooltip-portal-arrow{background:var(--panel-bg);border:1px solid var(--glass-border);width:8px;height:8px;position:absolute}.tooltip-portal-arrow.is-top{border-top:none;border-left:none;top:100%;transform:translate(-50%,-5px)rotate(45deg)}.tooltip-portal-arrow.is-bottom{border-bottom:none;border-right:none;bottom:100%;transform:translate(-50%,5px)rotate(45deg)}.main{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:24px;display:grid}.main-col{flex-direction:column;gap:16px;min-width:0;display:flex}.main-col>.metrics-strip,.main-col>.context-panel{min-height:60px}.metrics-strip-review{border-color:#a78bfa73;animation:1.1s cubic-bezier(.22,.61,.36,1) metrics-review-pulse}.metrics-strip-review:hover{border-color:#a78bfaa6}.metrics-strip-details-btn{background:var(--glass-bg);border:1px solid var(--glass-border);width:26px;height:26px;color:var(--ink-mute);cursor:pointer;border-radius:6px;place-items:center;padding:0;transition:color .12s,background .12s,border-color .12s;display:inline-grid}.metrics-strip-details-btn:hover{color:var(--ink);background:var(--glass-bg-strong);border-color:color-mix(in srgb, var(--accent) 50%, var(--glass-border))}@keyframes metrics-review-pulse{0%{box-shadow:0 0 #a78bfa8c}60%{box-shadow:0 0 0 8px #a78bfa00}to{box-shadow:0 0 #a78bfa00}}.target-editor{font-family:var(--mono);color:var(--ink);cursor:pointer;background:0 0;border:1px dashed #0000;border-radius:6px;align-items:baseline;gap:6px;padding:2px 6px;font-size:13px;line-height:1.2;display:inline-flex}.target-editor-button:hover{background:#a78bfa14;border-color:#a78bfa73}.target-editor-active{background:#a78bfa14;border-style:solid;border-color:#a78bfa8c}.target-editor-num{color:var(--ink);font-size:18px}.target-editor-label{text-transform:uppercase;letter-spacing:.6px;color:var(--ink-mute);font-size:10px}.target-editor-input{width:3.5ch;color:var(--ink);font-family:var(--mono);background:0 0;border:none;outline:none;padding:0;font-size:18px;font-weight:700}.target-editor-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.target-editor-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.target-editor-input[type=number]{-moz-appearance:textfield}.stats-target-slot{justify-content:center;margin-top:4px;display:flex}.target-editor-step{border:1px solid var(--glass-border);background:var(--glass-bg);width:22px;height:22px;color:var(--ink-mute);font-family:var(--mono);cursor:pointer;border-radius:6px;place-items:center;padding:0;font-size:14px;line-height:1;transition:background .12s,color .12s,border-color .12s,opacity .18s,transform .18s cubic-bezier(.22,.61,.36,1);display:inline-grid}.target-editor-step:hover:not(:disabled){color:var(--ink);background:#a78bfa2e;border-color:#a78bfa80}.target-editor-step:disabled{color:#ffffff40;cursor:default;border-color:#ffffff1a}.target-editor-stepper{padding-left:30px;padding-right:30px;position:relative}.target-editor-stepper .target-editor-step{opacity:0;pointer-events:none;position:absolute;top:50%}.target-editor-stepper .target-editor-step-minus{left:2px;transform:translate(-6px,-50%)}.target-editor-stepper .target-editor-step-plus{right:2px;transform:translate(6px,-50%)}.target-editor-stepper:hover .target-editor-step,.target-editor-stepper:focus-within .target-editor-step{opacity:1;pointer-events:auto;transform:translateY(-50%)}.target-editor-floor-pip{color:#fbbf24d9;cursor:help;background:#fbbf241f;border:1px solid #fbbf2459;border-radius:50%;place-items:center;width:14px;height:14px;margin-left:4px;font-size:9px;transition:background .12s,border-color .12s;display:inline-grid}.target-editor-floor-pip:hover{background:#fbbf2438;border-color:#fbbf248c}.target-editor-stepper.is-below-floor .target-editor-num{color:var(--ink-mute)}.level-badge{font-family:var(--mono);color:var(--ink);-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#a78bfa38,#38bdf829);border:1px solid #a78bfa8c;border-radius:999px;align-items:center;gap:8px;padding:4px 12px 4px 6px;font-size:12px;display:inline-flex;box-shadow:0 0 0 1px #a78bfa2e,0 6px 14px #a78bfa26}.level-badge-emoji{background:#00000040;border:1px solid #ffffff14;border-radius:50%;flex-shrink:0;place-items:center;width:24px;height:24px;font-size:14px;display:inline-grid}.level-badge-glyph{letter-spacing:.04em;color:var(--ink);font-weight:700}.level-badge-title{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);font-size:10px}@media (width<=640px){.level-badge-title{display:none}}@media (width<=900px){.main{grid-template-columns:1fr}}.panel{background:var(--panel-bg);border:1px solid var(--glass-border);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);border-radius:18px}.stage{cursor:text;flex-direction:column;gap:18px;padding:24px 32px 18px;display:flex;position:relative}@media (width<=640px){.stage{gap:18px;padding:22px 18px 18px}}.hidden-input{opacity:0;pointer-events:none;caret-color:#0000;background:0 0;border:0;outline:none;width:1px;height:1px;font-size:16px;position:absolute;top:50%;left:50%}.stage-preview .stream-cursor-overlay{opacity:0}.stage-preview .stream{opacity:.85}.idle-pill{color:var(--ink);font-family:var(--mono);letter-spacing:.5px;text-transform:uppercase;pointer-events:none;background:#fbbf242e;border:1px solid #fbbf2473;border-radius:999px;padding:4px 10px;font-size:11px;animation:.2s idle-fade-in;position:absolute;top:14px;right:18px}@keyframes idle-fade-in{0%{opacity:0;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}.focus-veil{-webkit-backdrop-filter:blur(4px);color:var(--ink);font-family:var(--mono);letter-spacing:.6px;text-transform:uppercase;border-radius:inherit;cursor:pointer;z-index:10;background:#0b0b1473;border:none;place-items:center;font-size:14px;display:grid;position:absolute;inset:0}:root[data-theme=light] .focus-veil{background:#f5f4fb8c}.stream{font-family:var(--mono);font-size:var(--stream-size,28px);letter-spacing:.5px;color:var(--ink-mute);-webkit-user-select:none;user-select:none;min-height:calc(var(--stream-size,28px) * 1.7 * 3);word-break:break-word;line-height:1.7;position:relative}@media (width<=640px){.stream{min-height:140.8px;font-size:22px;line-height:1.6}}.stage.text-size-sm{--stream-size:22px;--kb-key:36px}.stage.text-size-md{--stream-size:28px;--kb-key:44px}.stage .stream+.kb{margin-top:14px}.ch{z-index:1;transition:color 80ms;position:relative}.ch-pending{color:var(--ink-mute)}.ch-pending.ch-in-word{color:var(--ink-soft)}.ch-masked{color:#e7e8f32e}.ch-correct{color:var(--ink)}.ch-wrong{color:var(--bad);background:#fb71852e;border-radius:3px}.ch-ghost{border-radius:3px;box-shadow:inset 0 0 0 1px #38bdf8cc}.ch-next-1{color:var(--ink)}.ch-next-2{color:var(--ink-soft)}.ch-next-3{color:var(--ink-soft);opacity:.85}.ch-current{color:var(--ink)}.stream-cursor-overlay{pointer-events:none;z-index:0;width:0;height:0;box-shadow:inset 0 -2px 0 var(--accent);will-change:transform, width, height;background:#a78bfa2e;border-radius:4px;transition:transform .15s cubic-bezier(.22,.61,.36,1),width .15s cubic-bezier(.22,.61,.36,1),height .15s cubic-bezier(.22,.61,.36,1);animation:1.1s ease-in-out infinite pulse-cursor;position:absolute;top:0;left:0}@keyframes pulse-cursor{0%,to{box-shadow:inset 0 -2px 0 var(--accent)}50%{box-shadow:inset 0 -2px #0000}}.stream-cursor-underline .stream-cursor-overlay{box-shadow:inset 0 -3px 0 var(--accent);background:0 0;animation:none}.stream-cursor-block .stream-cursor-overlay{background:var(--accent);box-shadow:none;animation:1.1s ease-in-out infinite pulse-block}.stream-cursor-block .ch-current{color:#0b0b14}@keyframes pulse-block{0%,to{opacity:1}50%{opacity:.55}}.hint{text-align:center;letter-spacing:.6px;color:var(--ink-mute);text-transform:uppercase;margin:0;font-size:12px}.stage-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px 16px;display:flex}.stage-foot .hint{text-align:left;flex:auto}.seg-sm{padding:2px}.seg-sm .seg-btn{letter-spacing:.3px;padding:4px 8px;font-size:10px}.seg-btn.seg-icon{justify-content:center;align-items:center;padding:4px 8px;line-height:0;display:inline-flex}@media (width<=560px){.stage-foot{justify-content:center}.stage-foot .hint{text-align:center;flex-basis:100%}}.progress-row{align-items:center;gap:10px;display:flex}.lesson-progress{background:#ffffff0d;border-radius:99px;flex:1;height:3px;margin:0 4px;position:relative;overflow:hidden}.time-remaining{font-family:var(--mono);color:var(--ink-mute);letter-spacing:.4px;text-align:right;min-width:28px;font-size:11px}.metro-pulse{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:.22s ease-out metro-flash;display:inline-block;box-shadow:0 0 6px #a78bfa8c}@keyframes metro-flash{0%{opacity:.2;transform:scale(.6)}35%{opacity:1;transform:scale(1.4)}to{opacity:.4;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.metro-pulse{opacity:.4;animation:none}}:root[data-theme=light] .lesson-progress{background:#14132a12}.lesson-progress-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:99px;height:100%;transition:width 90ms linear}.kb{--key:var(--kb-key,44px);border:1px solid var(--glass-border);background:#0000002e;border-radius:14px;flex-direction:column;align-self:center;gap:8px;max-width:100%;padding:10px;display:flex}:root[data-theme=light] .kb{background:#14132a0d}@media (width<=640px){.kb{display:none}}.finger-hint{justify-content:center;align-items:flex-end;gap:28px;margin-top:-4px;display:flex}@media (width<=640px){.finger-hint{display:none}}.hh-palm{fill:#ffffff0d;stroke:var(--glass-border);stroke-width:1px}.hh-finger{fill:#ffffff1a;stroke:var(--glass-border);stroke-width:1px;transition:fill .16s,stroke .16s,filter .16s}.hh-finger.on{fill:var(--accent);stroke:var(--accent);filter:drop-shadow(0 0 6px #a78bfa99)}.hh-label{font-family:var(--mono);fill:var(--ink-mute);letter-spacing:.5px;font-size:10px}:root[data-theme=light] .hh-palm{fill:#14132a0f}:root[data-theme=light] .hh-finger{fill:#14132a1a}.kb-row{gap:8px;display:flex}.kb-key{width:var(--key);height:var(--key);background:var(--glass-bg-strong);border:1px solid var(--glass-border);font-family:var(--mono);color:var(--ink-soft);border-radius:8px;place-items:center;font-size:14px;transition:background .12s,color .12s,transform 80ms,border-color .12s;display:grid;position:relative}.kb-key.kb-home:after{content:"";background:var(--ink-mute);opacity:.6;border-radius:2px;width:8px;height:2px;position:absolute;bottom:6px}.kb-locked{opacity:.25}.kb-key.kb-mod{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute);font-size:10px}.kb-key-shift{color:var(--ink-mute);opacity:.75;pointer-events:none;font-size:10px;line-height:1;position:absolute;top:4px;left:6px}.kb-next{color:var(--ink);background:linear-gradient(135deg,#a78bfa4d,#38bdf840);border-color:#a78bfa99;transform:translateY(-1px);box-shadow:0 0 0 1px #a78bfa66,0 6px 18px #a78bfa40}.kb-wrong{color:var(--ink);background:#fb718538;border-color:#fb71858c}.kb-space{width:calc(6 * var(--key))}.f-l5{box-shadow:inset 0 -2px #a78bfa59}.f-l4{box-shadow:inset 0 -2px #38bdf859}.f-l3{box-shadow:inset 0 -2px #4ade8059}.f-l2,.f-r2{box-shadow:inset 0 -2px #fbbf2459}.f-r3{box-shadow:inset 0 -2px #4ade8059}.f-r4{box-shadow:inset 0 -2px #38bdf859}.f-r5{box-shadow:inset 0 -2px #a78bfa59}.stats{flex-direction:column;gap:18px;padding:24px;display:flex}@media (width<=900px){.stats{padding:18px}}.practice-plan{background:linear-gradient(135deg,#a78bfa1a,#38bdf80f);border:1px solid #a78bfa40;border-radius:12px;flex-direction:column;gap:4px;padding:10px 12px;display:flex}.practice-plan-label{font-family:var(--mono);letter-spacing:.7px;text-transform:uppercase;color:var(--ink-mute);font-size:10px}.practice-plan-text{color:var(--ink);font-size:13px;line-height:1.5}.practice-plan-action{color:var(--ink);font-family:var(--mono);letter-spacing:.3px;cursor:pointer;background:#a78bfa26;border:1px solid #a78bfa80;border-radius:999px;align-self:flex-start;margin-top:4px;padding:4px 10px;font-size:11px;transition:background .12s}.practice-plan-action:hover{background:#a78bfa40}.coach-compact .coach-line{flex-wrap:wrap;align-items:baseline;gap:6px 8px;margin-top:2px;display:flex}.coach-compact .coach-headline{color:var(--ink-soft);font-size:11px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.4px}.coach-compact .coach-sep{color:var(--ink-mute);opacity:.55}.coach-compact .coach-detail{color:var(--ink);font-family:var(--mono);letter-spacing:.2px;font-size:14px;font-weight:600}.drill-chip{color:var(--ink);font-family:var(--mono);cursor:pointer;background:#38bdf826;border:1px solid #38bdf859;border-radius:999px;align-self:flex-start;align-items:center;gap:6px;margin-top:6px;padding:3px 8px;font-size:11px;transition:background .12s;display:inline-flex}.drill-chip:hover{background:#38bdf840}.drill-chip-label{opacity:.7;text-transform:uppercase;letter-spacing:.6px;font-size:10px}.drill-chip-value{font-weight:600}.drill-chip-x{opacity:.5;margin-left:2px}.stats-top{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.metric{text-align:center;border:1px solid var(--glass-border);background:#0000002e;border-radius:12px;padding:12px 8px}.metric-num{font-family:var(--mono);color:var(--ink);font-size:28px;line-height:1}.metric-num .pct{color:var(--ink-mute);margin-left:2px;font-size:14px}.metric-label{text-transform:uppercase;letter-spacing:.7px;color:var(--ink-mute);margin-top:6px;font-size:11px}.live-curve{opacity:.85;margin:4px auto 0;display:block}.wpm-history{width:100%;height:auto;display:block}.wpm-history-empty{color:var(--ink-mute);border:1px dashed var(--glass-border);border-radius:8px;place-items:center;font-size:12px;display:grid}.stats-h{text-transform:uppercase;letter-spacing:.7px;color:var(--ink-mute);margin:6px 0 4px;font-size:12px;font-weight:500}.stats-h-with-count{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.stats-count{color:var(--ink-soft);font-family:var(--mono);letter-spacing:.3px;text-transform:none;font-size:11px}.stats-h-toggle{cursor:pointer;width:100%;color:var(--ink-mute);background:0 0;border:none;align-items:center;gap:4px;margin:0;padding:0;display:flex}.stats-h-toggle .stats-h{text-align:left;flex:1;margin:6px 0 4px}.stats-h-chev{font-size:10px;transition:transform .16s;display:inline-block}.stats-h-toggle.collapsed .stats-h-chev{transform:rotate(-90deg)}.stats-h-toggle:hover{color:var(--ink-soft)}.stats-h-row{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.target-pill{font-family:var(--mono);color:var(--ink-soft);letter-spacing:.3px;background:#a78bfa24;border:1px solid #a78bfa4d;border-radius:999px;padding:2px 8px;font-size:11px}.stats-meta{letter-spacing:.5px;text-transform:uppercase;color:var(--ink-mute);justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;display:flex}.stats-share{color:var(--ink-mute);cursor:pointer;background:0 0;border:none;border-radius:6px;place-items:center;padding:4px;transition:color .12s,background .12s;display:inline-grid}.stats-share:hover:not(:disabled){color:var(--ink);background:var(--glass-bg-strong)}.stats-share:disabled{opacity:.3;cursor:not-allowed}.stats-h-toggle-row{align-items:center;gap:6px;display:flex}.stats-h-toggle-row .stats-h-toggle{flex:1}.stats-share-inline{padding:3px}.stats-meta strong{color:var(--ink-soft);font-family:var(--mono);letter-spacing:0;text-transform:none;margin-left:4px;font-weight:500}.ach-grid{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.ach-groups{flex-direction:column;gap:8px;margin-top:8px;display:flex}.ach-group{flex-direction:column;gap:2px;display:flex}.ach-group-label{font-family:var(--mono);letter-spacing:.7px;text-transform:uppercase;color:var(--ink-mute);font-size:10px}.ach-badge{border:1px solid var(--glass-border);filter:grayscale()opacity(.45);cursor:default;background:#ffffff0a;border-radius:8px;place-items:center;width:28px;height:28px;font-size:16px;transition:filter .2s,transform .12s,background .2s;display:inline-grid}.ach-badge.on{filter:none;background:linear-gradient(135deg,#a78bfa2e,#38bdf824);border-color:#a78bfa66}.ach-badge:hover{transform:translateY(-1px)}.ach-badge-locked{color:var(--ink-mute);filter:none;cursor:help;background:0 0;border-style:dashed;font-weight:600}.ach-tip{background:var(--panel-bg);color:var(--ink);border:1px solid var(--glass-border);font-family:var(--sans);letter-spacing:.15px;white-space:normal;pointer-events:none;z-index:100;width:max-content;max-width:min(320px,100vw - 16px);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(8px);border-radius:8px;padding:7px 11px;font-size:12px;font-weight:500;line-height:1.35}.ach-count{font-family:var(--mono);color:var(--ink-mute);margin-left:4px;font-weight:500}.celebration-emoji{font-size:80px;line-height:1;display:inline-block}.tod{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;width:100%;margin-top:6px;padding:6px 6px 0;display:block}:root[data-theme=light] .tod{background:#14132a0a}.tod-bar{fill:var(--accent);transition:fill .2s}.tod-bar-empty{fill:#ffffff0f}:root[data-theme=light] .tod-bar-empty{fill:#14132a1a}.tod-tick{font-family:var(--mono);fill:var(--ink-mute);font-size:7px}.dow{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;width:100%;margin-top:6px;padding:6px 6px 0;display:block}:root[data-theme=light] .dow{background:#14132a0a}.dow-bar{fill:var(--accent-2);transition:fill .2s}.dow-bar-empty{fill:#ffffff0f}:root[data-theme=light] .dow-bar-empty{fill:#14132a1a}.dow-tick{font-family:var(--mono);fill:var(--ink-mute);font-size:7px}.dow-empty{border:1px dashed var(--glass-border);color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;background:#0000002e;border-radius:8px;place-items:center;height:56px;margin-top:6px;font-size:11px;display:grid}:root[data-theme=light] .dow-empty{background:#14132a0a}.tod-empty{border:1px dashed var(--glass-border);color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;background:#0000002e;border-radius:8px;place-items:center;height:56px;margin-top:6px;font-size:11px;display:grid}.heatcal-wrap{position:relative}.heatcal{margin-top:6px;display:block}.heatcal rect{transition:fill .12s}.hc-empty{fill:#ffffff0a}.hc-l0{fill:#ffffff0f}.hc-l1{fill:#a78bfa47}.hc-l2{fill:#a78bfa80}.hc-l3{fill:#a78bfabf}.hc-l4{fill:var(--accent)}.hc-today{stroke:var(--accent-2);stroke-width:1.4px}.hc-clickable{cursor:pointer}.hc-selected{stroke:var(--ink);stroke-width:1.5px}.hc-axis{font-family:var(--mono);fill:var(--ink-mute);font-size:7px}:root[data-theme=light] .hc-empty{fill:#14132a0d}:root[data-theme=light] .hc-l0{fill:#14132a14}.heatcal-detail{border:1px solid var(--glass-border);font-family:var(--mono);color:var(--ink-soft);background:#0000002e;border-radius:10px;margin-top:8px;padding:8px 10px;font-size:12px}:root[data-theme=light] .heatcal-detail{background:#14132a0d}.heatcal-detail-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.heatcal-detail-row+.heatcal-detail-row{color:var(--ink-mute);margin-top:4px}.heatcal-date{color:var(--ink);letter-spacing:.3px}.heatcal-replay-list{flex-direction:column;gap:3px;margin:6px 0 0;padding:0;list-style:none;display:flex}.heatcal-replay-row{font-family:var(--mono);color:var(--ink-mute);justify-content:space-between;align-items:center;padding:3px 0;font-size:11px;display:flex}.heatcal-replay-btn{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-soft);cursor:pointer;border-radius:6px;padding:2px 8px;font-size:13px;line-height:1}.heatcal-replay-btn:hover{background:var(--glass-bg-strong);color:var(--ink)}.heatcal-close{color:var(--ink-mute);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:16px;line-height:1}.heatcal-close:hover{color:var(--ink)}.stage-strip{gap:4px;margin-top:8px;display:flex}.stage-pip{text-align:center;font-family:var(--mono);color:var(--ink-mute);border:1px solid var(--glass-border);background:#ffffff0a;border-radius:6px;flex:1;padding:4px 0;font-size:11px;transition:background .2s,color .2s,border-color .2s}.stage-pip.on{color:var(--ink);background:linear-gradient(135deg,#a78bfa38,#38bdf82e);border-color:#a78bfa73}.stage-pip.off{color:var(--ink-mute);opacity:.7}.stage-pip.clickable{cursor:pointer}.stage-pip.clickable:hover{border-color:#a78bfa8c}.stage-pip:disabled{cursor:default}.letter-list{flex-direction:column;gap:6px;max-height:360px;margin:0;padding:4px 0;list-style:none;display:flex;overflow-y:auto;-webkit-mask-image:linear-gradient(#0000 0,#000 12px calc(100% - 12px),#0000 100%);mask-image:linear-gradient(#0000 0,#000 12px calc(100% - 12px),#0000 100%)}.ms-chart{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;width:100%;margin-top:6px;padding:4px 6px;display:block}:root[data-theme=light] .ms-chart{background:#14132a0a}.ms-dot{fill:var(--accent)}.ms-dot.ms-stage{fill:var(--accent-2)}.ms-dot.ms-target{fill:var(--good)}.ms-empty{border:1px dashed var(--glass-border);color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;background:#0000002e;border-radius:8px;place-items:center;height:56px;margin-top:6px;font-size:11px;display:grid}:root[data-theme=light] .ms-empty{background:#14132a0a}.bigram-list{flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none;display:flex}.bigram-row{grid-template-columns:32px 1fr 28px;align-items:center;gap:8px;display:grid}.bigram-row-button{cursor:pointer;border-radius:6px;margin:0 -4px;padding:2px 4px;transition:background .12s}.bigram-row-button:hover{background:var(--glass-bg-strong)}.bigram-row-button.drilling{background:#a78bfa1a}.bigram-pair-btn{font:inherit;color:inherit;text-align:left;cursor:pointer;background:0 0;border:none;padding:0}.bigram-pair{font-family:var(--mono);color:var(--ink-soft);letter-spacing:1px;font-size:13px}.bigram-bar{background:#ffffff0d;border-radius:99px;height:6px;overflow:hidden}:root[data-theme=light] .bigram-bar{background:#14132a12}.bigram-fill{background:linear-gradient(90deg, var(--accent-warm), var(--bad));border-radius:99px;height:100%;transition:width .22s}.bigram-wpm{font-family:var(--mono);color:var(--ink-mute);text-align:right;font-size:11px}.bigram-empty{text-align:center;border:1px dashed var(--glass-border);color:var(--ink-mute);letter-spacing:.4px;text-transform:uppercase;background:#0000002e;border-radius:8px;margin-top:6px;padding:14px 8px;font-size:11px}:root[data-theme=light] .bigram-empty{background:#14132a0a}.finger-stats{border:1px solid var(--glass-border);background:#0000002e;border-radius:10px;flex-direction:column;gap:8px;margin-top:8px;padding:10px 8px 8px;display:flex}.finger-cols{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.hand-balance{border-bottom:1px dashed var(--glass-border);flex-direction:column;gap:4px;padding:4px 6px 6px;display:flex}.hand-bal-row{font-family:var(--mono);grid-template-columns:16px 1fr 28px;align-items:center;gap:8px;font-size:11px;display:grid}.hand-bal-side{color:var(--ink-mute);text-align:center}.hand-bal-bar{background:#ffffff0d;border-radius:99px;height:6px;overflow:hidden}:root[data-theme=light] .hand-bal-bar{background:#14132a12}.hand-bal-fill{background:linear-gradient(90deg, var(--accent-2), var(--accent));border-radius:99px;height:100%;transition:width .22s}.hand-bal-num{color:var(--ink-soft);text-align:right}:root[data-theme=light] .finger-stats{background:#14132a0a}.finger-col{flex-direction:column;align-items:center;gap:4px;display:flex}.finger-col-bar{background:#ffffff0f;border-radius:4px;align-items:flex-end;width:14px;height:56px;display:flex;position:relative;overflow:hidden}:root[data-theme=light] .finger-col-bar{background:#14132a14}.finger-col-fill{background:linear-gradient(180deg, var(--accent-2), var(--accent));border-radius:4px 4px 2px 2px;width:100%;transition:height .24s}.finger-col-fill.pass{background:linear-gradient(180deg, #38d399, var(--good))}.finger-col-num{font-family:var(--mono);color:var(--ink-soft);font-size:11px;line-height:1}.finger-col-label{font-family:var(--mono);color:var(--ink-mute);letter-spacing:.4px;font-size:10px}.letter-row{grid-template-columns:22px 1fr 32px 22px;align-items:center;gap:10px;display:grid}.letter-row.drilling{background:#a78bfa1a;border-radius:6px;margin:0 -4px;padding:2px 4px}.letter-row.drilling-bigram{margin-left:-6px;padding-left:6px;box-shadow:inset 2px 0 #38bdf8a6}.letter-drill{color:var(--ink-mute);border-radius:6px;padding:4px;font-size:12px;line-height:1;transition:color .12s,background .12s}.letter-row:hover .letter-drill{color:var(--ink-soft)}.letter-drill.on{color:var(--accent)}.letter-drill:hover{background:var(--glass-bg-strong)}.letter-key{font-family:var(--mono);text-align:center;color:var(--ink-soft);font-size:13px}.letter-bar{background:#ffffff0d;border-radius:99px;height:8px;position:relative;overflow:hidden}.letter-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));border-radius:99px;height:100%;transition:width .2s}.letter-fill.pass{background:linear-gradient(90deg, var(--good), #38d399)}.letter-row-locked{opacity:.45}.letter-row-locked .letter-key{color:var(--ink-mute);font-style:italic}.letter-row-locked .letter-bar{background:#ffffff08}.letter-row-locked .letter-wpm{font-size:11px}.letter-drill-placeholder{color:var(--ink-mute);opacity:.6;place-items:center;padding:4px;font-size:12px;line-height:1;display:inline-grid}.letter-wpm{font-family:var(--mono);color:var(--ink-mute);text-align:right;font-size:12px}.sparkline{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;width:100%;height:auto;margin-top:6px;display:block}.sparkline-empty{border:1px dashed var(--glass-border);color:var(--ink-mute);letter-spacing:.5px;text-transform:uppercase;background:#0000002e;border-radius:8px;place-items:center;margin-top:6px;font-size:11px;display:grid}.toast{background:var(--panel-bg);border:1px solid var(--glass-hi);font-family:var(--mono);color:var(--ink);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);z-index:40;pointer-events:none;border-radius:999px;align-items:baseline;gap:8px;padding:10px 18px;animation:.22s cubic-bezier(.2,.9,.3,1.4) toast-in,.28s ease-in 2.3s forwards toast-out;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%)}.toast-num{font-size:18px}.toast-unit{color:var(--ink-mute);text-transform:uppercase;letter-spacing:.5px;margin-left:2px;font-size:11px}.toast-sep{color:var(--ink-mute);margin:0 2px}.toast-badge{letter-spacing:.6px;background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0b0b14;text-transform:uppercase;border-radius:999px;margin-right:4px;padding:3px 8px;font-size:11px}.toast-best{border-color:#a78bfa8c;animation:.22s cubic-bezier(.2,.9,.3,1.4) toast-in,.28s ease-in 3.1s forwards toast-out;box-shadow:0 10px 40px #a78bfa59,0 0 0 1px #a78bfa66}.toast-clickable{pointer-events:auto;cursor:pointer;font-family:var(--mono)}.toast-clickable:hover{border-color:#a78bfa80}.tip-thanks{background:var(--panel-bg);border:1px solid var(--accent-warm);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(20px);color:var(--ink);font-family:var(--mono);z-index:50;border-radius:14px;align-items:center;gap:12px;padding:12px 18px 12px 16px;animation:.22s cubic-bezier(.2,.9,.3,1.4) toast-in;display:flex;position:fixed;top:24px;left:50%;transform:translate(-50%)}.tip-thanks-heart{color:var(--accent);font-size:22px;line-height:1}.tip-thanks-text{flex-direction:column;gap:2px;display:flex}.tip-thanks-title{font-size:14px}.tip-thanks-sub{color:var(--ink-mute);font-size:11px}.tip-thanks-close{color:var(--ink-mute);cursor:pointer;background:0 0;border:0;padding:0 4px;font-size:18px;line-height:1}.tip-thanks-close:hover{color:var(--ink)}.lesson-detail{width:min(520px,100vw - 32px)}.rhythm-chart{border:1px solid var(--glass-border);background:#0000002e;border-radius:8px;width:100%;margin-top:6px;padding:4px;display:block}:root[data-theme=light] .rhythm-chart{background:#14132a0a}.rhythm-baseline{stroke:var(--ink-mute);stroke-width:.6px;stroke-dasharray:3 3;opacity:.5}.mistake-text{font-family:var(--mono);border:1px solid var(--glass-border);color:var(--ink-soft);word-break:break-word;background:#0000002e;border-radius:8px;margin-top:6px;padding:8px 10px;font-size:14px;line-height:1.6}:root[data-theme=light] .mistake-text{background:#14132a0a}.mistake-ch{border-radius:2px;padding:1px 0}.sentence-list{flex-direction:column;gap:4px;margin:6px 0 0;padding:0;list-style:none;display:flex}.sentence-row{border-radius:8px;grid-template-columns:1fr 38px;align-items:baseline;gap:10px;padding:6px 10px;font-size:12px;line-height:1.45;display:grid}.sentence-row.sent-good{background:#4ade801a;border:1px solid #4ade8040}.sentence-row.sent-mid{background:#fbbf241a;border:1px solid #fbbf2440}.sentence-row.sent-bad{background:#fb71851a;border:1px solid #fb71854d}.sentence-text{color:var(--ink);font-family:var(--mono);word-break:break-word}.sentence-acc{font-family:var(--mono);text-align:right;color:var(--ink-soft);font-size:11px}.coach-hint{color:var(--ink);background:linear-gradient(135deg,#a78bfa1f,#38bdf81a);border:1px solid #a78bfa52;border-radius:10px;align-items:center;gap:10px;padding:10px 14px;font-size:13px;line-height:1.45;display:flex}.coach-hint-icon{font-size:14px;line-height:1}.detail-list{flex-direction:column;gap:6px;margin:8px 0 0;padding:0;list-style:none;display:flex}.detail-row{border:1px solid var(--glass-border);background:#0000002e;border-radius:10px;grid-template-columns:28px 1fr 64px 76px;align-items:baseline;gap:10px;padding:8px 12px;display:grid}:root[data-theme=light] .detail-row{background:#14132a0a}.detail-letter{font-family:var(--mono);color:var(--ink);font-size:16px}.detail-stat{font-family:var(--mono);color:var(--ink-soft);text-align:right;font-size:13px}.detail-unit{color:var(--ink-mute);text-transform:uppercase;letter-spacing:.5px;margin-left:2px;font-size:10px}.detail-errs{color:var(--bad)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}@keyframes toast-out{to{opacity:0;transform:translate(-50%,-6px)}}.quick-test{cursor:text;width:min(720px,100vw - 32px)}.qt-bar{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.qt-metric{text-align:center;border:1px solid var(--glass-border);background:#0000002e;border-radius:12px;justify-content:center;align-items:baseline;gap:4px;padding:14px 8px;display:flex}:root[data-theme=light] .qt-metric{background:#14132a0d}.qt-num{font-family:var(--mono);color:var(--ink);font-size:26px;line-height:1}.qt-unit{color:var(--ink-mute);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.qt-stage{max-height:140.8px;padding:4px 0;position:relative;overflow:hidden}.qt-stage .stream{min-height:140.8px;font-size:22px;line-height:1.6;transition:transform .22s}.qt-result{border-top:1px solid var(--glass-border);flex-direction:column;gap:6px;padding-top:8px;display:flex}.qt-result-line{font-family:var(--mono);justify-content:space-between;display:flex}.qt-result-line span{color:var(--ink-mute);text-transform:uppercase;letter-spacing:.5px;font-size:12px}.qt-result-line strong{color:var(--ink);font-weight:500}.qt-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.settings-tabs{align-self:flex-start}.modal-backdrop{-webkit-backdrop-filter:blur(6px);z-index:100;background:#0806128c;place-items:center;transition:background .32s,-webkit-backdrop-filter .32s,backdrop-filter .32s;animation:.16s fade-in;display:grid;position:fixed;inset:0}.modal-backdrop.peeking{-webkit-backdrop-filter:blur();background:#08061200}.modal.peeking{opacity:.15}.modal{transition:opacity .32s}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{flex-direction:column;gap:14px;width:min(440px,100vw - 32px);padding:22px 24px 18px;animation:.24s cubic-bezier(.2,.9,.3,1.4) pop;display:flex}.snippets-modal{width:min(640px,100vw - 32px)}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-header h2{color:var(--ink);letter-spacing:.2px;margin:0;font-size:16px;font-weight:600}.modal-footer{border-top:1px solid var(--glass-border);justify-content:flex-end;gap:8px;margin-top:4px;padding-top:4px;display:flex}.modal-footer-stack{flex-wrap:wrap}.onboarding-footer{justify-content:space-between;align-items:center}.onboarding-mute-link{color:var(--ink-mute);font-family:var(--sans);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:12px;transition:color .12s,background .12s}.onboarding-mute-link:hover,.onboarding-mute-link:focus-visible{color:var(--ink);background:var(--glass-bg-strong)}.setting-row{grid-template-columns:1fr auto;align-items:center;gap:14px;padding:8px 0;display:grid}.setting-row-stack{grid-template-columns:1fr;align-items:stretch}.setting-textarea{resize:vertical;border:1px solid var(--glass-border);width:100%;min-height:84px;color:var(--ink);font-family:var(--mono);background:#0000002e;border-radius:10px;outline:none;padding:10px 12px;font-size:12px;line-height:1.5}:root[data-theme=light] .setting-textarea{background:#14132a0d}.setting-textarea:focus{border-color:#a78bfa80;box-shadow:0 0 0 2px #a78bfa26}.snippet-bar{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.snippet-select{border:1px solid var(--glass-border);min-width:0;color:var(--ink);font-family:var(--mono);background:#0000002e;border-radius:10px;outline:none;flex:1;padding:8px 10px;font-size:12px}:root[data-theme=light] .snippet-select{background:#14132a0d}.snippet-empty{color:var(--ink-mute);letter-spacing:.3px;flex:1;font-size:12px}.snippet-name{border:1px solid var(--glass-border);width:100%;color:var(--ink);font-family:var(--mono);background:#0000002e;border-radius:10px;outline:none;margin-bottom:6px;padding:8px 10px;font-size:12px}:root[data-theme=light] .snippet-name{background:#14132a0d}.snippet-name:focus{border-color:#a78bfa80;box-shadow:0 0 0 2px #a78bfa26}.setting-label{flex-direction:column;gap:2px;display:flex}.setting-label>span:first-child{color:var(--ink);font-size:14px}.setting-help{color:var(--ink-mute);letter-spacing:.2px;font-size:11px}.setting-control{align-items:center;gap:10px;display:flex}.setting-value{font-family:var(--mono);color:var(--ink-soft);text-align:right;min-width:24px;font-size:13px}.setting-control input[type=range]{accent-color:var(--accent);width:140px}.switch{border:1px solid var(--glass-border);background:#ffffff14;border-radius:999px;width:40px;height:22px;padding:0;transition:background .16s;position:relative}.switch.on{background:linear-gradient(135deg, var(--accent), var(--accent-2));border-color:#0000}.switch-knob{background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .16s;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0000004d}.switch.on .switch-knob{transform:translate(18px)}.confetti{pointer-events:none;z-index:60;width:100%;height:100%;position:fixed;inset:0}.celebration{pointer-events:none;z-index:50;place-items:center;display:grid;position:fixed;inset:0}.celebration-persistent{pointer-events:auto;-webkit-backdrop-filter:blur(2px);background:#0f122052}.celebration-card{background:var(--panel-bg);border:1px solid var(--glass-hi);text-align:center;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(24px);border-radius:22px;padding:36px 60px;animation:.32s cubic-bezier(.2,.9,.3,1.4) pop;position:relative}.celebration-persistent .celebration-card{pointer-events:auto}.celebration-close{border:1px solid var(--glass-border);background:var(--glass-bg);width:28px;height:28px;color:var(--ink-mute);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:color .12s,background .12s,border-color .12s;display:inline-flex;position:absolute;top:10px;right:12px}.celebration-close:hover{color:var(--ink);background:var(--glass-bg-strong);border-color:var(--glass-hi)}.celebration-close:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.celebration-letter{font-family:var(--mono);background:linear-gradient(135deg, var(--accent), var(--accent-2));color:#0000;-webkit-background-clip:text;background-clip:text;font-size:92px;line-height:1}.celebration-text{letter-spacing:1.4px;text-transform:uppercase;color:var(--ink-mute);margin-top:8px;font-size:12px}@keyframes pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.celebration-unlock-list{flex-wrap:wrap;justify-content:center;gap:8px;margin-top:6px;display:flex}.celebration-unlock-chip{border:1px solid var(--glass-border);color:var(--ink);text-transform:none;letter-spacing:0;background:linear-gradient(135deg,#a78bfa2e,#60a5fa29);border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:inline-flex}.celebration-unlock-chip-emoji{font-size:18px;line-height:1}.celebration-unlock-chip-label{font-weight:500}.fresh-unlock,[data-fresh-unlock=true]{animation:1.8s ease-in-out infinite fresh-unlock-pulse;position:relative}@keyframes fresh-unlock-pulse{0%,to{box-shadow:0 0 #a78bfa8c,0 0 12px #60a5fa26}50%{box-shadow:0 0 0 6px #a78bfa00,0 0 18px 4px #60a5fa59}}.fresh-unlock-dot{background:linear-gradient(135deg, var(--accent), var(--accent-2));width:8px;height:8px;box-shadow:0 0 0 2px var(--bg,#14132a);pointer-events:none;border-radius:50%;position:absolute;top:-2px;right:-2px}.pomodoro{background:var(--glass-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);z-index:40;width:180px;font-family:var(--mono);border-radius:12px;padding:10px 12px;position:fixed;bottom:14px;right:14px;box-shadow:0 8px 24px #00000040}.pomodoro-row{align-items:baseline;gap:6px;display:flex}.pomodoro-phase{text-transform:uppercase;letter-spacing:.7px;color:var(--ink-mute);flex:1;font-size:10px}.pomodoro-time{color:var(--ink);font-size:18px}.pomodoro-count{color:var(--accent-2);font-size:11px}.pomodoro-bar{background:#ffffff0f;border-radius:999px;height:4px;margin-top:6px;overflow:hidden}.pomodoro-fill{background:linear-gradient(90deg, var(--accent), var(--accent-2));height:100%;transition:width .4s linear}.pomodoro-break .pomodoro-fill{background:linear-gradient(90deg,#38bdf8,#22d3ee)}.pomodoro-actions{gap:6px;margin-top:8px;display:flex}.pomodoro-btn{background:var(--glass-bg-strong);border:1px solid var(--glass-border);color:var(--ink-soft);cursor:pointer;border-radius:8px;flex:1;padding:4px 8px;font-family:inherit;font-size:11px;transition:color .12s,background .12s}.pomodoro-btn:hover{color:var(--ink);background:#ffffff1a}.pomodoro-btn-ghost{background:0 0}.auth-signin-btn{cursor:pointer;color:var(--ink);background:linear-gradient(135deg,#a78bfa1f,#60a5fa1a);border-color:#a78bfa6b;align-self:center;align-items:center;gap:8px;font-family:inherit;display:inline-flex;position:relative;overflow:hidden}.auth-signin-btn:hover:not(:disabled){background:linear-gradient(135deg,#a78bfa33,#60a5fa2e);border-color:#a78bfaa6}.auth-signin-btn:before{content:"";pointer-events:none;background:linear-gradient(110deg,#0000 0%,#ffffff38 50%,#0000 100%);width:40%;height:100%;animation:4.5s ease-in-out infinite auth-signin-shine;position:absolute;top:0;left:-60%}@keyframes auth-signin-shine{0%{opacity:0;left:-60%}15%{opacity:1}60%{opacity:1;left:120%}61%,to{opacity:0;left:120%}}@media (prefers-reduced-motion:reduce){.auth-signin-btn:before{animation:none;display:none}}.auth-signin-btn svg{z-index:1;flex-shrink:0;position:relative}.auth-signin-btn>span{z-index:1;position:relative}.auth-signin-sep{color:var(--ink-mute);opacity:.6;font-size:11px}.auth-signin-sub{color:var(--ink-mute);letter-spacing:.01em;font-size:11px}@keyframes auth-signin-pulse{0%,to{border-color:var(--glass-border);box-shadow:0 0 #a78bfa00}50%{border-color:#a78bfaa6;box-shadow:0 0 0 6px #a78bfa2e}}.auth-signin-pulse{animation:1.6s ease-in-out infinite auth-signin-pulse}@media (prefers-reduced-motion:reduce){.auth-signin-pulse{border-color:#a78bfaa6;animation:none}}.auth-menu{align-self:center;display:inline-flex;position:relative}.auth-avatar{border:1px solid var(--glass-border);background:var(--glass-bg);cursor:pointer;width:34px;height:34px;color:var(--ink);font-family:var(--mono);border-radius:50%;place-items:center;padding:0;font-size:14px;display:grid;overflow:hidden}.auth-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.auth-avatar-letter{line-height:1}.auth-menu-popover{background:var(--panel-bg);border:1px solid var(--glass-border);-webkit-backdrop-filter:blur(14px);z-index:50;border-radius:10px;min-width:180px;padding:6px;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #00000040}.auth-menu-email{color:var(--ink-mute);font-size:11px;font-family:var(--mono);word-break:break-all;border-bottom:1px solid var(--glass-border);margin-bottom:4px;padding:6px 10px}.auth-menu-item{text-align:left;cursor:pointer;width:100%;color:var(--ink-soft);background:0 0;border:none;border-radius:6px;padding:6px 10px;font-size:12px}.auth-menu-item:hover{background:var(--glass-bg-strong);color:var(--ink)}.topbar-brand-group{align-items:center;gap:18px;min-width:0;display:flex}.topbar-tabs{align-items:center;gap:8px;display:flex}.topbar-tab{background:var(--glass-bg-strong);border:1px solid var(--glass-border);font-family:var(--mono);letter-spacing:.4px;text-transform:lowercase;color:var(--ink-soft);cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 14px 9px;font-size:13px;font-weight:600;transition:color .12s,background .12s,transform 80ms,border-color .12s,box-shadow .12s;display:inline-flex;position:relative;box-shadow:inset 0 -2px #0000002e,0 1px #ffffff0d}.topbar-tab:hover{color:var(--ink);border-color:color-mix(in srgb, var(--accent) 45%, var(--glass-border));transform:translateY(-1px);box-shadow:inset 0 -2px #0000002e,0 4px 10px #00000026}.topbar-tab:active{transform:translateY(1px);box-shadow:inset 0 1px 3px #00000040}.topbar-tab-on{color:var(--ink);background:linear-gradient(135deg,#a78bfa4d,#38bdf840);border-color:#a78bfa99;transform:translateY(-1px);box-shadow:0 0 0 1px #a78bfa66,0 6px 18px #a78bfa40,inset 0 1px 2px #ffffff1f}.topbar-tab-on:hover{transform:translateY(-1px)}.topbar-tab .fresh-unlock-dot{position:absolute;top:3px;right:4px}@media (width<=640px){.topbar-brand-group{gap:10px}.topbar-tabs{gap:6px}.topbar-tab{letter-spacing:.3px;padding:6px 10px 7px;font-size:11px}}.main-library{display:block}.library-view{background:linear-gradient(180deg, var(--panel-bg) 0%, color-mix(in srgb, var(--panel-bg) 92%, #3a2814 8%) 100%);border:1px solid var(--glass-border);border-radius:14px;flex-direction:column;gap:18px;min-height:60vh;padding:22px 26px 20px;animation:.2s fade-in;display:flex;box-shadow:0 8px 30px #0000002e}.library-header{justify-content:space-between;align-items:center;display:flex}.library-title{color:var(--ink);letter-spacing:.3px;margin:0;font-size:18px;font-weight:700}.library-filters{align-items:center;gap:8px;display:flex}.library-filter{border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--ink-mute);font-family:var(--sans);cursor:pointer;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:500;transition:background .12s,color .12s,border-color .12s}.library-filter:hover{color:var(--ink)}.library-filter-on{background:var(--accent);color:#fff;border-color:var(--accent)}.library-empty,.library-opening-hint{text-align:center;color:var(--ink-mute);padding:32px 16px;font-size:13px}.library-opening-hint{padding:12px}.library-shelf{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;max-height:70vh;margin:0;padding:4px;list-style:none;display:grid;overflow-y:auto}.library-book{perspective:900px}.library-book-btn{border:1px solid var(--glass-border);background:var(--glass-bg);width:100%;color:var(--ink);cursor:pointer;text-align:left;font-family:var(--sans);border-radius:10px;grid-template-columns:96px 1fr;gap:14px;padding:12px;transition:background .14s,transform .2s,box-shadow .2s,opacity .22s;display:grid}.library-book-btn:hover{background:var(--glass-bg-strong);transform:translateY(-2px);box-shadow:0 14px 28px #00000047}.library-book-cover{background:var(--book-cover,#475569);border-radius:4px 8px 8px 4px;width:96px;height:140px;position:relative;overflow:hidden;box-shadow:inset 4px 0 #0000002e,inset -1px 0 #ffffff14,0 6px 12px #00000059}.library-book-spine-stripe{background:linear-gradient(#ffffff2e,#0000002e);width:6px;position:absolute;inset:0 auto 0 4px}.library-book-cover-inner{color:#ffffffeb;text-shadow:0 1px 2px #0000008c;flex-direction:column;justify-content:space-between;display:flex;position:absolute;inset:8px 8px 8px 16px}.library-book-cover-title{letter-spacing:.3px;-webkit-line-clamp:4;-webkit-box-orient:vertical;font-size:11px;font-weight:700;line-height:1.15;display:-webkit-box;overflow:hidden}.library-book-cover-author{opacity:.85;font-size:9px;font-style:italic}.library-book-cover-lang{letter-spacing:1px;background:#00000040;border-radius:3px;align-self:flex-end;padding:1px 5px;font-size:9px;font-weight:700}.library-book-bookmark{clip-path:polygon(0 0,100% 0,100% 100%,50% 80%,0 100%);filter:drop-shadow(0 2px 3px #00000059);background:linear-gradient(#dc2626,#991b1b);width:8px;height:24px;transition:top .2s;position:absolute;right:10px}.library-book-finished{color:#fde047;text-shadow:0 1px 2px #00000080;font-size:16px;position:absolute;top:6px;right:8px}.library-book-meta{flex-direction:column;gap:4px;min-width:0;display:flex}.library-book-meta-title{color:var(--ink);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;font-weight:600;line-height:1.2;display:-webkit-box;overflow:hidden}.library-book-meta-author{color:var(--ink-mute);font-size:11px;font-style:italic}.library-book-progress{background:var(--glass-bg-strong);border-radius:2px;height:4px;margin-top:auto;overflow:hidden}.library-book-progress-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .28s}.library-book-progress-label{color:var(--ink-mute);letter-spacing:.3px;font-size:10px}.library-reader{flex-direction:column;flex:1;gap:14px;min-height:0;animation:.36s cubic-bezier(.2,.85,.3,1.05) both lib-reader-rise;display:flex}@keyframes lib-reader-rise{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.reader-chapters{align-items:stretch;gap:6px;display:flex;position:relative}.reader-chapters-step{background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--ink-soft);width:32px;font-size:16px;font-family:var(--mono);cursor:pointer;border-radius:8px;transition:background .12s,color .12s,border-color .12s}.reader-chapters-step:hover:not(:disabled){color:var(--ink);background:var(--glass-bg-strong);border-color:color-mix(in srgb, var(--accent) 40%, var(--glass-border))}.reader-chapters-step:disabled{opacity:.35;cursor:default}.reader-chapters-current{background:var(--glass-bg);border:1px solid var(--glass-border);font-family:var(--sans);color:var(--ink);cursor:pointer;text-align:left;border-radius:8px;flex:1;justify-content:space-between;align-items:center;gap:10px;padding:8px 14px;font-size:13px;transition:background .12s,border-color .12s;display:flex}.reader-chapters-current:hover{background:var(--glass-bg-strong);border-color:color-mix(in srgb, var(--accent) 40%, var(--glass-border))}.reader-chapters-current-open{background:var(--glass-bg-strong);border-color:color-mix(in srgb, var(--accent) 55%, var(--glass-border))}.reader-chapters-label{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.reader-chapters-caret{color:var(--ink-mute);font-size:10px}.reader-chapters-popover{background:var(--panel-bg);border:1px solid var(--glass-border);z-index:20;border-radius:10px;max-height:320px;margin:0;padding:6px;list-style:none;animation:.16s fade-in;position:absolute;top:calc(100% + 6px);left:38px;right:38px;overflow-y:auto;box-shadow:0 14px 32px #00000052}.reader-chapter-item button{width:100%;color:var(--ink-soft);font-family:var(--sans);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;grid-template-columns:18px 32px 1fr;align-items:center;gap:6px;padding:7px 8px;font-size:12px;transition:background .1s,color .1s;display:grid}.reader-chapter-item button:hover{color:var(--ink);background:var(--glass-bg)}.reader-chapter-current button{color:var(--ink);background:color-mix(in srgb, var(--accent) 18%, transparent)}.reader-chapter-read button{color:var(--ink-mute)}.reader-chapter-mark{color:var(--accent);text-align:center;font-size:11px}.reader-chapter-num{font-family:var(--mono);color:var(--ink-mute);text-align:right;font-size:11px}.reader-chapter-read .reader-chapter-mark{color:var(--ink-mute)}.reader-chapter-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.library-reader-flash .library-reader-paragraph{animation:.22s lib-flash}@keyframes lib-flash{0%{background:color-mix(in srgb, var(--accent) 18%, transparent)}to{background:0 0}}.library-reader-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.library-reader-title-block{flex-direction:column;gap:4px;display:flex}.library-reader-back{align-self:flex-start;font-size:12px}.library-reader-title{color:var(--ink);letter-spacing:.3px;margin-top:6px;font-size:18px;font-weight:700}.library-reader-author{color:var(--ink-mute);font-size:12px;font-style:italic}.library-reader-stats{align-items:center;gap:14px;display:flex}.library-reader-stat{text-align:center;min-width:56px}.library-reader-stat-value{color:var(--ink);font-variant-numeric:tabular-nums;font-size:18px;font-weight:700}.library-reader-stat-label{text-transform:uppercase;letter-spacing:.6px;color:var(--ink-mute);font-size:10px}.library-reader-progress{background:var(--glass-bg-strong);border-radius:2px;height:4px;overflow:hidden}.library-reader-progress-fill{background:var(--accent);height:100%;transition:width .22s}.library-reader-stage{flex:1;justify-content:center;align-items:center;min-height:0;display:flex}.library-reader-paragraph{border:1px solid var(--glass-border);background:var(--glass-bg);border-radius:8px;width:100%;max-height:55vh;padding:18px 22px;overflow-y:auto}.library-reader-paragraph .stream{font-size:18px;line-height:1.7}.library-reader-end{flex-direction:column;align-items:center;gap:14px;padding:36px 16px;display:flex}.library-reader-end-msg{color:var(--ink);font-size:16px;font-weight:600}.library-reader-footer{color:var(--ink-mute);justify-content:space-between;align-items:center;font-size:11px;display:flex}.library-reader-hint{letter-spacing:.3px}.library-reader-restart{font-size:11px}@media (width<=600px){.library-view{padding:16px 14px 12px}.library-shelf{grid-template-columns:1fr;max-height:60vh}.library-reader-stats{gap:10px}.library-reader-stat-value,.library-reader-paragraph .stream{font-size:16px}}
