*{margin:0;padding:0;box-sizing:border-box}body{background:#121213;color:#d7dadc;font-family:Segoe UI,system-ui,-apple-system,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;overflow:hidden}h1{font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem;color:#d7dadc}#game-canvas{border:2px solid #3a3a3c;display:block;width:90vw;max-width:1200px;height:auto;aspect-ratio:800 / 608}#results-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10}#results-overlay.hidden{display:none}#results-content{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:8px;padding:2rem;max-width:400px;width:90%;text-align:center}#results-content h2{font-size:1.5rem;margin-bottom:1.5rem;color:#538d4e}.results-times{margin-bottom:1.5rem}.result-row{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #3a3a3c;font-family:monospace}.result-label{font-weight:600;min-width:100px;text-align:left}.result-time{color:#d7dadc}.result-pb{color:#818384;font-size:.85rem}.results-stats{color:#818384;font-size:.9rem;margin-bottom:1.5rem}#restart-btn{background:#538d4e;color:#fff;border:none;border-radius:4px;padding:.75rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.05em}#restart-btn:hover{background:#6aaf60}.results-hint{color:#818384;font-size:.8rem;margin-top:.75rem}.title-row{display:flex;align-items:center;gap:.5rem}#settings-btn{background:transparent;border:1px solid #3a3a3c;border-radius:50%;width:32px;height:32px;font-size:16px;color:#d7dadc;cursor:pointer;line-height:1}#settings-btn:hover:not(.disabled){background:#3a3a3c}#settings-btn.disabled{opacity:.3;cursor:not-allowed}#settings-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:20}#settings-overlay.hidden{display:none}.settings-modal{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:8px;padding:2rem;max-width:400px;width:90%;position:relative;color:#d7dadc}.settings-modal h2{font-size:1.25rem;margin-bottom:1rem}.settings-close{position:absolute;top:8px;right:12px;background:transparent;border:none;color:#818384;font-size:24px;cursor:pointer;line-height:1}.settings-close:hover{color:#d7dadc}.ghost-fieldset{border:1px solid #3a3a3c;border-radius:4px;padding:.75rem}.ghost-fieldset legend{font-size:.9rem;color:#818384;padding:0 .25rem}.ghost-fieldset label{display:block;padding:.35rem 0;font-size:.9rem;cursor:pointer}.ghost-fieldset input[type=radio]{margin-right:.5rem;accent-color:#538d4e}.submit-section{margin-bottom:1rem}.submit-btn{background:#3a3a3c;color:#d7dadc;border:1px solid #818384;border-radius:4px;padding:.5rem 1.25rem;font-size:.9rem;cursor:pointer}.submit-btn:hover{background:#4a4a4c}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.name-form{display:flex;flex-direction:column;gap:.5rem;align-items:center}.name-input{background:#121213;color:#d7dadc;border:1px solid #818384;border-radius:4px;padding:.5rem;font-size:.9rem;font-family:monospace;text-align:center;width:200px}.name-input:focus{outline:none;border-color:#538d4e}.name-error{color:#e74c3c;font-size:.8rem;min-height:1.2em}.submit-success{color:#538d4e;font-weight:600}.lb-open-btn{background:none;color:#818384;border:1px solid #3a3a3c;border-radius:4px;padding:.25rem .75rem;font-size:.8rem;cursor:pointer;margin-bottom:.5rem}.lb-open-btn:hover{color:#d7dadc;border-color:#818384}#leaderboard-modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:20}#leaderboard-modal.hidden{display:none}.lb-content{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:8px;padding:1.5rem;max-width:450px;width:90%;max-height:80vh;display:flex;flex-direction:column}.lb-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.lb-header h2{font-size:1.25rem;color:#d7dadc;margin:0}.lb-close{background:none;border:none;color:#818384;font-size:1.5rem;cursor:pointer;padding:0 .25rem}.lb-close:hover{color:#d7dadc}.lb-tabs{display:flex;gap:.25rem;margin-bottom:1rem}.lb-tab{background:#3a3a3c;color:#818384;border:none;border-radius:4px;padding:.4rem .75rem;font-size:.8rem;cursor:pointer;flex:1}.lb-tab:hover{color:#d7dadc}.lb-tab-active{background:#538d4e;color:#fff}.lb-body{overflow-y:auto;flex:1;font-family:monospace;font-size:.85rem;color:#818384}.lb-table{display:flex;flex-direction:column}.lb-row{display:flex;padding:.3rem 0;border-bottom:1px solid #2a2a2b}.lb-rank{width:3rem;color:#818384}.lb-name{flex:1;color:#d7dadc}.lb-time{color:#d7dadc;text-align:right}.lb-your-rank{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #3a3a3c;color:#538d4e;text-align:center}#how-to-play-btn{background:transparent;border:1px solid #3a3a3c;border-radius:50%;width:32px;height:32px;font-size:16px;font-weight:700;color:#d7dadc;cursor:pointer;line-height:1}#how-to-play-btn:hover{background:#3a3a3c}#how-to-play-modal{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:20}#how-to-play-modal.hidden{display:none}.htp-content{background:#1a1a1b;border:1px solid #3a3a3c;border-radius:8px;padding:1.5rem;max-width:400px;width:90%;position:relative;color:#d7dadc}.htp-content h2{font-size:1.25rem;margin-bottom:1rem}.htp-close{position:absolute;top:8px;right:12px;background:transparent;border:none;color:#818384;font-size:24px;cursor:pointer;line-height:1}.htp-close:hover{color:#d7dadc}.htp-section{margin-bottom:1rem}.htp-section:last-child{margin-bottom:0}.htp-section h3{font-size:.9rem;color:#818384;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.htp-row{display:flex;justify-content:space-between;padding:.3rem 0;border-bottom:1px solid #2a2a2b;font-size:.85rem}.htp-key{color:#538d4e;font-weight:600;font-family:monospace}.controls-fieldset{border:1px solid #3a3a3c;border-radius:4px;padding:.75rem;margin-top:.75rem}.controls-fieldset legend{font-size:.9rem;color:#818384;padding:0 .25rem}.keybind-row{display:flex;align-items:center;justify-content:space-between;padding:.35rem 0;border-bottom:1px solid #2a2a2b}.keybind-row:last-child{border-bottom:none}.keybind-action{font-size:.9rem;font-weight:600;min-width:60px}.keybind-keys{display:flex;gap:.25rem;flex-wrap:wrap;justify-content:flex-end}.keybind-key{background:#3a3a3c;color:#d7dadc;border:1px solid #818384;border-radius:3px;padding:.2rem .5rem;font-size:.8rem;font-family:monospace;cursor:pointer;min-width:2rem;text-align:center}.keybind-key:hover{background:#4a4a4c}.keybind-key.listening{background:#538d4e;border-color:#6aaf60;color:#fff}.keybind-reset{background:none;border:1px solid #3a3a3c;color:#818384;border-radius:4px;padding:.3rem .75rem;font-size:.75rem;cursor:pointer;margin-top:.5rem;width:100%}.keybind-reset:hover{color:#d7dadc;border-color:#818384}@media(prefers-reduced-motion:reduce){*{animation-duration:0s!important;transition-duration:0s!important}}
