*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#181819;--bg2:#1f1f21;--bg3:#27272a;--border:#2e2e33;--sub:#3f3f46;--text-dim:#52525b;--text-muted:#71717a;--text:#d4d4d8;--text-hi:#f4f4f5;--accent:#e2b714;--accent2:#c8a010;--correct:#e2b714;--wrong:#ca4754;--extra:#ca4754;--char-dim:#4b5563;--font-mono:"Roboto Mono", "Courier New", monospace;--font-ui:system-ui, -apple-system, sans-serif;--radius:6px;--radius-lg:10px;--t:.15s ease;--word-fs:2rem;--word-lh:3rem;--word-gap-y:1rem;--row-h:calc(var(--word-lh) + var(--word-gap-y));--caret-h:calc(var(--word-lh) * .85)}html.light-mode{--bg:#f5f5f7;--bg2:#fff;--bg3:#e8e8ed;--border:#d2d2d7;--sub:#86868b;--text-dim:#a1a1a6;--text-muted:#6e6e73;--text:#1d1d1f;--text-hi:#000;--char-dim:#b0b0b8}html{font-size:16px}body{background:var(--bg);color:var(--text);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;min-height:100vh}button{cursor:pointer;background:0 0;border:none;font-family:inherit}input{font-family:inherit}.app{flex-direction:column;min-height:100vh;display:flex}.main{flex-direction:column;flex:1;justify-content:center;width:100%;max-width:1100px;margin:0 auto;padding:0 40px;display:flex}.header{z-index:100;background:var(--bg);border-bottom:none;position:sticky;top:0}.header-inner{align-items:center;gap:16px;max-width:1000px;height:56px;margin:0 auto;padding:0 40px;display:flex}.logo{flex-shrink:0;align-items:center;gap:4px;padding:4px 0;display:flex}.logo-svg{flex-shrink:0;margin-right:2px;display:block}.logo-text{color:var(--text-hi);letter-spacing:-.03em;font-size:1.375rem;font-weight:700;font-family:var(--font-mono)}.logo-dot{color:var(--accent);font-size:1.75rem;font-weight:700;line-height:1}.logo-accent{color:var(--accent);font-size:1.375rem;font-weight:700;font-family:var(--font-mono)}.header-nav{flex:1;align-items:center;gap:2px;display:flex}.hn-btn{border-radius:var(--radius);color:var(--text-muted);transition:color var(--t), background var(--t);align-items:center;gap:6px;padding:6px 12px;font-size:.8125rem;display:flex}.hn-btn:hover{color:var(--text);background:var(--bg3)}.hn-btn.active{color:var(--accent)}.header-right{align-items:center;margin-left:auto;display:flex}.sign-in-btn{border-radius:var(--radius);color:var(--text-muted);border:1px solid var(--border);transition:color var(--t), border-color var(--t), background var(--t);padding:7px 18px;font-size:.8125rem}.sign-in-btn:hover{color:var(--text);border-color:var(--sub);background:var(--bg3)}.user-menu-wrap{position:relative}.user-btn{border-radius:var(--radius);color:var(--text-muted);background:0 0;border:1px solid #0000;align-items:center;gap:8px;padding:8px 14px;font-size:.8125rem;transition:color .2s,border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.user-btn:before{content:"";background:linear-gradient(105deg,#0000 40%,#e2b71426 50%,#0000 60%);transition:transform .55s;position:absolute;inset:0;transform:translate(-100%)}.user-btn:hover{color:var(--accent);border-color:var(--accent);background:#e2b7140f}.user-btn:hover:before{transform:translate(100%)}.user-btn-avatar{background:var(--accent);width:22px;height:22px;color:var(--bg);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:.6875rem;font-weight:700;transition:box-shadow .2s;display:flex}.user-btn:hover .user-btn-avatar{box-shadow:0 0 0 2px #e2b71466}.user-btn-name{font-family:var(--font-mono);font-size:.8125rem}.user-btn-chevron{opacity:.5;transition:transform .2s}.user-btn-chevron.open{transform:rotate(180deg)}.user-dropdown{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:200;min-width:180px;padding:6px;animation:.15s ddIn;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 40px #00000080,0 0 0 1px #ffffff0a}@keyframes ddIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.ud-header{border-bottom:1px solid var(--border);margin-bottom:4px;padding:10px 12px 8px}.ud-avatar-row{align-items:center;gap:10px;display:flex}.ud-avatar-lg{background:var(--accent);width:32px;height:32px;color:var(--bg);border-radius:6px;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.ud-username{color:var(--text);font-size:.875rem;font-family:var(--font-mono)}.ud-joined{color:var(--text-dim);margin-top:1px;font-size:.6875rem}.ud-item{border-radius:var(--radius);width:100%;color:var(--text-muted);transition:background var(--t), color var(--t);align-items:center;gap:9px;padding:9px 12px;font-size:.8125rem;display:flex}.ud-item:hover{background:var(--bg3);color:var(--text)}.ud-item.danger:hover{color:var(--wrong);background:#ca475414}.ud-sep{background:var(--border);height:1px;margin:4px 0}.navbar-wrap{margin-top:14px}.navbar{flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;max-width:1000px;margin:0 auto;padding:0 40px;display:flex}.nav-group{background:var(--bg2);border:1px solid var(--border);border-radius:16px;align-items:center;gap:6px;padding:6px 12px;transition:all .2s;display:flex}.nav-group:hover{border-color:var(--sub)}.nb-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);font-size:.65rem}.nb-pill{color:var(--text-muted);border-radius:999px;padding:4px 10px;font-size:.75rem;transition:all .15s}.nb-pill:hover{background:var(--bg3);color:var(--text)}.nb-pill.active{color:var(--accent);background:#e2b7141f}.nb-num{font-family:var(--font-mono);color:var(--text-muted);border-radius:10px;padding:4px 8px;transition:all .15s}.nb-num:hover{background:var(--bg3);color:var(--text)}.nb-num.active{color:var(--accent);background:#e2b7141f}.nb-icon{color:var(--text-muted);justify-content:center;align-items:center;display:flex}.nb-icon:hover{color:var(--accent)}.nb-custom-input{background:var(--bg3);border:1px solid var(--border);width:70px;color:var(--text);border-radius:8px;padding:5px 8px}.nb-custom-go{background:var(--accent);color:#000;border-radius:8px;padding:5px 10px;font-weight:700}.counter-bar{align-items:center;gap:20px;min-height:auto;margin-bottom:28px;display:flex}.counter-num{font-size:3rem;font-family:var(--font-mono);color:var(--accent);font-weight:700;line-height:1;transition:color .3s}.counter-num.danger{color:var(--wrong);animation:.6s infinite alternate pulse}@keyframes pulse{to{opacity:.6}}.counter-of{color:var(--text-dim);margin-left:1px;font-size:1.1rem}.live-wpm{font-size:1.5rem;font-family:var(--font-mono);color:var(--accent);margin-left:auto;font-weight:700}.live-label{color:var(--accent);opacity:.6;margin-left:3px;font-size:.8rem}.typing-area{cursor:text;-webkit-user-select:none;user-select:none;max-width:1000px;margin:0 auto;padding:40px 0;position:relative;-webkit-mask-image:linear-gradient(#0000 0%,#000 10% 85%,#0000 100%);mask-image:linear-gradient(#0000 0%,#000 10% 85%,#0000 100%)}.words-viewport{height:calc(var(--row-h) * 3);transition:filter .15s;position:relative;overflow:hidden}.words-viewport.blurred{filter:blur(5px)}.words-container{will-change:transform;flex-wrap:wrap;align-content:flex-start;display:flex;position:relative}.word{margin-right:.6em;margin-bottom:var(--word-gap-y);font-size:var(--word-fs);font-family:var(--font-mono);line-height:var(--word-lh);flex-wrap:nowrap;align-items:baseline;display:inline-flex;position:relative}.word.wrong-word:after{content:"";background:var(--wrong);opacity:.7;border-radius:1px;height:2px;position:absolute;bottom:2px;left:-1px;right:-1px}.ch{line-height:var(--word-lh);transition:color 40ms;display:inline-block;position:relative}.ch.dim{color:var(--char-dim)}.ch.correct{color:var(--correct)}.ch.wrong{color:var(--wrong)}.ch.extra{color:var(--extra);font-size:calc(var(--word-fs) * .85);opacity:.8;vertical-align:baseline}.pipe-caret{width:3px;height:var(--caret-h);background:var(--accent);pointer-events:none;z-index:10;box-shadow:0 0 14px rgba(var(--accent-rgb,226,183,20), .8);border-radius:2px;transition:left 60ms cubic-bezier(.25,0,0,1),top;position:absolute}.ghost-input{opacity:0;pointer-events:none;width:0;height:0;position:absolute;top:0;left:0;overflow:hidden}.restart-row{justify-content:center;margin-top:28px;display:flex}.restart-btn{border-radius:var(--radius);color:var(--text-dim);transition:all var(--t);border:1px solid #0000;align-items:center;gap:6px;padding:9px 16px;font-size:.8125rem;display:flex}.restart-btn:hover{color:var(--text-muted);background:var(--bg3);border-color:var(--border)}.results-wrap{padding:28px 0 40px;animation:.28s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.results-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px;display:grid}.res-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--t);flex-direction:column;gap:8px;padding:20px;display:flex}.res-block:hover{border-color:var(--sub)}.res-block.primary{background:#e2b7140d;border-color:#e2b71480}.res-label{color:var(--text-dim);letter-spacing:.06em;align-items:center;gap:5px;font-size:.6875rem;display:flex}.res-val{font-size:2.75rem;font-family:var(--font-mono);color:var(--text-hi);font-weight:700;line-height:1}.res-block.primary .res-val{color:var(--accent)}.res-unit{color:var(--text-muted);margin-left:2px;font-size:1.25rem}.res-saved{color:var(--accent);opacity:.8;align-items:center;gap:6px;margin-bottom:20px;font-size:.75rem;display:flex}.res-actions{align-items:center;gap:16px;display:flex}.res-restart{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);transition:all var(--t);align-items:center;gap:8px;padding:10px 24px;font-size:.875rem;display:flex}.res-restart:hover{border-color:var(--accent);color:var(--accent)}.res-hint{color:var(--text-dim);font-size:.75rem}kbd{background:var(--bg3);border:1px solid var(--border);font-size:.6875rem;font-family:var(--font-mono);color:var(--text-muted);border-radius:4px;padding:2px 6px;display:inline-block}.page-wrap{padding:36px 0 60px;animation:.2s fadeUp}.page-header{color:var(--text-hi);align-items:center;gap:10px;margin-bottom:24px;display:flex}.page-header h2{font-size:1.25rem;font-weight:600;font-family:var(--font-mono)}.empty-state{color:var(--text-dim);text-align:center;font-size:.875rem;font-family:var(--font-mono);padding:60px 0}.lb-table{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.lb-head{color:var(--text-dim);letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg3);grid-template-columns:48px 1fr 80px 80px;padding:11px 20px;font-size:.6875rem;display:grid}.lb-head.hist-head{grid-template-columns:1fr 70px 70px 70px 130px}.lb-row{border-bottom:1px solid var(--border);transition:background var(--t);grid-template-columns:48px 1fr 80px 80px;align-items:center;padding:13px 20px;font-size:.875rem;display:grid}.lb-row:last-child{border-bottom:none}.lb-row:hover{background:var(--bg3)}.lb-row.lb-me{background:#e2b7140d}.lb-row.hist-row{grid-template-columns:1fr 70px 70px 70px 130px}.lb-rank{font-family:var(--font-mono);color:var(--text-dim);align-items:center;font-size:.8125rem;display:flex}.lb-user{color:var(--text);font-family:var(--font-mono);font-size:.8125rem}.lb-wpm{font-family:var(--font-mono);color:var(--accent);font-weight:600}.lb-acc{font-family:var(--font-mono);color:var(--text-muted)}.lb-mode{font-family:var(--font-mono);color:var(--text-dim);font-size:.75rem}.stats-cards{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:6px;padding:16px 20px;display:flex}.sc-label{color:var(--text-dim);letter-spacing:.06em;font-size:.6875rem}.sc-val{font-size:1.875rem;font-family:var(--font-mono);color:var(--text-hi);font-weight:700;line-height:1}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000a6;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);width:340px;padding:28px;animation:.18s slideIn;position:relative;box-shadow:0 24px 64px #000000b3,0 0 0 1px #ffffff0a}@keyframes slideIn{0%{opacity:0;transform:scale(.96)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-close{color:var(--text-dim);border-radius:var(--radius);transition:color var(--t);padding:4px;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--text)}.modal-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:24px;display:flex}.modal-tabs button{color:var(--text-muted);transition:all var(--t);border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:.875rem}.modal-tabs button:hover{color:var(--text)}.modal-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.modal-form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-dim);letter-spacing:.04em;font-size:.75rem}.field input{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);transition:border-color var(--t);font-size:.875rem;font-family:var(--font-mono);outline:none;padding:10px 12px}.field input:focus{border-color:var(--accent)}.field input::placeholder{color:var(--text-dim)}.modal-error{color:var(--wrong);border-radius:var(--radius);background:#ca47541a;border:1px solid #ca475433;padding:8px 12px;font-size:.8125rem}.modal-submit{background:var(--accent);color:var(--bg);border-radius:var(--radius);transition:background var(--t), opacity var(--t);margin-top:4px;padding:11px;font-size:.875rem;font-weight:700}.modal-submit:hover:not(:disabled){background:var(--accent2)}.modal-submit:disabled{opacity:.5;cursor:not-allowed}.footer{border-top:1px solid var(--border);width:100%;max-width:1000px;font-family:var(--font-mono);letter-spacing:.04em;flex-direction:row;justify-content:center;align-items:center;gap:24px;margin:0 auto;padding:20px 40px;font-size:.6875rem;display:flex}.footer-right{align-items:center;gap:12px;display:flex}.footer-link{color:var(--text-muted);transition:color var(--t);align-items:center;gap:4px;text-decoration:none;display:inline-flex}.footer-link:hover{color:var(--accent)}.footer-dot{color:var(--text-dim);-webkit-user-select:none;user-select:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--sub)}::selection{background:#e2b71433}@media (width<=680px){:root{--word-fs:1.2rem;--word-lh:1.85rem;--word-gap-y:.6rem}.main{padding:0 20px 60px}.header-inner,.navbar{padding:0 20px}.results-grid,.stats-cards{grid-template-columns:repeat(2,1fr)}.header-nav span{display:none}.res-val{font-size:2rem}.lb-head,.lb-row{grid-template-columns:36px 1fr 64px 64px;font-size:.75rem}.footer{text-align:center;flex-direction:column;gap:12px;padding:20px}}.theme-dot{background:var(--dot-color);cursor:pointer;border:2px solid #0000;border-radius:50%;width:16px;height:16px;transition:border-color .15s,transform .15s}.theme-dot:hover{transform:scale(1.2)}.theme-dot.active{border-color:var(--text-hi)}.pb-badge{background:rgba(var(--accent-rgb,226,183,20), .1);border:1px solid rgba(var(--accent-rgb,226,183,20), .3);border-radius:var(--radius);color:var(--accent);font-size:.875rem;font-family:var(--font-mono);align-items:center;gap:8px;margin-bottom:20px;padding:8px 16px;animation:.3s fadeUp;display:inline-flex}.chars-row{font-family:var(--font-mono);align-items:center;gap:6px;margin-bottom:20px;font-size:.875rem;display:flex}.char-stat{font-weight:700}.char-stat.correct{color:var(--correct)}.char-stat.wrong{color:var(--wrong)}.char-stat.extra{color:var(--extra)}.char-stat.missed{color:var(--text-dim)}.char-labels{color:var(--text-dim);margin-left:8px;font-size:.75rem}.wpm-delta{font-family:var(--font-mono);align-items:center;gap:6px;margin-bottom:16px;font-size:.8125rem;display:flex}.wpm-delta.up{color:var(--correct)}.wpm-delta.down{color:var(--wrong)}.chart-section{margin-bottom:36px}.chart-title{font-size:.8125rem;font-family:var(--font-mono);color:var(--text-muted);letter-spacing:.04em;margin-bottom:16px}.custom-tooltip{box-shadow:0 8px 24px #0006;background:var(--bg2)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;padding:10px 14px!important}.custom-tooltip .label{color:var(--text-dim);margin-bottom:4px;font-size:.6875rem}.custom-tooltip .value{color:var(--accent);font-size:1rem;font-weight:700;font-family:var(--font-mono)}.profile-header{align-items:center;gap:20px;margin-bottom:32px;display:flex}.profile-avatar{background:var(--accent);width:64px;height:64px;color:var(--bg);font-size:1.5rem;font-weight:700;font-family:var(--font-mono);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-name{color:var(--text-hi);font-size:1.5rem;font-weight:700;font-family:var(--font-mono)}.profile-email{color:var(--text-muted);margin-top:2px;font-size:.8125rem}.profile-joined{color:var(--text-dim);margin-top:2px;font-size:.75rem}.loading-state{color:var(--text-dim);font-family:var(--font-mono);justify-content:center;padding:60px 0;font-size:.875rem;display:flex}.lb-head.lb-expanded,.lb-row.lb-expanded{grid-template-columns:48px 1fr 90px 90px 80px}.lb-tests{font-family:var(--font-mono);color:var(--text-muted);font-size:.8125rem}.avatar-img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.profile-avatar-wrap{flex-direction:column;flex-shrink:0;align-items:center;gap:8px;display:flex}.avatar-upload-label{font-size:.6875rem;font-family:var(--font-mono);color:var(--text-muted);cursor:pointer;border:1px solid var(--border);transition:color var(--t), border-color var(--t), background var(--t);border-radius:4px;padding:4px 8px}.avatar-upload-label:hover{color:var(--text);border-color:var(--sub);background:var(--bg3)}.guest-badge{font-size:.6875rem;font-family:var(--font-mono);color:var(--text-muted);border:1px solid var(--border);border-radius:4px;margin-left:10px;padding:2px 6px}.user-btn-avatar.guest-avatar{background:var(--bg3);color:var(--text-muted);border:1px solid var(--border)}.focus-error-overlay{z-index:50;cursor:pointer;background:0 0;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:absolute;inset:0}.focus-error-text{font-family:var(--font-mono);color:var(--text);align-items:center;gap:8px;font-size:.875rem;display:flex}.caps-lock-indicator{z-index:60;background:rgba(var(--accent-rgb,226,183,20), .1);border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;box-shadow:0 4px 12px rgba(var(--accent-rgb,226,183,20), .15);border-radius:8px;align-items:center;gap:8px;padding:6px 14px;font-size:.72rem;font-weight:700;animation:.1s ease-out clFadeIn;display:flex;position:absolute;top:10px;left:50%;transform:translate(-50%)}@keyframes clFadeIn{0%{opacity:0}to{opacity:1}}.caps-lock-dot{background:var(--accent);border-radius:50%;width:6px;height:6px;display:inline-block}.password-input-wrap{align-items:center;width:100%;display:flex;position:relative}.password-input-wrap input{width:100%;padding-right:40px!important}.password-toggle-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius);transition:color var(--t);justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:12px}.password-toggle-btn:hover{color:var(--text)}
