*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #ffffff;--text: #000000;--text-muted: #888888;--border: #e0e0e0;--correct: #000000;--incorrect: #cc0000;--font: "Roboto", sans-serif;--font-mono: "Roboto Mono", monospace}[data-theme=dark]{--bg: #000000;--text: #ffffff;--text-muted: #888888;--border: #333333;--correct: #ffffff;--incorrect: #ff4444}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;transition:background .2s,color .2s}.app{min-height:100vh;display:flex;flex-direction:column;max-width:900px;margin:0 auto;padding:2rem}.header{display:flex;justify-content:space-between;align-items:center;padding-bottom:2rem;border-bottom:1px solid var(--border);margin-bottom:2rem}.logo h1{font-size:1.25rem;font-weight:500;letter-spacing:-.02em}.logo .tagline{display:none}.nav,.user-info{display:flex;align-items:center;gap:1rem}.user-info .username{color:var(--text-muted)}.auth-buttons{display:flex;gap:.5rem}button{font-family:var(--font)}.btn-primary,.btn-secondary{padding:.5rem 1rem;border:1px solid var(--text);border-radius:0;font-size:.875rem;cursor:pointer;transition:all .15s;background:transparent;color:var(--text)}.btn-primary{background:var(--text);color:var(--bg)}.btn-primary:hover{opacity:.8}.btn-secondary:hover{background:var(--text);color:var(--bg)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.theme-toggle{background:none;border:none;padding:.5rem;cursor:pointer;color:var(--text);font-size:1rem}.main{flex:1;display:grid;grid-template-columns:1fr 240px;gap:3rem}.game-section{display:flex;flex-direction:column;min-width:0}.mode-toggle{display:flex;gap:.5rem;margin-bottom:1.5rem}.mode-toggle button{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.375rem .75rem;font-size:.75rem;cursor:pointer;transition:all .15s;font-family:var(--font)}.mode-toggle button:hover{border-color:var(--text);color:var(--text)}.mode-toggle button.active{background:var(--text);color:var(--bg);border-color:var(--text)}.typing-test{flex:1}.quote-display{margin-bottom:2rem;max-width:100%}.quote-text{font-family:var(--font-mono);font-size:1.125rem;line-height:2;color:var(--text-muted);word-break:normal;overflow-wrap:normal;white-space:normal}.quote-text .correct{color:var(--correct)}.quote-text .incorrect{color:var(--incorrect);text-decoration:underline}.quote-text .cursor{border-bottom:2px solid var(--text)}.quote-source{margin-top:1rem;font-size:.75rem;color:var(--text-muted)}.input-area textarea{width:100%;min-height:100px;padding:1rem;font-family:var(--font-mono);font-size:1rem;line-height:2;background:var(--bg);border:1px solid var(--border);color:var(--text);resize:none}.input-area textarea:focus{outline:none;border-color:var(--text)}.input-area textarea::placeholder{color:var(--text-muted)}.stats-live{display:flex;gap:2rem;margin-top:1rem;font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.hint{color:var(--text-muted);font-size:.75rem;margin-top:1rem}.results{text-align:center;padding:3rem 0}.results h2{font-size:1rem;font-weight:500;margin-bottom:2rem;text-transform:lowercase}.stats-final{display:flex;justify-content:center;gap:4rem;margin-bottom:2rem}.stat{display:flex;flex-direction:column;align-items:center}.stat .value{font-family:var(--font-mono);font-size:2.5rem;font-weight:500}.stat .label{font-size:.75rem;color:var(--text-muted);text-transform:lowercase}.login-prompt{color:var(--text-muted);font-size:.75rem;margin-bottom:1.5rem}.leaderboard{font-size:.875rem}.leaderboard-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.leaderboard h2{font-size:.75rem;font-weight:500;text-transform:lowercase}.reset-timer{font-size:.625rem;color:var(--text-muted)}.leaderboard table{width:100%;border-collapse:collapse}.leaderboard th,.leaderboard td{padding:.375rem 0;text-align:left;font-size:.75rem}.leaderboard th{color:var(--text-muted);font-weight:400;text-transform:lowercase}.leaderboard td{color:var(--text)}.leaderboard .rank{font-family:var(--font-mono);width:1.5rem;color:var(--text-muted)}.leaderboard .wpm{font-family:var(--font-mono)}.leaderboard .time{font-family:var(--font-mono);color:var(--text-muted)}.leaderboard .empty{color:var(--text-muted);font-size:.75rem;padding:1rem 0}.auth-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#80808080;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-content{background:var(--bg);padding:2rem;width:100%;max-width:320px;position:relative;border:1px solid var(--border)}.close-btn{position:absolute;top:1rem;right:1rem;background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;line-height:1}.close-btn:hover{color:var(--text)}.auth-content h2{margin-bottom:1.5rem;font-size:1rem;font-weight:500;text-transform:lowercase}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.25rem;font-size:.75rem;color:var(--text-muted);text-transform:lowercase}.form-group input{width:100%;padding:.5rem;background:var(--bg);border:1px solid var(--border);color:var(--text);font-size:.875rem;font-family:var(--font)}.form-group input:focus{outline:none;border-color:var(--text)}.auth-content .btn-primary{width:100%;padding:.5rem;margin-top:1rem}.auth-switch{margin-top:1rem;text-align:center;font-size:.75rem;color:var(--text-muted)}.auth-switch button{background:none;border:none;color:var(--text);cursor:pointer;font-size:.75rem;text-decoration:underline}.error{color:var(--incorrect);padding:.5rem;margin-bottom:1rem;font-size:.75rem;border:1px solid var(--incorrect)}.loading{color:var(--text-muted);font-size:.75rem}.username-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.875rem;font-family:var(--font);padding:0}.username-btn:hover{color:var(--text);text-decoration:underline}.profile-content{background:var(--bg);padding:2rem;width:100%;max-width:480px;max-height:80vh;overflow-y:auto;position:relative;border:1px solid var(--border)}.profile-content h2{margin-bottom:1.5rem;font-size:1rem;font-weight:500}.profile-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.profile-stat{display:flex;flex-direction:column;align-items:center;text-align:center}.profile-stat .value{font-family:var(--font-mono);font-size:1.5rem;font-weight:500}.profile-stat .label{font-size:.625rem;color:var(--text-muted);text-transform:lowercase}.profile-history h3{font-size:.75rem;font-weight:500;margin-bottom:1rem;text-transform:lowercase}.profile-history .empty{color:var(--text-muted);font-size:.75rem}.history-day{margin-bottom:1rem}.history-date{font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.history-item{display:grid;grid-template-columns:60px 1fr 60px;gap:.75rem;padding:.375rem 0;font-size:.75rem;border-bottom:1px solid var(--border)}.history-wpm{font-family:var(--font-mono)}.history-quote{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-time{color:var(--text-muted);text-align:right;font-size:.625rem}.footer{padding-top:2rem;margin-top:2rem;border-top:1px solid var(--border)}.footer p{font-size:.75rem;color:var(--text-muted)}@media(max-width:700px){.main{grid-template-columns:1fr;gap:2rem}.sidebar{order:-1}.app{padding:1rem}}
