*,*:before,*:after{box-sizing:border-box}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}ul[role=list],ol[role=list]{list-style:none}html:focus-within{scroll-behavior:smooth}body{min-height:100vh;text-rendering:optimizeSpeed;line-height:1.5}a:not([class]){text-decoration-skip-ink:auto}img,picture{max-width:100%;display:block}input,button,textarea,select{font:inherit}button{background:none;border:none;cursor:pointer;padding:0}:root{--font-sans: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace}body{background-color:var(--bg-color, #18181b);color:var(--text-color, #a1a1aa);font-family:var(--font-sans);transition:background-color .7s ease-in-out;overflow:hidden}.app-root{position:relative;min-height:100vh;width:100%;display:flex;flex-direction:column;overflow:hidden}.main-content{position:relative;z-index:10;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.custom-scrollbar::-webkit-scrollbar{width:8px;height:8px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:var(--sub-color);border-radius:4px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:var(--text-color)}@keyframes pulse-slow{0%,to{opacity:.2;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes zoomIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.animate-fade-in{animation:fadeIn .3s ease-out forwards}.animate-zoom-in{animation:zoomIn .3s ease-out forwards}.animate-caret-blink{animation:blink 1s step-end infinite}.background-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-10;overflow:hidden;transition:background-color .7s ease-in-out;background-color:var(--bg-color)}.blob{position:absolute;border-radius:50%;mix-blend-mode:screen;filter:blur(100px);transition:background-color .7s ease-in-out;animation:pulse-slow 4s cubic-bezier(.4,0,.6,1) infinite}.blob-1{top:-20%;left:-10%;width:60vh;height:60vh;opacity:.2;background-color:var(--main-color)}.blob-2{bottom:-20%;right:-10%;width:50vh;height:50vh;opacity:.1;background-color:var(--main-color);animation-delay:2s;filter:blur(120px)}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.07;transition:all .7s}.vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.app-header{position:relative;z-index:10;width:100%;max-width:1280px;margin:0 auto;padding:2rem 1.5rem;display:flex;flex-direction:column;gap:1.5rem;align-items:center}@media(min-width:768px){.app-header{flex-direction:row;justify-content:space-between}}.header-left,.header-right{display:flex;align-items:center;gap:1rem}.header-left{order:2;flex-direction:column}.header-right{order:1;flex-direction:column}@media(min-width:640px){.header-left,.header-right{flex-direction:row}}@media(min-width:768px){.header-left{order:1}.header-right{order:2}}.divider{width:1px;height:16px;background-color:#ffffff1a;display:none}@media(min-width:640px){.divider{display:block}}.history-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;color:var(--text-color);transition:all .2s}.history-btn:hover{background-color:#ffffff0d}.history-btn svg,.history-btn span{opacity:.7;transition:opacity .2s}.history-btn:hover svg,.history-btn:hover span{opacity:1}.history-text{font-size:.875rem;font-family:var(--font-mono);font-weight:500}.selector-container{display:flex;align-items:center;gap:.75rem}.selector-label{font-size:10px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.1em;opacity:.4;color:var(--text-color);display:none}@media(min-width:768px){.selector-label{display:block}}.selector-controls{display:flex;padding:.25rem;border-radius:.5rem;border:1px solid var(--sub-color);background-color:#0003;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:border-color .3s}.selector-btn{padding:.25rem .75rem;font-size:.75rem;font-family:var(--font-mono);font-weight:700;border-radius:.375rem;text-transform:uppercase;transition:all .2s;color:var(--text-color);opacity:.4}.selector-btn:hover{background-color:#ffffff0d;opacity:.8}.selector-btn.active{background-color:#ffffff1a;box-shadow:0 1px 2px #0000001a;color:var(--main-color);opacity:1}.theme-selector-wrapper{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:wrap}.theme-btn{position:relative;display:flex;align-items:center;gap:.5rem;padding:.375rem .75rem;border-radius:9999px;border:1px solid transparent;transition:all .3s}.theme-btn:hover{background-color:#ffffff0d}.theme-btn.active{background-color:#ffffff1a;border-color:#fff3}.theme-dot{width:.75rem;height:.75rem;border-radius:50%;transition:transform .3s;background-color:var(--theme-dot-color)}.theme-btn:hover .theme-dot{transform:scale(1.1)}.theme-name{font-size:.75rem;font-family:var(--font-mono);font-weight:500;transition:color .3s;color:var(--text-color);opacity:.5}.theme-btn:hover .theme-name{opacity:.8}.theme-btn.active .theme-name{color:var(--main-color);opacity:1}.test-area-wrapper{position:relative;width:100%;max-width:1024px;margin:0 auto;padding:0 1rem;perspective:1000px}.hidden-input{position:absolute;opacity:0;z-index:-10;width:1px;height:1px;pointer-events:none}.test-container{position:relative;padding:2rem;border-radius:.75rem;transition:all .3s;min-height:200px;cursor:text;display:flex;flex-wrap:wrap;align-content:flex-start;gap:.5rem 0}@media(min-width:768px){.test-container{padding:3rem}}.test-container.blurred{filter:blur(2px);opacity:.5;transform:scale(.99)}.test-container:not(.blurred){opacity:1;transform:scale(1)}.click-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:20}.click-msg{background-color:#000c;padding:.5rem 1rem;border-radius:.25rem;color:#fff;font-family:var(--font-mono);display:flex;align-items:center;gap:.5rem}.word{display:inline-block;white-space:nowrap}.char-wrapper{position:relative;display:inline-block}.char{font-family:var(--font-mono);font-size:1.5rem;transition:color 75ms,background-color 75ms;border-radius:2px}@media(min-width:768px){.char{font-size:1.875rem}}.char.correct{color:var(--text-color);opacity:1;color:#fff}.char.incorrect{color:var(--error-color);text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}.char.pending{color:var(--sub-color);opacity:.5}.char.selected{background-color:var(--main-color);color:var(--bg-color)!important;opacity:1}.caret{position:absolute;left:-1px;top:0;bottom:0;width:2px;background-color:var(--caret-color);z-index:10;animation:blink 1s step-end infinite}.space-char{color:transparent}.space-char.incorrect{color:var(--error-color)}.space-char.selected{background-color:var(--main-color);opacity:.5}.restart-hint{display:flex;justify-content:center;margin-top:3rem;opacity:.5;transition:opacity .2s}.restart-hint:hover{opacity:1}.restart-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:var(--font-mono);font-size:.875rem;border-radius:.25rem;color:var(--text-color);transition:background-color .2s}.restart-btn:hover{background-color:#ffffff0d}.loading-container{width:100%;max-width:56rem;margin:0 auto;height:16rem;display:flex;align-items:center;justify-content:center}.loading-dots{display:flex;gap:.5rem}.dot{width:.75rem;height:.75rem;border-radius:50%;background-color:var(--main-color);animation:bounce 1s infinite}.dot:nth-child(2){animation-delay:75ms}.dot:nth-child(3){animation-delay:.15s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-25%)}}.live-stats{margin-bottom:3rem;display:flex;gap:2rem;padding:.75rem 2rem;border-radius:9999px;background-color:#0003;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.05);transition:opacity .3s;opacity:0}.live-stats.visible{opacity:1}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-label{font-size:.75rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.05em;opacity:.5;color:var(--text-color)}.stat-value{font-size:1.25rem;font-family:var(--font-mono);font-weight:700;color:var(--main-color)}.stat-divider{width:1px;background-color:#ffffff1a}.results-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:50;background-color:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.results-card{position:relative;width:100%;max-width:56rem;padding:2rem;border-radius:1rem;border:1px solid var(--sub-color);background-color:var(--bg-color);box-shadow:0 25px 50px -12px #00000040;transition:border-color .3s,background-color .3s}.close-results-btn{position:absolute;top:1rem;right:1rem;background:transparent;border:none;cursor:pointer;color:var(--sub-color);padding:.5rem;border-radius:.5rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-results-btn:hover{color:var(--text-color);background-color:#0000000d}.results-content{display:flex;flex-direction:column;gap:2rem}@media(min-width:768px){.results-content{flex-direction:row}}.stats-column{flex:1;display:flex;flex-direction:column;gap:2rem}.big-stat h2{font-size:1.25rem;font-family:var(--font-mono);opacity:.5;color:var(--text-color);margin-bottom:.25rem}.big-stat div{font-size:3.75rem;font-weight:700;font-family:var(--font-mono);color:var(--main-color);line-height:1}.secondary-stats{display:flex;gap:2rem}.small-stat h3{font-size:.875rem;font-family:var(--font-mono);opacity:.5;color:var(--text-color)}.small-stat p{font-size:1.5rem;font-family:var(--font-mono);color:var(--text-color)}.restart-action-btn{margin-top:1rem;padding:.75rem 2rem;border-radius:.5rem;font-family:var(--font-mono);font-size:1.125rem;font-weight:700;background-color:var(--main-color);color:var(--bg-color);transition:all .2s;align-self:flex-start}.restart-action-btn:hover{opacity:.9;transform:scale(1.02)}.restart-action-btn:active{transform:scale(.98)}.chart-column{flex:1;height:300px;min-height:250px}@media(min-width:768px){.chart-column{height:400px}}.chart-title{font-size:.875rem;font-family:var(--font-mono);opacity:.5;color:var(--text-color);margin-bottom:1rem}.history-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background-color:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:1rem}.history-card{position:relative;width:100%;max-width:56rem;max-height:80vh;display:flex;flex-direction:column;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--sub-color);background-color:var(--bg-color);overflow:hidden}.history-header{padding:1.5rem;border-bottom:1px solid var(--sub-color);display:flex;justify-content:space-between;align-items:center}.history-title{font-size:1.5rem;font-family:var(--font-mono);font-weight:700;color:var(--main-color)}.history-actions{display:flex;gap:1rem}.clear-btn{padding:.5rem 1rem;font-size:.875rem;font-family:var(--font-mono);border-radius:.25rem;color:var(--error-color);transition:background-color .2s}.clear-btn:hover{background-color:#ffffff1a}.close-btn{padding:.5rem;border-radius:9999px;color:var(--text-color);transition:background-color .2s}.close-btn:hover{background-color:#ffffff1a}.history-content{flex:1;overflow-y:auto;padding:1.5rem}.empty-history{text-align:center;padding:3rem 0;opacity:.5;font-family:var(--font-mono);color:var(--text-color)}.table-wrapper{overflow-x:auto}.history-table{width:100%;text-align:left;font-family:var(--font-mono);font-size:.875rem;border-collapse:collapse}.history-table th{padding-bottom:.75rem;padding-left:.5rem;opacity:.5;color:var(--text-color);font-weight:400;border-bottom:1px solid var(--sub-color)}.history-table td{padding:1rem 0 1rem .5rem;border-bottom:1px solid var(--sub-color);color:var(--text-color)}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover{background-color:#ffffff0d}.history-date{opacity:.7}.history-wpm{font-weight:700;font-size:1.125rem;color:var(--main-color)}.history-time,.history-mode,.history-words{opacity:.8}
