html,body,#app{width:100%;height:100%;margin:0}:root{--app-height: 100vh;--game-width: 560px;--panel-bg: rgba(8, 10, 19, .74);--panel-border: rgba(245, 241, 223, .14);--gold: #ffd166;--mint: #11d6a0}*,*:before,*:after{box-sizing:border-box}body{overflow:hidden;background:#090a12;color:#f5f1df;font-family:Inter,Trebuchet MS,Microsoft JhengHei,sans-serif}#app{position:relative;display:flex;min-height:100%;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:12px;background:linear-gradient(180deg,#13241fb8,#090a1200 24%),linear-gradient(135deg,#6c20402e,#0f5d631f 46%,#c99b481f)}#game-wrap{position:relative;width:min(calc(100vw - 24px),var(--game-width));aspect-ratio:560 / 760}#game{display:grid;place-items:center;width:100%;height:100%}canvas{display:block;max-width:100%;max-height:100%;margin:auto;touch-action:none;-webkit-user-select:none;user-select:none}button{position:relative;overflow:hidden;min-height:44px;border:1px solid rgba(245,241,223,.18);border-radius:8px;color:#fdf8e8;background:linear-gradient(180deg,#20243ff5,#0d101ff2);box-shadow:inset 0 1px #ffffff1a,0 8px 18px #00000040;font:inherit;font-weight:800;cursor:pointer;transition:border-color .16s ease,filter .16s ease,transform .12s ease}button:not(:disabled):hover{border-color:#ffd1666b;filter:brightness(1.08)}button:not(:disabled):active{transform:translateY(1px) scale(.99)}button:disabled{cursor:not-allowed;opacity:.45}#hud,#controls{z-index:2;width:min(100vw - 24px,760px)}#hud{display:flex;flex-direction:column;gap:6px}.status-strip{display:grid;grid-template-columns:.78fr 1.24fr .88fr;gap:6px}.stat,#progress-panel{border:1px solid var(--panel-border);border-radius:8px;background:var(--panel-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat{display:grid;min-height:40px;min-width:0;grid-template-columns:auto minmax(0,1fr);align-items:end;gap:6px;padding:6px 10px}.label{color:#f5f1dfa8;font-size:10px;font-weight:700;letter-spacing:0}.value{min-width:0;overflow:hidden;color:#fff7d8;font-size:19px;font-weight:900;line-height:1.1;text-overflow:ellipsis;white-space:nowrap}.score .value{color:#ffd166}#ui-time.low{color:#ff5f7d}#progress-panel{padding:7px 9px}.progress-top,.best{display:flex;align-items:center;justify-content:space-between;color:#f5f1dfbd;font-size:11px;font-weight:700;gap:8px}.progress-top strong,.best span{color:#fff7d8}.tier-chip{display:flex;min-width:0;align-items:baseline;gap:6px}.tier-name{min-width:0;overflow:hidden;color:#fff7d8;font-size:14px;font-weight:900;line-height:1;text-overflow:ellipsis;white-space:nowrap}.progress-track{height:6px;margin:5px 0 4px;overflow:hidden;border-radius:8px;background:#0000006b}#ui-progress{width:0%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--mint),var(--gold),#ff5f7d);transition:width .2s ease}#controls{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.control-btn{display:grid;min-height:40px;place-items:center;padding:0}.control-icon{color:#fff7d8;font-size:22px;font-weight:900;line-height:1}.control-count{position:absolute;right:8px;bottom:5px;color:var(--gold);font-size:10px;font-weight:900;line-height:1}.sound-icon{position:relative}#sound-btn.off{color:#f5f1df9e;background:#12152694}#sound-btn.off .sound-icon:after{position:absolute;top:50%;right:-5px;left:-5px;height:2px;border-radius:999px;background:#ff5f7d;content:"";transform:rotate(-35deg)}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}#combo-toast{position:absolute;top:18px;left:50%;z-index:4;padding:6px 14px;border-radius:999px;color:#0d1120;background:#ffd166;font-size:18px;font-weight:900;opacity:0;pointer-events:none;transform:translate(-50%) scale(.86)}#combo-toast.show{animation:combo-pop .64s ease}@keyframes combo-pop{0%{opacity:0;transform:translate(-50%) scale(.75)}28%{opacity:1;transform:translate(-50%) scale(1.08)}to{opacity:0;transform:translate(-50%) scale(1)}}.overlay{position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:22px;background:#05060cb8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.overlay.hidden,.hidden{display:none!important}.overlay-card{width:min(370px,100%);padding:24px;border:1px solid rgba(255,209,102,.34);border-radius:8px;background:linear-gradient(160deg,#121526f5,#111f22f5),#121526;box-shadow:0 24px 80px #0000008c;text-align:center}.eyebrow{margin:0 0 8px;color:#7ff7dc;font-size:12px;font-weight:900;letter-spacing:0;text-transform:uppercase}.overlay-card h1{margin:0 0 10px;color:#fff8dc;font-size:30px;line-height:1.1}.overlay-card p{margin:0;color:#f5f1dfc7;font-size:15px;line-height:1.55}.overlay-big{margin:16px 0 2px;color:#ffd166;font-size:24px;font-weight:900}#overlay-button{width:100%;margin-top:18px;color:#111322;background:linear-gradient(90deg,#ffd166,#11d6a0)}@media(max-width:680px){html,body,#app{height:100vh;height:100svh;height:100dvh;height:var(--app-height)}#app{min-height:100vh;min-height:100svh;min-height:100dvh;min-height:var(--app-height);justify-content:flex-start;gap:5px;overflow:hidden;padding:max(6px,env(safe-area-inset-top)) 4px max(6px,env(safe-area-inset-bottom))}#hud{width:min(calc(100vw - 10px),560px);gap:5px}.status-strip{gap:5px}.stat{min-height:34px;gap:4px;padding:4px 8px}.label{font-size:9px}.value{font-size:15px}#progress-panel{padding:5px 8px}.tier-name{font-size:12px}.progress-top,.best{font-size:10px}.progress-track{height:5px;margin:4px 0 3px}#game-wrap{width:min(calc(100vw - 8px),var(--game-width))}#controls{width:min(calc(100vw - 10px),560px);gap:5px;margin-top:auto}button,.control-btn{min-height:36px}.control-icon{font-size:20px}.control-count{right:6px;bottom:4px;font-size:9px}.overlay-card h1{font-size:26px}}
