:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--ink:#1b1d22;--muted:#66707c;--panel:#ffffffd1;--line:#1c202824;--bench:#f4f6f1;--yellow:#d7ae11;--purple:#8b3767;--green:#1f9d55;--focus:#205bd6}*{box-sizing:border-box}html,body{overscroll-behavior:none;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-text-size-adjust:100%;-webkit-touch-callout:none;height:100%;color:var(--ink);background:radial-gradient(circle at 24% 18%,#ffffffe0,#0000 28rem),linear-gradient(140deg,#e8ece4,#f7f5ed 58%,#e4e8df);margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.app{grid-template-rows:auto 1fr auto;min-height:100%;display:grid}.toolbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);z-index:2;background:#fafbf7bd;align-items:center;gap:10px;min-height:58px;padding:10px clamp(12px,4vw,26px);display:flex}.title{white-space:nowrap;align-items:baseline;gap:10px;min-width:0;margin-right:auto;display:flex}.title strong{letter-spacing:0;font-size:16px;font-weight:760}.title .status-label{color:var(--muted);font-size:12px;font-weight:640}.build-label{color:var(--muted);font-variant-numeric:tabular-nums;font-size:11px;font-weight:640}button,input[type=range]{font:inherit}.icon-button{border:1px solid var(--line);width:38px;height:38px;color:var(--ink);cursor:pointer;background:#ffffffc2;border-radius:8px;place-items:center;display:inline-grid;box-shadow:0 1px 1px #14181e0a}.icon-button:hover{background:#fff;border-color:#1c20283d}.icon-button:focus-visible,.speed:focus-visible,.primary-action:focus-visible,.secondary-action:focus-visible,.stage-select-button:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.speed{accent-color:#586b44;width:100%}.settings-dialog{width:min(340px,100vw - 28px);color:var(--ink);background:0 0;border:0;border-radius:8px;padding:0}.settings-dialog::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#1b1d2252}.settings-panel{border:1px solid var(--line);background:#fafbf7f5;border-radius:8px;padding:15px;box-shadow:0 22px 64px #181c213d}.settings-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.settings-head h2{letter-spacing:0;margin:0;font-size:15px;font-weight:760}.setting-row{color:var(--muted);justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:10px;font-size:13px;font-weight:680;display:flex}.setting-row output{color:var(--ink);font-variant-numeric:tabular-nums}.stage-shell{place-items:center;min-height:0;padding:clamp(10px,2.2vw,22px);display:grid}.stage{aspect-ratio:9/14;background:linear-gradient(120deg, #ffffff94, transparent 36%), var(--bench);border:1px solid #1c20281f;border-radius:8px;width:min(100%,520px,64.2857vh - 82.2857px);max-width:520px;position:relative;overflow:hidden;box-shadow:0 20px 58px #2e332629,inset 0 0 0 1px #ffffff75}@supports (height:100dvh){.stage{width:min(100%,520px,64.2857dvh - 82.2857px)}}canvas{touch-action:none;width:100%;height:100%;display:block}.touch-guide{z-index:3;pointer-events:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;display:grid;position:absolute;inset:0}.touch-guide[hidden]{display:none}.touch-zone{background:#1f9d5524;border:2px solid #1f9d55b8;border-radius:8px;min-width:0;animation:1.25s ease-in-out infinite touchPulse;box-shadow:inset 0 0 0 1px #ffffff8a,0 0 #1f9d5561}.stage[data-touch-side=left] .touch-zone-right,.stage[data-touch-side=right] .touch-zone-left{visibility:hidden}.tutorial-overlay{z-index:4;pointer-events:none;justify-content:center;align-items:flex-start;padding:14px;display:flex;position:absolute;inset:0}.tutorial-overlay[hidden]{display:none}.tutorial-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;background:#fafbf7f0;border:1px solid #1c202824;border-radius:8px;width:min(100%,390px);padding:14px;box-shadow:0 18px 52px #1f232a33}.tutorial-stage,.menu-kicker{color:var(--muted);letter-spacing:0;text-transform:uppercase;margin:0 0 8px;font-size:12px;font-weight:780}.tutorial-panel h2,.menu-panel h2,.menu-panel h1{letter-spacing:0;margin:0}.tutorial-panel h2{font-size:20px;font-weight:820}.tutorial-copy{color:var(--ink);word-break:keep-all;margin:10px 0 8px;font-size:15px;font-weight:720;line-height:1.42}.touch-copy{display:none}.tutorial-hint{color:var(--muted);word-break:keep-all;margin:0 0 14px;font-size:13px;font-weight:650;line-height:1.38}.touch-hint{display:none}.tutorial-keyboard{gap:5px;width:max-content;margin:0 0 14px;display:grid}.keyboard-row{grid-template-columns:repeat(var(--key-count,3), 38px);gap:5px;display:grid}.keyboard-key{min-width:0;height:34px;color:var(--ink);font-variant-numeric:tabular-nums;background:linear-gradient(#fff,#eef1ec);border:1px solid #1c20282e;border-radius:7px;place-items:center;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:15px;font-weight:860;display:grid;box-shadow:inset 0 -2px #1c20281a,0 3px 8px #1c202814}.keyboard-key.is-active{animation:1s ease-in-out infinite keyPulse}.keyboard-key.is-spacer{visibility:hidden}.primary-action,.secondary-action,.stage-select-button{cursor:pointer;border:1px solid #1c202826;border-radius:8px;min-height:42px}.primary-action{color:#fff;background:#1f2937;justify-content:center;align-items:center;min-width:132px;padding:0 18px;font-weight:780;display:inline-flex;box-shadow:0 10px 26px #1f29372e}.primary-action:hover{background:#111827}.secondary-action{width:100%;color:var(--muted);background:#ffffffbd;padding:0 14px;font-weight:720}.secondary-action:hover{color:var(--ink);background:#fff}.menu-overlay{z-index:20;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#f7f8f3db,#e8ece4f5),#f4f6f1f0;place-items:center;padding:clamp(16px,4vw,34px);display:grid;position:fixed;inset:0}.menu-overlay[hidden]{display:none}.menu-panel{text-align:center;background:#fafbf7e6;border:1px solid #1c202824;border-radius:8px;width:min(100%,420px);padding:clamp(20px,5vw,30px);box-shadow:0 24px 72px #1f232a38}.menu-panel[hidden]{display:none}.menu-panel h1{word-break:keep-all;font-size:clamp(38px,12vw,62px);font-weight:860;line-height:.98}.menu-panel h2{font-size:clamp(26px,8vw,36px);font-weight:840;line-height:1.05}.title-screen .primary-action{margin-top:24px}.stage-list{gap:10px;margin:22px 0 12px;display:grid}.stage-select-button{width:100%;color:var(--ink);text-align:left;background:#ffffffc2;grid-template-columns:auto 1fr auto;align-items:center;gap:5px 12px;padding:12px 14px;display:grid}.stage-select-button:hover{background:#fff;border-color:#1c20283d}.stage-number{color:var(--muted);font-variant-numeric:tabular-nums;text-transform:uppercase;font-size:12px;font-weight:800}.stage-select-button strong{min-width:0;font-size:15px;font-weight:780}.stage-summary{min-width:0;color:var(--muted);grid-column:2;font-size:12px;font-weight:680}.stage-record{color:#2d5b40;font-variant-numeric:tabular-nums;white-space:nowrap;grid-area:1/3/span 2;justify-self:end;font-size:12px;font-style:normal;font-weight:800}.stage-hud{pointer-events:none;align-items:center;gap:6px;display:flex;position:absolute;top:8px;right:8px}.timer-label,.score-label{min-width:58px;color:var(--ink);font-variant-numeric:tabular-nums;text-align:right;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffffb8;border:1px solid #1c20281a;border-radius:7px;padding:4px 7px;font-size:11px;font-weight:760}.timer-label.is-overtime{color:#a52b2b}.score-panel{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#f7f8f394;place-items:center;padding:18px;display:grid;position:absolute;inset:0}.score-panel[hidden]{display:none}.score-card{background:#ffffffe6;border:1px solid #1c202824;border-radius:8px;width:min(270px,100%);padding:14px;box-shadow:0 16px 38px #1c202829}.score-title{margin-bottom:10px;font-size:16px;font-weight:780}.score-rows{font-variant-numeric:tabular-nums;grid-template-columns:1fr auto;gap:7px 14px;margin:0 0 13px;font-size:12px;display:grid}.score-rows dt{color:var(--muted);font-weight:680}.score-rows dd{color:var(--ink);margin:0;font-weight:760}.score-next{color:#fff;width:100%;min-height:36px;font:inherit;cursor:pointer;background:#1b1d22;border:1px solid #1c202826;border-radius:8px;font-size:13px;font-weight:760}.score-next:focus-visible{outline:2px solid var(--focus);outline-offset:2px}.readout{pointer-events:none;grid-template-columns:1fr auto;align-items:end;gap:10px;display:grid;position:absolute;bottom:12px;left:12px;right:12px}.meter{background:#24282d1f;border-radius:999px;height:5px;overflow:hidden}.meter span{width:calc(var(--sorted,0) * 100%);background:linear-gradient(90deg, var(--purple), var(--yellow));height:100%;display:block}.count{background:var(--panel);min-width:124px;color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #1c20281f;border-radius:7px;padding:5px 8px;font-size:12px}@keyframes touchPulse{0%,to{background:#1f9d551f;box-shadow:inset 0 0 0 1px #ffffff80,0 0 #1f9d555c}50%{background:#1f9d553d;box-shadow:inset 0 0 0 1px #ffffff9e,0 0 0 9px #1f9d5500}}@keyframes keyPulse{0%,to{background:linear-gradient(#fff,#eef1ec);border-color:#1c20282e;transform:translateY(0)}50%{background:linear-gradient(#eef5ff,#dce9ff);border-color:#205bd6b8;transform:translateY(1px);box-shadow:inset 0 -2px #205bd629,0 0 0 4px #205bd624}}.legend{min-height:38px;color:var(--muted);flex-wrap:wrap;justify-content:center;align-items:center;gap:18px;padding:0 14px 12px;font-size:12px;font-weight:650;display:flex}.legend a{color:var(--muted);text-decoration:none}.legend a:hover,.legend a:focus-visible{color:var(--ink);text-decoration:underline}.swatch{align-items:center;gap:7px;display:inline-flex}.swatch:before{content:"";background:var(--swatch);border-radius:99px;width:18px;height:8px;transform:rotate(-9deg);box-shadow:inset 0 -1px #0000002e}@media (width<=520px){.toolbar{gap:7px}.title{flex:0 clamp(88px,34vw,150px);width:clamp(88px,34vw,150px);margin-right:0;overflow:hidden}.title strong{text-overflow:ellipsis;min-width:0;max-width:100%;display:block;overflow:hidden}.title .status-label{display:none}.build-label{min-width:100%;font-size:10px}.stage-shell{padding:8px}.stage{width:min(100%,64.2857vh - 66.8571px)}.tutorial-overlay{padding:10px}.tutorial-panel{padding:12px}.tutorial-panel h2{font-size:18px}.tutorial-copy{font-size:14px}.tutorial-hint{font-size:12px}.touch-zone{border-width:2px}}@media (width<=760px),(hover:none) and (pointer:coarse){html,body{background:var(--bench);width:100%;height:100vh}body{position:fixed;inset:0}.app{background:var(--bench);grid-template-rows:1fr;width:100vw;height:100vh;min-height:100vh}.toolbar,.legend{display:none}.stage-shell{place-items:stretch stretch;width:100vw;height:100vh;min-height:0;padding:0;overflow:hidden}.stage{aspect-ratio:auto;width:100vw;max-width:none;height:100vh;box-shadow:none;border:0;border-radius:0}.stage-hud{top:max(8px, env(safe-area-inset-top));right:max(8px, env(safe-area-inset-right))}.readout{left:max(12px, env(safe-area-inset-left));right:max(12px, env(safe-area-inset-right));bottom:max(12px, env(safe-area-inset-bottom))}.menu-overlay{padding:max(14px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) max(14px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left))}}@supports (height:100dvh){@media (width<=520px){.stage{width:min(100%,64.2857dvh - 66.8571px)}}@media (width<=760px),(hover:none) and (pointer:coarse){html,body,.app,.stage-shell,.stage{height:100dvh}.stage{aspect-ratio:auto;width:100vw;max-width:none}}}@media (width<=520px),(hover:none),(pointer:coarse){.desktop-copy,.desktop-hint{display:none}.touch-copy,.touch-hint{display:block}}@media (hover:hover) and (pointer:fine) and (width>=521px){.touch-guide{display:none}}
