:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.typing-interface{max-width:60vw}@media (max-width: 768px){.typing-interface{max-width:none;width:100%}}.text-display{margin:2rem auto;font-family:Courier New,monospace;font-weight:700;font-size:2rem;word-wrap:break-word;display:flex;flex-wrap:wrap;align-items:baseline}.word{white-space:nowrap;display:inline-flex}.letter{display:inline-block;min-width:.5em;height:1.5em;line-height:1.5em;text-align:center;transition:background-color .2s ease;color:#fff9;border-bottom:2px solid transparent}.letter::selection{background-color:#0003}.letter.cursor{border-bottom:2px solid;animation:blink 1s infinite}@keyframes blink{0%,50%{border-bottom-color:#fff6}51%,to{border-bottom-color:transparent}}.letter.untyped{color:#fff9}.letter.correct{color:#fff}.letter.incorrect{color:#ff6b6b}.letter.partially-correct{color:#ffd93b}.progression-display{display:flex;flex-direction:column;align-items:center;font-family:Courier New,monospace;font-weight:700;font-size:1rem}.progression-display .text-line{display:flex;flex-wrap:nowrap;background-color:#ffffff0d}.progression-display .letter{min-width:1rem}.progression-display .letter.highlight{min-width:1rem;background-color:green}.info-display{display:flex;justify-content:space-between;align-items:flex-end;margin:1rem auto;font-family:Andale Mono,monospace}.info-display-top{display:contents}@media (max-width: 768px){.info-display{flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.5rem}.info-display-top{display:contents}.sequence-display{order:3;width:100%;justify-content:center}}.current-char{display:flex;justify-content:center;align-items:center;font-size:2rem;font-weight:700;color:#fff;width:4rem;height:4rem;border-radius:8px;background-color:#ffffff0d;font-family:Courier New,monospace;flex-shrink:0}.metrics{display:flex;flex-direction:column;align-items:flex-end;text-align:right}.accuracy{font-size:1rem;color:#fffc;margin-bottom:.25rem}.wpm{font-size:3rem}.sequence-display{display:flex;align-items:center;gap:.5rem;font-family:Courier New,monospace;font-size:2rem;font-weight:700;color:#fffc}.sequence-char{padding:.25rem .5rem;background-color:#ffffff1a;border-radius:4px;color:#fff}.sequence-separator{color:#fff9}.sequence-result{padding:.25rem .5rem;background-color:#ffffff1a;border-radius:4px;color:#fff}.mobile-keyboard-input{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}
