:root{--bg:#11120f;--panel:#181a16;--panel2:#20221d;--text:#f1f0e8;--muted:#85887e;--accent:#d9ff59;--accent2:#a9cc31;--error:#ff6b61;--line:#2a2d26;--shadow:0 24px 80px #0005}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--bg);color:var(--text);font-family:Manrope,sans-serif;min-height:100vh;transition:.3s}.grain{position:fixed;inset:0;pointer-events:none;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E")}.topbar{height:80px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 max(28px,calc((100vw - 1180px)/2));position:relative;z-index:5}.brand{display:flex;align-items:center;gap:12px;color:var(--text);text-decoration:none;font-weight:800;font-size:19px;letter-spacing:-.5px}.brand-mark{width:30px;height:30px;border-radius:8px;background:var(--accent);display:flex;gap:2px;align-items:end;justify-content:center;padding:7px}.brand-mark i{display:block;width:3px;background:#151712;border-radius:3px}.brand-mark i:nth-child(1){height:8px}.brand-mark i:nth-child(2){height:15px}.brand-mark i:nth-child(3){height:11px}nav{display:flex;gap:5px;background:var(--panel);padding:4px;border-radius:10px}.nav-btn{border:0;background:transparent;color:var(--muted);font:600 13px Manrope;padding:8px 18px;border-radius:7px;cursor:pointer}.nav-btn.active{background:var(--panel2);color:var(--text)}button{font-family:inherit}.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--panel);color:var(--muted);display:grid;place-items:center;cursor:pointer}.icon-btn svg{width:18px;fill:none;stroke:currentColor;stroke-width:1.6}.icon-btn:hover{color:var(--accent);border-color:var(--accent2)}main{width:min(1180px,calc(100% - 56px));margin:0 auto;padding:64px 0 100px}.hero{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px}.eyebrow{text-transform:uppercase;color:var(--accent);font-weight:700;letter-spacing:2.2px;font-size:10px;margin:0 0 15px}.hero h1,.history-head h1{font-size:clamp(40px,5vw,66px);letter-spacing:-4px;line-height:.98;margin:0;font-weight:700}.hero h1 em{font-family:Georgia,serif;font-weight:400;color:var(--accent)}.subtitle{color:var(--muted);font-size:14px;margin:17px 0 0}.mode-card>span{display:block;text-transform:uppercase;font-size:9px;letter-spacing:1.5px;color:var(--muted);font-weight:700;margin:0 0 9px 4px}.mode-switch{display:flex;padding:4px;background:var(--panel);border:1px solid var(--line);border-radius:11px}.mode-switch button{border:0;background:transparent;color:var(--muted);font-weight:600;font-size:12px;padding:9px 14px;border-radius:7px;cursor:pointer}.mode-switch button.active{background:var(--accent);color:#171913}.test-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}.stats-row{display:flex;padding:22px 30px;border-bottom:1px solid var(--line)}.stat{min-width:110px;border-right:1px solid var(--line);margin-right:26px}.stat span{display:block;font:500 24px DM Mono;color:var(--text)}.stat label{display:block;color:var(--muted);text-transform:uppercase;letter-spacing:1.4px;font-size:8px;margin-top:4px}.stat.primary span{color:var(--accent)}.stat.timer{border:0;margin-left:auto;margin-right:0;text-align:right}.progress-track{height:2px;background:var(--line)}.progress-track div{width:0;height:100%;background:var(--accent);box-shadow:0 0 12px var(--accent);transition:width .15s}.passage-wrap{position:relative;padding:52px 54px 46px;min-height:245px;cursor:text}.passage{font:400 clamp(21px,2.1vw,29px)/1.8 DM Mono;color:#4d5048;letter-spacing:.1px;user-select:none}.passage .correct{color:var(--text)}.passage .incorrect{color:var(--error);background:#ff6b6115;border-radius:2px}.passage .current{position:relative}.passage .current:before{content:"";position:absolute;left:-1px;top:3px;width:2px;height:1.25em;background:var(--accent);animation:blink .9s infinite;box-shadow:0 0 8px var(--accent)}@keyframes blink{50%{opacity:.15}}#typingInput{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px}.start-overlay{position:absolute;inset:0;background:#181a16e8;backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:9px;color:var(--muted);font-size:11px;transition:.25s}.start-overlay.hidden{opacity:0;pointer-events:none}.start-key{color:#171913;background:var(--accent);padding:10px 18px;border-radius:20px;font-weight:800;text-transform:uppercase;letter-spacing:1.2px;font-size:9px;box-shadow:0 0 25px #d9ff5930}.test-footer{border-top:1px solid var(--line);padding:15px 30px;display:flex;align-items:center;justify-content:space-between;color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:1px}.test-footer>div{display:flex;align-items:center;gap:22px}.streak{color:var(--accent);font-weight:700}.restart-btn{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:10px;text-transform:uppercase;letter-spacing:1px}.restart-btn:hover{color:var(--text)}kbd{border:1px solid var(--line);background:var(--panel2);border-radius:4px;padding:2px 5px;font:500 9px DM Mono;color:var(--muted)}.keyboard-section{margin-top:38px}.section-heading{display:flex;justify-content:space-between;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted);font-size:9px;font-weight:700;margin:0 4px 13px}.status-dot:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--accent);box-shadow:0 0 7px var(--accent);margin-right:7px}.keyboard{background:var(--panel);border:1px solid var(--line);padding:20px;border-radius:16px;display:flex;flex-direction:column;gap:7px}.key-row{display:flex;gap:7px;justify-content:center}.key{height:48px;flex:1;max-width:72px;min-width:34px;background:var(--panel2);border:1px solid #30332c;border-bottom-color:#3a3e34;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#72766b;font:500 12px DM Mono;box-shadow:0 3px 0 #0b0c0a;transition:.08s}.key.wide{flex:1.45;max-width:105px}.key.space{flex:5;max-width:360px}.key.active{transform:translateY(3px);box-shadow:0 0 18px #d9ff5940;border-color:var(--accent);background:var(--accent);color:#181a14}.key.wrong{background:var(--error);border-color:var(--error);color:white;box-shadow:0 0 18px #ff6b6140}.pop{position:absolute;width:5px;height:5px;background:var(--accent);border-radius:50%;animation:pop .55s ease-out forwards;pointer-events:none}@keyframes pop{to{transform:translate(var(--x),var(--y)) scale(0);opacity:0}}.history-view{min-height:600px}.hidden{display:none!important}.history-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:42px}.text-btn{border:0;background:none;color:var(--muted);cursor:pointer}.text-btn:hover{color:var(--error)}.history-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:28px}.summary-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:24px}.summary-card strong{display:block;font:500 34px DM Mono;color:var(--accent)}.summary-card span{font-size:9px;text-transform:uppercase;letter-spacing:1.4px;color:var(--muted)}.history-list{display:flex;flex-direction:column;gap:8px}.history-item{display:grid;grid-template-columns:1.5fr repeat(4,1fr);align-items:center;background:var(--panel);border:1px solid var(--line);padding:18px 22px;border-radius:12px}.history-item time{color:var(--muted);font-size:12px}.history-item span{font:500 14px DM Mono}.history-item b{color:var(--accent);font:500 19px DM Mono}.empty{text-align:center;padding:90px 20px;border:1px dashed var(--line);border-radius:16px;color:var(--muted)}.modal-backdrop,.drawer-backdrop{position:fixed;inset:0;background:#090a08cc;z-index:20;display:grid;place-items:center;backdrop-filter:blur(8px);padding:20px}.modal{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow)}.results-modal{width:min(480px,100%);padding:42px;text-align:center}.close-btn{position:absolute;right:18px;top:16px;background:none;border:0;color:var(--muted);font-size:28px;cursor:pointer}.results-modal h2{font-size:30px;letter-spacing:-1.5px;margin:0 0 28px}.result-score{display:flex;align-items:baseline;justify-content:center;position:relative}.result-score strong{font:500 82px DM Mono;color:var(--accent);letter-spacing:-7px}.result-score>span{font-size:11px;color:var(--muted);margin-left:12px}.result-score b{position:absolute;top:0;right:5px;background:var(--accent);color:#171913;font-size:8px;text-transform:uppercase;padding:5px 8px;border-radius:8px}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:12px;margin:28px 0;overflow:hidden}.result-grid div{padding:16px 5px;border-right:1px solid var(--line)}.result-grid div:last-child{border:0}.result-grid span{display:block;font:500 17px DM Mono}.result-grid label{color:var(--muted);text-transform:uppercase;font-size:7px;letter-spacing:1px}.primary-btn,.secondary-btn{width:100%;padding:14px;border-radius:9px;cursor:pointer;font-weight:700}.primary-btn{background:var(--accent);border:0;color:#171913}.primary-btn span{float:right}.secondary-btn{margin-top:8px;background:transparent;border:1px solid var(--line);color:var(--muted)}.drawer-backdrop{place-items:stretch end;padding:0}.drawer{background:var(--panel);border-left:1px solid var(--line);width:min(410px,100%);padding:36px;box-shadow:var(--shadow);animation:slide .25s ease-out}.drawer-head{position:relative;margin-bottom:34px}.drawer-head h2{font-size:34px;margin:0}.setting{display:flex;align-items:center;justify-content:space-between;padding:19px 0;border-bottom:1px solid var(--line);position:relative}.setting strong{display:block;font-size:13px}.setting small{color:var(--muted);font-size:10px}.setting select{background:var(--panel2);border:1px solid var(--line);color:var(--text);padding:8px;border-radius:7px}.setting input{position:absolute;opacity:0}.toggle{display:block;width:38px;height:21px;border-radius:20px;background:#34372f;position:relative;transition:.2s}.toggle:after{content:"";position:absolute;width:15px;height:15px;left:3px;top:3px;border-radius:50%;background:#777b70;transition:.2s}.setting input:checked+.toggle{background:var(--accent)}.setting input:checked+.toggle:after{transform:translateX(17px);background:#171913}.shortcut-note{color:var(--muted);font-size:11px;margin-top:30px}.shake{animation:shake .18s}@keyframes shake{25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}@keyframes slide{from{transform:translateX(100%)}}body.reduced-motion *{animation:none!important;transition:none!important}
html[data-theme=light]{--bg:#f3f1e8;--panel:#fffef8;--panel2:#ebe9df;--text:#1d201a;--muted:#72766b;--line:#dcdbd1;--shadow:0 24px 80px #65654a20}.start-overlay{background:color-mix(in srgb,var(--panel) 92%,transparent)}
html[data-theme=forest]{--bg:#0c1712;--panel:#122119;--panel2:#1a2c22;--text:#edf5ed;--muted:#829889;--accent:#9eff8c;--accent2:#55ba65;--line:#24382b}
@media(max-width:760px){.topbar{height:68px;padding:0 18px}.topbar nav{display:none}main{width:calc(100% - 28px);padding:38px 0 70px}.hero{display:block}.hero h1{letter-spacing:-2.5px}.mode-card{margin-top:30px}.mode-switch button{flex:1;padding:9px 8px}.mode-switch{width:100%}.stats-row{padding:16px}.stat{min-width:0;flex:1;margin:0 10px 0 0}.stat span{font-size:18px}.passage-wrap{padding:35px 23px;min-height:230px}.passage{font-size:20px;line-height:1.7}.test-footer{padding:13px 16px}.restart-btn kbd{display:none}.keyboard{overflow:hidden;padding:10px;gap:5px}.key-row{gap:4px}.key{height:36px;min-width:0;font-size:8px;border-radius:5px}.key.wide{max-width:65px}.keyboard-section{margin-top:24px}.history-summary{grid-template-columns:1fr}.history-head{align-items:flex-start}.history-item{grid-template-columns:1.2fr repeat(2,1fr);gap:10px}.history-item span:nth-last-child(-n+2){display:none}.results-modal{padding:38px 20px}.result-score strong{font-size:68px}.result-grid{grid-template-columns:repeat(2,1fr)}.result-grid div:nth-child(2){border-right:0}.result-grid div:nth-child(-n+2){border-bottom:1px solid var(--line)}} 
