@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--bg-color:#323437;--main-color:#e2b714;--caret-color:#e2b714;--sub-color:#646669;--text-color:#d1d0c5;--error-color:#ca4754;--error-extra-color:#7e2a33}body{background-color:var(--bg-color);color:var(--text-color);justify-content:center;min-height:100vh;margin:0;padding:0;font-family:JetBrains Mono,monospace;font-size:1.5rem;line-height:1.5;display:flex;overflow-y:hidden}#root{flex-direction:column;width:100%;max-width:1000px;padding:2rem;display:flex}*{box-sizing:border-box}button{color:var(--sub-color);font-family:inherit;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:.5rem 1rem;transition:color .2s}button:hover{color:var(--text-color)}button:focus{color:var(--text-color);outline:none}.app-container{flex-direction:column;justify-content:space-between;height:100vh;transition:opacity .5s;display:flex}header,.footer,.footer-meta,.stats-bar{transition:opacity .5s,pointer-events .5s}.app-container.focus-mode header,.app-container.focus-mode .footer,.app-container.focus-mode .footer-meta{opacity:0;pointer-events:none}header{color:var(--sub-color);justify-content:space-between;align-items:center;margin-bottom:2rem;font-size:1rem;display:flex}.logo{color:var(--main-color);align-items:center;gap:.5rem;font-size:2rem;font-weight:700;display:flex}.typing-area{outline:none;flex-direction:column;width:100%;height:10rem;margin-top:2rem;margin-bottom:2rem;font-size:2rem;line-height:1.5;display:flex;position:relative;overflow:hidden}.words-wrapper{flex-wrap:wrap;gap:.5rem .8rem;transition:transform .2s ease-out;display:flex;position:relative}.word{border-bottom:2px solid #0000;transition:opacity .3s;display:flex}.word.hidden-past{opacity:0;pointer-events:none}.word.dimmed-past{opacity:.2}.word.dimmed-future{opacity:.5}.word.error-underline{border-bottom-color:var(--error-color)}.char{color:var(--sub-color);transition:color .1s}.char.correct{color:var(--text-color)}.char.incorrect{color:var(--error-color)}.char.extra{color:var(--error-extra-color)}.caret{background-color:var(--caret-color);z-index:10;width:2px;height:2.2rem;transition:left .1s,top .1s;animation:1s step-start infinite blink;position:absolute}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-4px)}}.caret.smooth{opacity:1;animation:none}.ghost-caret{background-color:var(--sub-color);opacity:.3;z-index:5;transition:left .1s linear,top .1s linear;animation:none}.caret.shake{background-color:var(--error-color);animation:.2s ease-in-out shake}.app-container.caret-block .caret{background-color:var(--caret-color);opacity:.5;width:1.2rem}.app-container.caret-underline .caret{width:1.2rem;height:4px;transform:translateY(1.2rem)}.stats-bar{color:var(--main-color);gap:2rem;min-height:2rem;margin-bottom:1rem;font-size:1.5rem;display:flex}.stats-bar.hidden{opacity:0}.results-display{flex-direction:column;align-items:center;gap:2rem;width:100%;animation:.3s fadeIn;display:flex}.results-display.glassmorphic{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#32343766;border:1px solid #ffffff0d;border-radius:16px;padding:3rem;box-shadow:0 10px 30px #0003}.results-top{align-items:center;gap:2rem;width:100%;display:flex}.chart-wrapper{flex-grow:1;height:200px}.results-stats{display:flex}.results-stats.vertical{flex-direction:column;gap:1rem;width:150px}.results-stats.horizontal{text-align:center;justify-content:center;gap:3rem;width:100%}.stat-group{flex-direction:column;gap:.2rem;display:flex}.stat-label{color:var(--sub-color);font-size:1.2rem}.stat-value{color:var(--main-color);font-size:2.5rem;font-weight:700;line-height:1}.stat-value.huge{font-size:5rem}.stat-value.small{color:var(--text-color);font-size:1.8rem}.history-section{border-top:1px solid #ffffff0d;flex-direction:column;gap:1rem;width:100%;margin-top:2rem;padding-top:2rem;display:flex}.history-header{justify-content:space-between;align-items:center;display:flex}.history-header h3{color:var(--sub-color);margin:0;font-size:1.2rem;font-weight:400}.clear-history-btn{border:1px solid var(--error-color);color:var(--error-color);cursor:pointer;opacity:.7;background:0 0;border-radius:4px;padding:.3rem .8rem;font-family:inherit;font-size:.8rem;transition:opacity .2s}.clear-history-btn:hover{opacity:1}.history-table-wrapper{max-height:200px;overflow-y:auto}.history-table{border-collapse:collapse;text-align:left;width:100%;font-size:.9rem}.history-table th{color:var(--sub-color);border-bottom:1px solid #ffffff0d;padding:.5rem;font-weight:400}.history-table td{color:var(--text-color);border-bottom:1px solid #ffffff05;padding:.8rem .5rem}.highlight-text{font-weight:700;color:var(--main-color)!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footer{justify-content:center;gap:1rem;margin-top:auto;padding:2rem 0;display:flex}.footer-meta{justify-content:center;padding-bottom:2rem;display:flex}.instructions{color:var(--sub-color);text-align:center;font-size:.9rem}.sep{opacity:.5;margin:0 1rem}.command-palette-backdrop{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:100;background:#00000080;justify-content:center;align-items:flex-start;padding-top:15vh;display:flex;position:fixed;inset:0}.command-palette-modal{background:var(--bg-color);border:1px solid #ffffff0d;border-radius:12px;width:100%;max-width:500px;animation:.2s cubic-bezier(.16,1,.3,1) modalIn;overflow:hidden;box-shadow:0 20px 40px #0006}.command-header{border-bottom:1px solid #ffffff0d;padding:1rem}.command-input{width:100%;color:var(--text-color);background:0 0;border:none;outline:none;font-family:JetBrains Mono,monospace;font-size:1.2rem}.command-list{max-height:400px;padding:.5rem;overflow-y:auto}.command-item{color:var(--sub-color);cursor:pointer;border-radius:8px;justify-content:space-between;align-items:center;padding:.8rem 1rem;transition:all .1s;display:flex}.command-item.selected{color:var(--text-color);background:#ffffff0d}.command-text{flex-direction:column;gap:.2rem;display:flex}.command-cat{opacity:.6;text-transform:uppercase;letter-spacing:1px;color:var(--main-color);font-size:.7rem}.command-empty{text-align:center;color:var(--sub-color);padding:2rem}.command-shortcut{color:var(--main-color);font-size:1.2rem}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.quick-settings{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;align-items:center;gap:.5rem;padding:.35rem .6rem;display:flex}.settings-group{align-items:center;gap:.15rem;display:flex}.settings-btn{color:var(--sub-color);cursor:pointer;white-space:nowrap;letter-spacing:.02em;background:0 0;border:none;border-radius:5px;padding:.3rem .6rem;font-family:JetBrains Mono,monospace;font-size:.8rem;transition:color .15s,background .15s}.settings-btn:hover{color:var(--text-color);background:#ffffff0f}.settings-btn.active{color:var(--main-color)}.settings-divider{background:#ffffff14;flex-shrink:0;width:1px;height:1rem;margin:0 .25rem}.logo-group{align-items:center;gap:1.5rem;display:flex}.header-icon-btn{color:var(--sub-color);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.header-icon-btn:hover{color:var(--main-color);background:#ffffff0d;transform:translateY(-1px)}.history-overlay-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:2rem;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.history-overlay-modal{background:var(--bg-color);border:1px solid #ffffff0d;border-radius:20px;flex-direction:column;width:100%;max-width:900px;max-height:85vh;display:flex;position:relative;overflow:hidden;box-shadow:0 30px 60px #0006}.history-overlay-header{border-bottom:1px solid #ffffff0d;justify-content:space-between;align-items:flex-start;padding:2rem;display:flex}.history-title-group h2{color:var(--text-color);margin:0 0 1rem;font-size:1.8rem}.history-headline-stats{gap:2rem;display:flex}.mini-stat{flex-direction:column;gap:.2rem;display:flex}.mini-stat .label{color:var(--sub-color);letter-spacing:1px;font-size:.7rem}.mini-stat .value{color:var(--main-color);font-size:1.4rem;font-weight:700}.history-overlay-modal .close-btn{color:var(--sub-color);cursor:pointer;background:#ffffff08;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.history-overlay-modal .close-btn:hover{color:var(--error-color);background:#ffffff1a}.history-overlay-content{flex:1;padding:1.5rem 2rem;overflow-y:auto}.history-table-container{width:100%}.wpm-cell{font-size:1.1rem;color:var(--main-color)!important;font-weight:800!important}.history-empty{text-align:center;color:var(--sub-color);padding:4rem;font-size:1.2rem}.history-overlay-footer{border-top:1px solid #ffffff0d;justify-content:flex-end;padding:1.5rem 2rem;display:flex}.clear-history-confirm{color:var(--sub-color);cursor:pointer;background:0 0;border:1px solid #ff171733;border-radius:8px;padding:.5rem 1.2rem;font-family:inherit;font-size:.9rem;transition:all .2s}.clear-history-confirm:hover{background:var(--error-color);color:#fff;border-color:var(--error-color)}
