@tailwind base;@tailwind components;@tailwind utilities;:root{--primary-color: #00ff9d;--secondary-color: #00cc8f;--background-color: #000000;--text-color: #646669;--error-color: #ca4754;--correct-color: #00ff9d;--neutral-color: #646669;--caret-color: #00ff9d;--sub-color: #646669;--header-offset: 3.5rem;--app-padding: 1rem}[data-theme=light]{--primary-color: #00ff9d;--secondary-color: #00cc8f;--background-color: #ffffff;--text-color: #333333;--error-color: #ca4754;--correct-color: #00ff9d;--neutral-color: #646669;--caret-color: #00ff9d;--sub-color: #646669}[data-theme=dark]{--primary-color: #00ff9d;--secondary-color: #00cc8f;--background-color: #000000;--text-color: #646669;--error-color: #ca4754;--correct-color: #00ff9d;--neutral-color: #646669;--caret-color: #00ff9d;--sub-color: #646669}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;font-family:JetBrains Mono,monospace;background-color:var(--background-color);color:var(--text-color);height:100vh;overflow:hidden}.app{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;height:100vh;padding:var(--app-padding);overflow:hidden}.logo{position:fixed;top:1rem;left:1rem;font-size:1.2rem;color:var(--primary-color);font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:2px;cursor:pointer;transition:color .2s ease}.logo:hover{color:var(--secondary-color)}.main-menu{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;width:100%;padding:2rem}.main-menu h1{font-size:4rem;color:var(--primary-color);margin-bottom:2rem;text-transform:uppercase;letter-spacing:4px}.menu-options{display:flex;flex-direction:column;gap:1rem}.menu-button{background:none;border:2px solid var(--primary-color);color:var(--text-color);padding:1rem 2rem;font-size:1.2rem;cursor:pointer;transition:all .2s ease;font-family:inherit;text-transform:uppercase;letter-spacing:2px;min-width:250px}.menu-button:hover{background-color:var(--primary-color);color:var(--background-color)}.typing-game{display:flex;flex-direction:column;align-items:center;width:100%;max-width:800px;margin:0 auto;padding:1rem;position:relative;height:100vh;overflow:hidden}.text-container{position:relative;width:100%;max-width:800px;margin:0 auto;padding:1rem 2rem 0;margin-top:var(--header-offset);display:flex;justify-content:center;align-items:flex-start}.text-display{font-family:JetBrains Mono,monospace;font-size:1.5rem;line-height:1.5;min-height:6rem;color:var(--text-color);position:relative;white-space:pre-wrap;word-break:keep-all;overflow-wrap:break-word;width:fit-content;max-width:800px;tab-size:4;hyphens:none;text-align:left;padding:1rem}.text-display span{white-space:pre;position:relative;display:inline-block}.text-display span.correct{color:var(--correct-color)}.text-display span.incorrect{color:var(--error-color)}.text-display span.neutral{color:var(--neutral-color)}.text-display span.current{position:relative}.text-display span.current:after{content:"▏";position:absolute;left:0;top:0;bottom:0;color:var(--caret-color);animation:blink 1s step-end infinite}.typing-input{position:relative;width:100%;opacity:1!important;z-index:1;cursor:text;caret-color:auto!important;background:transparent!important;color:transparent!important;border:none!important;outline:none!important;box-shadow:none!important}.typing-input:focus{background:transparent!important;color:transparent!important;border:none!important;outline:none!important;box-shadow:none!important}.theme-toggle{position:fixed;top:1rem;right:1rem;background:transparent!important;border:none!important;outline:none!important;box-shadow:none!important;color:var(--primary-color);padding:0;font-size:1.2rem;cursor:pointer;transition:color .2s ease;display:flex;align-items:center;gap:.5rem;z-index:100;border-radius:0;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;appearance:none;-webkit-appearance:none;-moz-appearance:none}.theme-toggle:focus,.theme-toggle:active{border:none!important;outline:none!important;box-shadow:none!important;background:transparent!important}.theme-toggle:hover{color:var(--secondary-color);background:transparent!important;box-shadow:none!important;transform:none}.theme-toggle svg{width:1.5rem;height:1.5rem;transition:color .2s,filter .2s;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@media (max-width: 768px){.main-menu h1{font-size:2.5rem;margin-bottom:1.5rem}.menu-button{padding:.8rem 1.5rem;font-size:1rem;min-width:200px}.typing-game{padding:1rem}.text-container{padding:1rem;margin-top:var(--header-offset)}.stats-container{padding:0 1rem}.wpm-stat{left:1rem;top:50%}.acc-stat{right:1rem;top:50%}.time-stat{bottom:.5rem;font-size:1rem}.text-display{font-size:1.2rem}.end-screen-stats{gap:1rem;padding:0 1rem}.end-screen-stat{padding:.5rem}.end-screen-stat-value{font-size:1.5rem}.graph-container{height:200px;padding:1rem}.graph-axis.x{left:1rem;right:1rem}.graph-axis.y,.end-screen-buttons{bottom:1rem}}@media (max-height: 600px){.stats-container{top:.5rem}.wpm-stat,.acc-stat{top:50%}.time-stat{bottom:.25rem;font-size:.9rem}.text-container{margin-top:4.5rem;padding:1rem}.text-display{font-size:1.2rem;min-height:4.5rem}.end-screen-stats{gap:.75rem;margin:1rem 0}.end-screen-stat{padding:.25rem}.end-screen-stat-value{font-size:1.2rem}.graph-container{height:200px}}@media (max-width: 600px){.typing-game{padding:.5rem;height:100vh;min-width:0}.text-container{padding:.5rem .5rem 0;margin-top:var(--header-offset);min-width:0}.text-display{font-size:1rem;padding:.5rem;min-height:3rem;max-width:100vw;word-break:break-word}}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.5rem;color:var(--primary-color);font-family:JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:2px}#root{display:flex;flex-direction:column;min-height:100vh}.stats-bar{display:none}.end-screen{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;width:100%;max-width:800px;margin:0 auto;padding:.25rem;margin-top:calc(var(--header-offset) - var(--app-padding));min-height:100vh;position:relative}.end-screen-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;width:100%;margin-bottom:3rem}.end-screen-stat{text-align:center;padding:1.5rem;transition:transform .2s ease}.end-screen-stat.wpm{grid-column:1;grid-row:1;text-align:left}.end-screen-stat.errors{grid-column:3;grid-row:1;text-align:right}.end-screen-stat.time{grid-column:2;grid-row:1;text-align:center}.end-screen-stat:hover{transform:translateY(-2px)}.end-screen-stat-label{font-size:.8rem;color:var(--text-color);text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem}.end-screen-stat-value{font-size:2.5rem;color:var(--primary-color);font-weight:700}.end-screen-buttons{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:1.5rem}.end-screen-button{background:none;border:2px solid var(--primary-color);color:var(--text-color);padding:1rem 2rem;font-size:1.2rem;cursor:pointer;transition:all .2s ease;font-family:inherit;text-transform:uppercase;letter-spacing:2px;min-width:250px;border-radius:8px}.end-screen-button:hover{background-color:var(--primary-color);color:var(--background-color);transform:translateY(-2px)}.correct{color:var(--correct-color)}.incorrect{color:var(--error-color);text-decoration:underline}.current{background-color:#0000001a;border-radius:2px}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:2rem;text-align:center}.error-screen h2{margin-bottom:1rem}.error-screen p{margin-bottom:2rem}.stats-container{position:fixed;top:1rem;left:0;right:0;display:flex;justify-content:space-between;width:100%;padding:0 2rem;z-index:10}.wpm-stat{position:fixed;left:2rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;text-align:center;width:6rem}.acc-stat{position:fixed;right:2rem;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;text-align:center;width:6rem}.time-stat{position:fixed;left:50%;transform:translate(-50%);bottom:1rem;z-index:100}.stat-label{font-size:.8rem;color:var(--text-color);text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem}.stat-value{font-size:2rem;color:var(--primary-color);font-weight:700}.graph-container{width:100%;height:300px;margin:6rem 0 2rem;position:relative;padding:2rem}.graph-container canvas{width:100%;height:100%}.graph-axis{position:absolute;color:var(--text-color);font-size:.8rem;font-family:JetBrains Mono,monospace}.graph-axis.x{bottom:0;left:2rem;right:2rem;display:flex;justify-content:space-between;padding:.5rem 0}.graph-axis.y{top:0;bottom:2rem;left:0;display:flex;flex-direction:column;justify-content:space-between;padding:0 .5rem;width:3rem;text-align:right}body,.app,#root{overflow-x:hidden;scrollbar-width:none}body::-webkit-scrollbar,.app::-webkit-scrollbar,#root::-webkit-scrollbar{display:none}.future-modes-placeholder{width:100%;min-height:3rem;background:transparent;margin-top:1.5rem}.end-screen-text{width:100%;max-width:800px;margin:0 auto .5rem;font-family:JetBrains Mono,monospace;font-size:1.2rem;color:var(--text-color);background:#0000000a;border-radius:6px;padding:1rem 1.5rem;text-align:left;word-break:break-word}.end-screen-graph-row{display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;width:100%;max-width:900px;margin:0 auto 1.5rem}.end-screen-stat.wpm{flex:0 0 120px;text-align:left;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-start;margin-right:1.5rem}.end-screen-stat.errors{flex:0 0 120px;text-align:right;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-end;margin-left:1.5rem}.graph-container{flex:1 1 0;min-width:0;margin:0;padding:1rem 0;height:300px;position:relative;background:#00000005;border-radius:8px}.end-screen-graph-row.end-screen-time-row{display:flex;justify-content:center;align-items:flex-start;margin:0 auto 2rem}.end-screen-stat.time{text-align:center;margin:0 auto;font-size:1.1rem}.end-screen-rawwpm{width:100%;max-width:900px;margin:0 auto 2rem;display:flex;flex-direction:row;justify-content:center;align-items:center;gap:1.5rem;font-size:1.3rem}.end-screen-rawwpm .stat-label{font-size:1rem;color:var(--text-color);text-transform:uppercase;letter-spacing:2px;margin-right:.5rem}.end-screen-rawwpm .stat-value{font-size:2rem;color:var(--primary-color);font-weight:700}.end-screen-stat.acc{flex:0 0 120px;text-align:right;display:flex;flex-direction:column;justify-content:flex-start;align-items:flex-end;margin-left:1.5rem}.end-screen-time{width:100%;max-width:900px;margin:0 auto;text-align:center;padding:1rem 0}.end-screen-time .stat-label{font-size:.9rem;margin-bottom:.3rem}.end-screen-time .stat-value{font-size:1.5rem}@media (max-width: 900px){.end-screen-graph-row{flex-direction:column!important;align-items:stretch!important;max-width:100vw!important;position:relative!important}.endscreen-side-stat{position:static!important;left:unset!important;right:unset!important;top:unset!important;transform:none!important;width:100%!important;margin-bottom:.5rem!important;z-index:10;display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important}.graph-container{max-width:100vw!important;min-width:0!important;width:100%!important;overflow-x:auto!important;margin:0 auto 1rem!important;height:160px!important}.end-screen-buttons{position:static!important;left:unset!important;bottom:unset!important;transform:none!important;width:100%!important;margin:1.5rem 0 0!important;flex-direction:column!important;gap:1rem!important;z-index:10}.end-screen-time{position:static!important;left:unset!important;transform:none!important;bottom:unset!important;width:100%!important;margin-top:1rem!important}}@media (max-width: 600px){.end-screen-graph-row{padding:0 .5rem!important}.graph-container{height:180px!important;padding:.5rem!important}.end-screen-stat.wpm,.end-screen-stat.acc{font-size:1rem!important;padding:.5rem!important}.end-screen-time .stat-value{font-size:1.2rem!important}}@media (max-width: 900px){.text-container{padding:.5rem!important;min-height:120px!important}}@media (max-width: 600px){.text-container{min-height:80px!important;font-size:1rem!important}}@media (max-width: 700px){:root{--header-offset: 2.5rem}body,#root,.app,.end-screen{overflow-y:auto!important;overflow-x:hidden!important}.end-screen{min-height:0!important;height:auto!important;padding:.5rem .75rem!important;padding-top:var(--header-offset)!important;padding-bottom:.5rem!important;display:flex!important;flex-direction:column!important}.end-screen-buttons{margin-top:auto!important;margin-bottom:0!important;width:100%!important}}
