:root{--ink: #2a2140;--card: #fffdf7;--pink: #ff5d8f;--blue: #3aa0ff;--yellow: #ffd24a;--green: #5fc27e;--safe-b: env(safe-area-inset-bottom, 0px);--safe-l: env(safe-area-inset-left, 0px);--safe-r: env(safe-area-inset-right, 0px);--safe-t: env(safe-area-inset-top, 0px);--ui-edge: clamp(12px, 2.8vw, 28px);--ui-gap: clamp(8px, 1.8vw, 16px);--ui-hit: 52px;--ui-panel: min(720px, calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r)));--ui-panel-narrow: min(480px, calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r)));--hud-top: calc(var(--safe-t) + var(--ui-edge));--hud-bottom: calc(var(--safe-b) + var(--ui-edge));--hud-status-y: calc(var(--hud-top) + var(--ui-hit) + var(--ui-gap));--hud-caption-clearance: clamp(112px, 20vh, 168px);--z-hud-status: 14;--z-hud-controls: 28;--z-hud-feedback: 37;--z-hud-modal: 40;--z-hud-picker: 55}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;height:100%;overflow:hidden;background:#bfe6ff;font-family:Fredoka,Bungee,system-ui,sans-serif;color:var(--ink);-webkit-user-select:none;user-select:none;touch-action:manipulation}#app{position:fixed;inset:0}#app canvas{display:block;width:100%;height:100%}#hud{position:fixed;inset:0;pointer-events:none;z-index:10;isolation:isolate}#hud>*{pointer-events:auto}.topbar{position:absolute;top:var(--hud-top);left:calc(var(--ui-edge) + var(--safe-l));right:calc(var(--ui-edge) + var(--safe-r));display:flex;align-items:flex-start;justify-content:space-between;gap:var(--ui-gap);pointer-events:none}.progress{display:flex;flex:1 1 auto;flex-wrap:wrap;align-items:center;gap:clamp(4px,1.2vw,7px);max-width:min(54vw,420px);min-height:var(--ui-hit);background:#ffffffb3;padding:8px 12px;border-radius:999px;box-shadow:0 4px #00000014}.progress span{display:inline-flex;align-items:center;justify-content:center;inline-size:clamp(22px,4vw,30px);block-size:clamp(22px,4vw,30px);font-size:clamp(21px,4vw,28px);line-height:1;filter:grayscale(1) opacity(.35);transition:transform .25s,filter .25s}.progress span.on{filter:none;transform:scale(1.18)}.tools{display:flex;flex:0 0 auto;gap:var(--ui-gap);pointer-events:none}.iconbtn{pointer-events:auto;border:none;width:var(--ui-hit);height:var(--ui-hit);min-width:var(--ui-hit);min-height:var(--ui-hit);border-radius:50%;background:#ffffffd9;font-size:24px;cursor:pointer;box-shadow:0 4px #0000001f;touch-action:manipulation}.iconbtn:active{transform:translateY(3px);box-shadow:none}.iconbtn:focus-visible,.menubtn:focus-visible,.bigbtn:focus-visible,.drive-btn:focus-visible,.char-select-tile:focus-visible{outline:4px solid rgba(255,210,74,.95);outline-offset:4px}#hud>.menu{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:var(--hud-top) calc(var(--ui-edge) + var(--safe-r)) var(--hud-bottom) calc(var(--ui-edge) + var(--safe-l));background:radial-gradient(120% 120% at 50% 20%,#5ab4ff80,#285aa0d1);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:var(--z-hud-modal);opacity:0;pointer-events:none;transition:opacity .25s}#hud>.menu.show{opacity:1;pointer-events:auto}.menupanel{display:flex;flex-direction:column;align-items:center;gap:16px;width:var(--ui-panel-narrow);max-height:100%;overflow:auto;text-align:center;transform:scale(.85);transition:transform .25s}.menu.show .menupanel{transform:scale(1)}.menupanel .hero{font-size:clamp(60px,14vw,110px);line-height:1;animation:bob 1.6s ease-in-out infinite}.menupanel h2{margin:0 0 6px;font-size:clamp(30px,7vw,56px);color:#fff;text-shadow:0 5px 0 rgba(0,0,0,.2)}.menubtn{border:none;border-radius:999px;padding:16px 40px;min-width:min(320px,80vw);min-height:var(--ui-hit);font-family:inherit;font-size:clamp(20px,4vw,30px);font-weight:900;color:#fff;cursor:pointer;touch-action:manipulation}.menubtn.resume{background:var(--green);box-shadow:0 8px #3f9a5b}.menubtn.home{background:var(--pink);box-shadow:0 8px #c83a68}.menubtn:active{transform:translateY(5px);box-shadow:none}.boss{position:absolute;top:var(--hud-status-y);left:50%;transform:translate(-50%) translateY(-10px);width:min(380px,var(--ui-panel-narrow));text-align:center;pointer-events:none;opacity:0;z-index:var(--z-hud-status);transition:opacity .3s,transform .3s}.boss.show{opacity:1;transform:translate(-50%) translateY(0)}.boss .name{font-size:17px;font-weight:900;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.4);margin-bottom:4px;letter-spacing:.5px}.boss .bar{height:16px;border-radius:999px;background:#00000073;border:3px solid rgba(255,255,255,.85);overflow:hidden;box-shadow:0 4px #00000040}.boss .fill{height:100%;width:100%;background:linear-gradient(90deg,#ff7a3a,#ff3a5d);border-radius:999px;transition:width .25s ease-out}.gauge{position:absolute;left:50%;bottom:calc(var(--hud-bottom) + 2px);transform:translate(-50%);width:min(420px,var(--ui-panel-narrow));pointer-events:none;opacity:0;z-index:var(--z-hud-controls);transition:opacity .35s}.gauge.show{opacity:1}.gauge .track{height:16px;border-radius:999px;background:#00000073;border:2px solid rgba(255,255,255,.18);overflow:hidden;box-shadow:inset 0 2px 6px #00000080}.gauge .fill{height:100%;width:0%;border-radius:999px;background:linear-gradient(90deg,var(--blue),#6fd3ff,#bff0ff);box-shadow:0 0 14px #6fd3ffcc;transition:width .08s linear}.gauge .pressure{margin-top:7px;height:7px;border-radius:999px;background:#0006;overflow:hidden}.gauge .pbar{height:100%;width:0%;background:linear-gradient(90deg,#ffc857,#e63946);transition:width .05s linear}.gauge .lab{display:flex;justify-content:space-between;gap:12px;font-weight:700;font-size:13px;letter-spacing:.5px;margin-bottom:5px;text-transform:uppercase;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.4)}.gauge .lab .pct{color:var(--yellow)}.gauge .lab .score{color:#ffe17a;font-variant-numeric:tabular-nums}#hud:has(.water-gun-hud.show) .gauge{bottom:calc(var(--hud-bottom) + clamp(112px,19vh,176px))}.crosshair{position:fixed;left:50%;top:50%;width:62px;height:62px;margin:-31px 0 0 -31px;border:4px solid #fff;border-radius:50%;pointer-events:none;z-index:var(--z-hud-feedback);box-shadow:0 0 0 2px #00000059,0 0 14px #ffffff8c;transition:border-color .08s,box-shadow .08s;will-change:transform}.crosshair.hot{border-color:#6fe06f;box-shadow:0 0 0 2px #00000059,0 0 18px #6ee06ff2}.crosshair-dot{position:absolute;left:50%;top:50%;width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;background:#fff;box-shadow:0 0 6px #00000080}.touch-reticle{position:fixed;width:66px;height:66px;margin:-33px 0 0 -33px;left:0;top:0;z-index:var(--z-hud-feedback);pointer-events:none;opacity:0;transition:transform .06s,opacity .2s}.touch-reticle.show{opacity:1}.touch-reticle svg{display:block;filter:drop-shadow(0 0 6px rgba(111,211,255,.45))}.touch-reticle .halo{fill:#6fd3ff29;stroke:#6fd3ff8c;stroke-width:1.5}.touch-reticle .rim{fill:#ffffff1a;stroke:#fff;stroke-width:2.5;opacity:.75}.touch-reticle.hot .halo{fill:#ffd23f38;stroke:#ffd23fa6}.touch-reticle.hot .rim{stroke:#ffd23f;opacity:1}.drive-controls{position:fixed;inset:0;display:none;pointer-events:none;opacity:0;z-index:var(--z-hud-controls);transition:opacity .18s ease}.drive-controls.show{opacity:1}.drive-stick,.drive-actions{position:absolute;pointer-events:auto}.drive-stick{left:calc(var(--ui-edge) + var(--safe-l));bottom:calc(var(--hud-bottom) + 4px);width:clamp(116px,24vw,154px);height:clamp(116px,24vw,154px);border-radius:50%;touch-action:none}.drive-stick-pad,.drive-stick-knob{position:absolute;left:50%;top:50%;border-radius:50%}.drive-stick-pad{width:100%;height:100%;transform:translate(-50%,-50%);background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.2) 0 28%,transparent 30%),radial-gradient(circle at 50% 50%,#ffd24a29,#142e52bd);border:3px solid rgba(255,255,255,.58);box-shadow:inset 0 0 24px #ffffff1f,0 8px #00000029,0 14px 32px #00000047;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.drive-stick-knob{width:44%;height:44%;transform:translate(-50%,-50%);background:linear-gradient(180deg,#fff7b0,#ffd24a 55%,#f0a61f);border:3px solid rgba(255,255,255,.88);box-shadow:0 5px #74480047,0 10px 22px #0000004d;transition:box-shadow .08s;will-change:transform}.drive-stick.active .drive-stick-knob{box-shadow:0 2px #74480047,0 8px 18px #00000057}.drive-stick-hint{position:absolute;left:50%;bottom:-20px;transform:translate(-50%);padding:3px 9px;border-radius:999px;background:#2a2140bd;color:#fff;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:10px;letter-spacing:.7px;text-shadow:0 2px 0 rgba(0,0,0,.28)}.drive-actions{right:calc(var(--ui-edge) + var(--safe-r));bottom:calc(var(--hud-bottom) + 6px);display:grid;grid-template-columns:1fr 1fr;align-items:end;gap:clamp(10px,2.4vw,16px)}.drive-btn{width:clamp(76px,16vw,96px);height:clamp(76px,16vw,96px);border:3px solid rgba(255,255,255,.76);border-radius:50%;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(10px,2.5vw,13px);line-height:1;color:#fff;text-transform:uppercase;text-shadow:0 2px 0 rgba(0,0,0,.28);cursor:pointer;touch-action:none;box-shadow:0 8px #0003,0 14px 28px #0000003d}.drive-btn .drive-icon{font-size:clamp(24px,6vw,34px);line-height:1}.drive-btn.active,.drive-btn:active{transform:translateY(5px) scale(.98);box-shadow:0 3px #00000038,0 8px 16px #00000038}.drive-fire{background:linear-gradient(180deg,#ff8f3f,#ff3f63)}.drive-brake{background:linear-gradient(180deg,#5ec7ff,#2869d5)}@media (hover: none),(pointer: coarse),(max-width: 860px){.drive-controls{display:block}#hud:has(.drive-controls) .caption{bottom:calc(var(--hud-bottom) + clamp(148px,28vh,206px))}}@media (max-height: 520px) and (orientation: landscape){.drive-stick{width:clamp(92px,26vh,124px);height:clamp(92px,26vh,124px);bottom:calc(var(--safe-b) + 8px)}.drive-actions{bottom:calc(var(--safe-b) + 8px)}.drive-btn{width:clamp(62px,17vh,78px);height:clamp(62px,17vh,78px);font-size:9px}.drive-btn .drive-icon{font-size:clamp(20px,6vh,28px)}.drive-stick-hint{display:none}#hud:has(.drive-controls) .caption{bottom:calc(var(--safe-b) + 92px);max-width:min(380px,54vw)}}.battle-hud{position:fixed;inset:0;pointer-events:none;opacity:0;z-index:var(--z-hud-status);transition:opacity .2s ease}.battle-hud.show{opacity:1}.bh-meters{position:absolute;top:var(--hud-status-y);left:calc(var(--ui-edge) + var(--safe-l));display:flex;flex-direction:column;gap:6px;width:clamp(132px,30vw,188px)}.bh-health{display:flex;flex-wrap:wrap;align-items:center;gap:5px}.bh-pip{width:clamp(14px,3vw,18px);height:clamp(14px,3vw,18px);border-radius:50%;background:#ffffff38;border:2px solid rgba(255,255,255,.5);box-shadow:inset 0 0 6px #00000040}.bh-pip.on{background:linear-gradient(180deg,#ff6f8f,#ff2d55);border-color:#ffffffd9;box-shadow:0 0 8px #ff4060b3}.bh-life{font-size:clamp(13px,3vw,16px);line-height:1;filter:drop-shadow(0 2px 0 rgba(0,0,0,.25))}.bh-speed{height:9px;border-radius:999px;background:#141e2e80;border:2px solid rgba(255,255,255,.45);overflow:hidden}.bh-speed-fill{height:100%;width:100%;transform-origin:left center;transform:scaleX(0);border-radius:999px;background:linear-gradient(90deg,#5ec7ff,#ffd24a 70%,#ff8f3f);transition:transform .08s linear}.bh-radar{position:absolute;top:calc(var(--hud-status-y) + var(--ui-hit) + var(--ui-gap));right:calc(var(--ui-edge) + var(--safe-r));width:clamp(112px,26vw,168px);height:auto;filter:drop-shadow(0 6px 14px rgba(0,0,0,.3))}.bh-blast{position:absolute;left:50%;bottom:calc(var(--hud-bottom) + 2px);transform:translate(-50%);width:clamp(132px,32vw,188px);height:30px;border-radius:999px;background:#141e2e94;border:2px solid rgba(255,255,255,.5);overflow:hidden;display:flex;align-items:center;justify-content:center}.bh-blast-fill{position:absolute;inset:0;transform-origin:left center;transform:scaleX(0);background:linear-gradient(90deg,#ff8f3fb3,#ff3f63d9);transition:transform .08s linear}.bh-blast-label{position:relative;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:12px;letter-spacing:1px;color:#ffffffb3;text-shadow:0 2px 0 rgba(0,0,0,.3)}.bh-blast.ready{border-color:#ffe08a;box-shadow:0 0 14px #ffd24a99}.bh-blast.ready .bh-blast-label{color:#fff}.bh-reticle{position:absolute;left:0;top:0;margin-left:-27px;margin-top:-27px;opacity:0;transition:opacity .12s ease}.bh-reticle.show{opacity:1}.bh-reticle .ring{fill:none;stroke:#ffe08a;stroke-width:3;opacity:.95}.bh-reticle .tick{stroke:#fff;stroke-width:2.5;stroke-linecap:round}@media (max-height: 520px) and (orientation: landscape){.bh-radar{width:clamp(96px,22vh,132px);top:calc(var(--hud-status-y) + 6px)}.bh-blast{bottom:calc(var(--safe-b) + 8px);height:24px;width:clamp(116px,26vw,152px)}}.water-gun-hud{position:fixed;left:50%;bottom:var(--safe-b);width:min(38vw,240px);height:min(28vh,190px);margin-left:min(-19vw,-120px);z-index:var(--z-hud-controls);pointer-events:none;opacity:0;transform:translateY(42%);transition:opacity .4s ease,transform .45s cubic-bezier(.22,1,.36,1);filter:drop-shadow(0 8px 18px rgba(0,0,0,.45))}.water-gun-hud.show{opacity:1;transform:translateY(6%)}.water-gun-hud.spraying{animation:wg-recoil .12s ease-in-out infinite alternate}.water-gun-hud.spraying .wg-spray{opacity:1}@keyframes wg-recoil{0%{transform:translateY(6%)}to{transform:translateY(10%)}}.water-gun-hud .wg-body{position:absolute;left:18%;bottom:8%;width:52%;height:38%;border-radius:14px 14px 10px 10px;background:linear-gradient(180deg,#ff4d5e,#c62839);border:3px solid rgba(255,255,255,.25)}.water-gun-hud .wg-tank{position:absolute;left:28%;bottom:38%;width:28%;height:34%;border-radius:50%;background:linear-gradient(135deg,#8ce6fff2,#3caadcd9);border:3px solid rgba(255,255,255,.45);box-shadow:inset 0 -8px 16px #00507840}.water-gun-hud .wg-barrel{position:absolute;left:8%;bottom:22%;width:72%;height:16%;border-radius:999px;background:linear-gradient(180deg,#ffe17a,#e6a800);border:2px solid rgba(255,255,255,.35)}.water-gun-hud .wg-nozzle{position:absolute;left:-2%;bottom:20%;width:14%;height:20%;border-radius:6px;background:#ffc857;border:2px solid rgba(255,255,255,.3)}.water-gun-hud .wg-grip{position:absolute;right:22%;bottom:0;width:22%;height:42%;border-radius:8px 8px 12px 12px;background:linear-gradient(180deg,#3a2850,#1f1428);border:2px solid rgba(255,255,255,.15);transform:rotate(-8deg)}.water-gun-hud .wg-spray{position:absolute;left:-18%;bottom:24%;width:22%;height:22%;border-radius:50% 0 50% 50%;background:radial-gradient(circle at 70% 50%,#b4ebffe6,#6fd3ff33);opacity:0;transition:opacity .08s;transform:rotate(-25deg)}.hud-pop{position:fixed;z-index:var(--z-hud-feedback);pointer-events:none;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:15px;color:#cdf3ff;text-shadow:0 2px 4px rgba(0,0,0,.65);transform:translate(-50%,-50%);will-change:transform,opacity}.combo-badge{position:fixed;z-index:var(--z-hud-feedback);pointer-events:none;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:21px;color:var(--yellow);text-shadow:0 2px 0 #b8860b,0 0 12px rgba(255,210,63,.6);opacity:0;transform:translate(-50%,-50%) scale(.8);transition:opacity .12s,transform .12s}.combo-badge.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.scene-banner{position:absolute;top:var(--hud-status-y);left:50%;transform:translate(-50%);width:var(--ui-panel);text-align:center;pointer-events:none;z-index:var(--z-hud-status);opacity:0;transition:opacity .4s,transform .4s}.scene-banner.show{opacity:1}.scene-banner.hide{opacity:0;transform:translate(-50%) translateY(-14px)}.scene-banner h1{margin:0;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(28px,6vw,58px);line-height:1;color:var(--yellow);letter-spacing:1px;text-shadow:0 3px 0 rgba(0,0,0,.25),0 6px 0 rgba(0,0,0,.18),0 0 26px rgba(255,210,63,.45)}.scene-banner h1.countdown{font-size:clamp(54px,16vw,150px)}.scene-banner p{margin:4px 0 0;font-weight:600;font-size:clamp(12px,2vw,16px);color:#fff;opacity:.85;text-shadow:0 2px 0 rgba(0,0,0,.35)}.caption{position:absolute;left:50%;bottom:calc(var(--hud-bottom) + var(--hud-caption-clearance));transform:translate(-50%) translateY(20px);width:max-content;max-width:var(--ui-panel);background:var(--card);border:4px solid #fff;border-radius:26px;padding:16px 26px;font-size:clamp(20px,3.4vw,30px);font-weight:800;line-height:1.25;text-align:center;box-shadow:0 10px #0000001f;opacity:0;z-index:var(--z-hud-status);transition:opacity .25s,transform .25s}#hud:has(.water-gun-hud.show) .caption,#hud:has(.gauge.show) .caption{bottom:calc(var(--hud-bottom) + clamp(176px,31vh,236px))}.caption.show{opacity:1;transform:translate(-50%) translateY(0)}.banner{position:absolute;left:50%;top:clamp(126px,28vh,260px);transform:translate(-50%,-50%) scale(.7);width:max-content;max-width:var(--ui-panel);text-align:center;opacity:0;transition:opacity .35s,transform .35s;pointer-events:none;padding:14px 30px;border-radius:26px;background:radial-gradient(120% 130% at 50% 40%,#142c4e6b,#142c4e24);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.banner.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.banner h1{margin:0;font-size:clamp(34px,7vw,64px);color:#fff;text-shadow:0 5px 0 rgba(0,0,0,.18),0 0 18px rgba(255,255,255,.4)}.banner p{margin:6px 0 0;font-size:clamp(18px,3.6vw,28px);font-weight:800;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.18)}.card{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:clamp(10px,2.5vh,18px);padding:var(--hud-top) calc(var(--ui-edge) + var(--safe-r)) var(--hud-bottom) calc(var(--ui-edge) + var(--safe-l));overflow:auto;text-align:center;background:radial-gradient(120% 120% at 50% 20%,#5ab4ff80,#285aa0c7);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:20;opacity:0;transition:opacity .28s}.card.show,.dialog-strip.show{opacity:1}.dialog-panel{display:grid;grid-template-columns:auto 1fr;gap:clamp(12px,2.5vw,18px);align-items:start;width:var(--ui-panel);padding:clamp(14px,2.8vh,20px);background:var(--card);border:4px solid #fff;border-radius:22px;box-shadow:0 10px #00000024,0 0 0 1px #2a214014;text-align:left}.dialog-panel--solo{grid-template-columns:1fr}.dialog-portrait{width:clamp(76px,18vw,112px);height:clamp(76px,18vw,112px);border-radius:16px;border:3px solid #fff;box-shadow:0 5px #0000001f;object-fit:cover;object-position:center 12%;background:linear-gradient(145deg,#8fd0ff,#3a7fd4);flex-shrink:0}.dialog-portrait.emoji{display:flex;align-items:center;justify-content:center;font-size:clamp(40px,10vw,58px);line-height:1}.dialog-body{min-width:0;display:flex;flex-direction:column;gap:6px}.dialog-name{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(14px,2.8vh,18px);font-weight:400;color:var(--blue);letter-spacing:.4px;text-transform:uppercase}.dialog-headline{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(18px,3.6vh,26px);font-weight:400;color:var(--ink);line-height:1.15;text-wrap:balance}.dialog-text{font-size:clamp(15px,3vh,22px);font-weight:600;color:var(--ink);line-height:1.38;text-wrap:pretty}.dialog-btn{margin-top:clamp(4px,1vh,8px);min-width:min(280px,70vw)}.dialog-strip{position:absolute;left:50%;bottom:var(--hud-bottom);transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:18;pointer-events:auto;opacity:0;transition:opacity .22s,transform .22s}.dialog-strip.show{transform:translate(-50%) translateY(0)}.dialog-strip:not(.show){transform:translate(-50%) translateY(16px)}.dialog-strip .dialog-panel{width:min(680px,var(--ui-panel))}.dialog-strip .dialog-btn{animation:none;padding:12px 32px;font-size:clamp(16px,3vh,22px);margin-top:0}.speech-strip{position:absolute;left:50%;bottom:var(--hud-bottom);transform:translate(-50%) translateY(16px);z-index:18;pointer-events:none;opacity:0;transition:opacity .22s,transform .22s}.speech-strip.show{opacity:1;transform:translate(-50%) translateY(0)}.speech-strip .dialog-panel{width:min(680px,var(--ui-panel))}.title-splash{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(10px,2vh,16px);padding:var(--hud-top) calc(var(--ui-edge) + var(--safe-r)) var(--hud-bottom) calc(var(--ui-edge) + var(--safe-l));overflow:auto;text-align:center;background:radial-gradient(130% 120% at 50% 15%,#6ec8ff8c,#235096e0);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:20;opacity:0;transition:opacity .28s}.title-splash.show{opacity:1}.title-splash:not(.show),.dialog-card:not(.show),.dialog-strip:not(.show){pointer-events:none}.title-hero{width:clamp(120px,28vw,180px);height:clamp(120px,28vw,180px);border-radius:24px;border:4px solid #fff;box-shadow:0 8px #00000024;object-fit:cover;object-position:center 12%;background:linear-gradient(145deg,#8fd0ff,#3a7fd4)}.title-hero.emoji{display:flex;align-items:center;justify-content:center;font-size:clamp(64px,16vw,96px);line-height:1}.title-splash-heading{margin:0;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(30px,6.5vw,52px);font-weight:400;color:#fff;line-height:1.1;text-shadow:0 4px 0 rgba(0,0,0,.18)}.title-splash-sub{margin:0;font-size:clamp(18px,3.6vw,26px);font-weight:700;color:#e8f6ff;line-height:1.3}.title-splash-text{display:flex;flex-direction:column;align-items:center;gap:clamp(10px,2vh,16px);min-width:0}.title-splash-btns{margin-top:clamp(8px,2vh,14px);display:flex;flex-direction:column;align-items:center;gap:clamp(10px,1.6vh,16px)}.title-splash-btn{min-width:min(280px,70vw)}.card .big{font-size:clamp(32px,7.5vh,64px);color:#fff;margin:0;text-shadow:0 6px 0 rgba(0,0,0,.22);line-height:1.08;max-width:min(720px,94vw);text-wrap:balance}.card .speaker-chip{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 10px;border-radius:999px;background:#ffffff38;border:2px solid rgba(255,255,255,.45);box-shadow:0 4px #00000026}.card .speaker-chip .chip-emoji{font-size:clamp(20px,4vh,28px);line-height:1}.card .speaker-chip .chip-label{font-size:clamp(14px,2.8vh,20px);font-weight:800;color:#fff;text-shadow:0 2px 0 rgba(0,0,0,.2);letter-spacing:.3px}.card .sub{font-size:clamp(15px,3.2vh,24px);color:#fff;font-weight:600;max-width:min(560px,90vw);line-height:1.35;text-shadow:0 3px 0 rgba(0,0,0,.2);text-wrap:balance}.card .hero{font-size:clamp(56px,14vh,120px);line-height:1;animation:bob 1.6s ease-in-out infinite}.bigbtn{pointer-events:auto;border:none;border-radius:999px;padding:clamp(12px,2vh,18px) clamp(28px,6vw,44px);min-height:var(--ui-hit);font-family:inherit;font-size:clamp(18px,3.6vh,30px);font-weight:700;color:#fff;background:var(--pink);cursor:pointer;box-shadow:0 9px #c83a68;animation:pulse 1.3s ease-in-out infinite;margin-top:clamp(4px,1vh,10px);touch-action:manipulation}.bigbtn:hover,.menubtn:hover,.iconbtn:hover{filter:brightness(1.04)}.bigbtn:active{transform:translateY(6px);box-shadow:0 3px #c83a68}.card.result .resultbtns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:clamp(6px,1.5vh,14px)}.card.result .resultbtns .bigbtn{animation:none;margin-top:0;min-height:48px}.bigbtn.blue{background:var(--blue);box-shadow:0 9px #1d6fc0}.bigbtn.blue:active{transform:translateY(6px);box-shadow:0 3px #1d6fc0}.bigbtn.ghost{background:#ffffff2e;box-shadow:0 9px #00000038}.bigbtn.ghost:active{transform:translateY(6px);box-shadow:0 3px #00000038}.loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(10px,2.5vh,18px);padding:var(--hud-top) calc(var(--ui-edge) + var(--safe-r)) var(--hud-bottom) calc(var(--ui-edge) + var(--safe-l));background-color:#4aa6ff;background-size:cover;background-position:center;z-index:30;transition:opacity .4s}.loading .hero{font-size:clamp(56px,14vh,96px);animation:bob 1.4s ease-in-out infinite}.loading .title{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(22px,5.2vh,40px);font-weight:800;color:#fff;text-align:center;text-wrap:balance;max-width:min(560px,90vw);line-height:1.1;text-shadow:0 5px 0 rgba(0,0,0,.22),0 0 18px rgba(255,255,255,.35)}.loading .bar{width:min(280px,70vw);height:clamp(14px,2.8vh,22px);border-radius:999px;background:#ffffff80;overflow:hidden;box-shadow:inset 0 2px 4px #00000026}.loading .fill{height:100%;width:0;background:var(--yellow);transition:width .2s}.loading .label{font-size:clamp(16px,3.4vh,24px);font-weight:700;color:#fff;text-shadow:0 3px 0 rgba(0,0,0,.18);text-wrap:balance;max-width:min(420px,88vw);text-align:center;line-height:1.25}.hidden{opacity:0!important;pointer-events:none!important}@media (max-width: 720px){:root{--ui-edge: clamp(10px, 3.5vw, 18px);--ui-hit: 48px;--hud-caption-clearance: clamp(96px, 18vh, 132px)}.topbar{align-items:flex-start}.progress{max-width:calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r) - 112px);padding:7px 10px}.tools{gap:8px}.iconbtn{font-size:22px}.scene-banner{top:calc(var(--hud-status-y) + 4px)}.scene-banner h1{font-size:clamp(24px,8vw,42px)}.scene-banner p{font-size:clamp(11px,3.4vw,14px)}.caption{padding:12px 18px;font-size:clamp(17px,5.2vw,24px)}.dialog-panel{grid-template-columns:1fr;justify-items:center;text-align:center}.dialog-body{align-items:center}}@media (max-width: 420px){.progress{max-width:calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r) - 104px);gap:3px}.progress span{inline-size:20px;block-size:20px;font-size:20px}#hud:has(.water-gun-hud.show) .gauge{bottom:calc(var(--hud-bottom) + clamp(92px,16vh,136px))}}@keyframes pop-rise{0%{transform:translate(-50%,-50%);opacity:1}to{transform:translate(-50%,-150%);opacity:0}}@keyframes bob{50%{transform:translateY(-12px)}}@keyframes pulse{50%{transform:scale(1.06)}}@media (max-height: 520px) and (orientation: landscape){:root{--ui-edge: clamp(8px, 2vh, 14px);--ui-hit: 44px;--hud-caption-clearance: clamp(72px, 20vh, 104px)}.progress{min-height:var(--ui-hit);max-width:42vw;padding-block:5px}.progress span{inline-size:19px;block-size:19px;font-size:19px}.iconbtn{font-size:20px}.boss,.scene-banner{top:calc(var(--hud-top) + 46px)}.gauge{width:min(340px,45vw)}#hud:has(.water-gun-hud.show) .gauge{bottom:calc(var(--hud-bottom) + clamp(74px,24vh,116px))}.water-gun-hud{width:min(25vw,170px);height:min(38vh,130px);margin-left:min(-12.5vw,-85px)}.card{gap:8px;padding-inline:calc(var(--ui-edge) + var(--safe-l)) calc(var(--ui-edge) + var(--safe-r))}.card .hero{font-size:clamp(44px,11vh,64px)}.card .big{font-size:clamp(26px,6.2vh,38px)}.card .sub{font-size:clamp(13px,2.8vh,17px);max-width:min(480px,86vw)}.bigbtn{padding:10px 32px;font-size:clamp(16px,3.2vh,22px);margin-top:4px}.loading .hero{font-size:clamp(44px,11vh,64px)}.loading .label{font-size:clamp(14px,3vh,18px)}.title-splash{flex-direction:row;justify-content:center;align-items:center;gap:clamp(20px,5vw,56px);padding:calc(8px + var(--safe-t)) 32px calc(10px + var(--safe-b))}.title-hero{width:clamp(92px,32vh,148px);height:clamp(92px,32vh,148px)}.title-hero.emoji{font-size:clamp(50px,18vh,84px)}.title-splash-text{align-items:flex-start;text-align:left;gap:clamp(6px,1.6vh,12px)}.title-splash-heading{font-size:clamp(24px,7.4vh,40px)}.title-splash-sub{font-size:clamp(13px,3.4vh,19px)}.title-splash-btns{margin-top:clamp(4px,1.4vh,10px)}.dialog-panel{gap:clamp(10px,1.8vw,14px);padding:clamp(9px,2vh,13px) clamp(12px,2vw,16px);border-radius:18px}.dialog-portrait{width:clamp(52px,17vh,84px);height:clamp(52px,17vh,84px);border-radius:13px}.dialog-portrait.emoji{font-size:clamp(30px,11vh,46px)}.dialog-name{font-size:clamp(12px,3vh,16px)}.dialog-text{font-size:clamp(13px,3.4vh,18px);line-height:1.3}.dialog-headline{font-size:clamp(16px,4.6vh,24px)}.speech-strip,.dialog-strip{bottom:calc(8px + var(--safe-b))}.speech-strip .dialog-panel,.dialog-strip .dialog-panel{width:min(560px,86vw)}.caption{bottom:calc(86px + var(--safe-b));font-size:clamp(15px,4vh,22px);padding:10px 20px}}#hud.stinky-feet-hud .scene-banner{top:calc(var(--safe-t) + 10px);left:calc(var(--ui-edge) + var(--safe-l));width:min(390px,calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r) - 128px));padding:10px 14px 11px;border:2px solid rgba(255,255,255,.62);border-radius:18px;background:linear-gradient(135deg,#2b5c2ddb,#2a2140b8),radial-gradient(circle at 18% 0%,rgba(255,210,74,.35),transparent 46%);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 8px #0000001f,0 16px 34px #0000003d;text-align:left;transform:translateY(-10px)}#hud.stinky-feet-hud .scene-banner.show{transform:translateY(0)}#hud.stinky-feet-hud .scene-banner.hide{transform:translateY(-10px)}#hud.stinky-feet-hud .scene-banner h1{font-size:clamp(20px,3.2vw,32px);letter-spacing:.5px;text-shadow:0 2px 0 rgba(0,0,0,.32),0 0 18px rgba(255,210,63,.35)}#hud.stinky-feet-hud .scene-banner p{margin-top:3px;max-width:34ch;font-size:clamp(11px,1.55vw,14px);font-weight:800;line-height:1.2;opacity:.92}#hud.stinky-feet-hud .scene-banner.countdown-mode{top:clamp(78px,20vh,150px);left:50%;width:max-content;max-width:var(--ui-panel);padding:0;border:0;border-radius:0;background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;text-align:center;transform:translate(-50%)}#hud.stinky-feet-hud .scene-banner.countdown-mode h1.countdown{font-size:clamp(58px,15vw,142px)}#hud.stinky-feet-hud .gauge{left:calc(var(--ui-edge) + var(--safe-l));bottom:calc(var(--hud-bottom) + 8px);transform:none;width:min(360px,calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r) - 300px));min-width:260px;padding:10px 12px 11px;border:2px solid rgba(255,255,255,.5);border-radius:18px;background:linear-gradient(180deg,#152539d1,#131c2ab3);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);box-shadow:0 8px #0000001f,0 16px 30px #0000003d}#hud.stinky-feet-hud:has(.water-gun-hud.show) .gauge{bottom:calc(var(--hud-bottom) + 8px)}#hud.stinky-feet-hud .gauge .lab{margin-bottom:7px;font-size:12px;line-height:1}#hud.stinky-feet-hud .gauge .track{height:18px;border-color:#ffffff52;background:#040e159e}#hud.stinky-feet-hud .gauge .pressure{margin-top:6px;height:6px;background:#ffffff29}#hud.stinky-feet-hud .water-gun-hud{bottom:calc(var(--safe-b) - 8px);width:min(30vw,210px);height:min(24vh,160px);margin-left:min(-15vw,-105px);filter:drop-shadow(0 7px 14px rgba(0,0,0,.38))}#hud.stinky-feet-hud .water-gun-hud.show{transform:translateY(14%)}#hud.stinky-feet-hud .water-gun-hud.spraying{animation-name:stinky-wg-recoil}@keyframes stinky-wg-recoil{0%{transform:translateY(14%)}to{transform:translateY(18%)}}#hud.stinky-feet-hud .caption{left:auto;right:calc(var(--ui-edge) + var(--safe-r));bottom:calc(var(--hud-bottom) + 92px);transform:translateY(14px);width:max-content;max-width:min(310px,32vw);padding:10px 16px;border-width:3px;border-radius:22px;font-size:clamp(15px,1.9vw,20px);line-height:1.15;box-shadow:0 7px #0000001f,0 14px 26px #0003}#hud.stinky-feet-hud .caption.show{transform:translateY(0)}#hud.stinky-feet-hud:has(.water-gun-hud.show) .caption,#hud.stinky-feet-hud:has(.gauge.show) .caption{bottom:calc(var(--hud-bottom) + 92px)}#hud.stinky-feet-hud .touch-reticle{width:58px;height:58px;margin:-29px 0 0 -29px}@media (max-width: 720px){#hud.stinky-feet-hud .scene-banner{width:calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r) - 104px);padding:9px 12px 10px}#hud.stinky-feet-hud .scene-banner h1{font-size:clamp(18px,6vw,28px)}#hud.stinky-feet-hud .scene-banner p{font-size:clamp(10px,3vw,13px)}#hud.stinky-feet-hud .gauge{left:50%;bottom:calc(var(--hud-bottom) + clamp(82px,16vh,120px));transform:translate(-50%);width:min(340px,calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r)));min-width:0}#hud.stinky-feet-hud:has(.water-gun-hud.show) .gauge{bottom:calc(var(--hud-bottom) + clamp(82px,16vh,120px))}#hud.stinky-feet-hud .caption{right:50%;bottom:calc(var(--hud-bottom) + 10px);max-width:min(340px,calc(100vw - (var(--ui-edge) * 2) - var(--safe-l) - var(--safe-r)));transform:translate(50%,12px)}#hud.stinky-feet-hud .caption.show{transform:translate(50%)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}}.char-select-overlay{position:fixed;inset:0;z-index:var(--z-hud-picker);display:flex;align-items:center;justify-content:center;padding:var(--hud-top) calc(var(--ui-edge) + var(--safe-r)) var(--hud-bottom) calc(var(--ui-edge) + var(--safe-l));background:#0a1e37b8;opacity:0;transition:opacity .22s ease;pointer-events:auto}.char-select-overlay.show{opacity:1}.char-select-card{display:flex;flex-direction:column;width:min(640px,var(--ui-panel));max-height:100%;overflow:auto;padding:24px 20px 28px;gap:12px;text-align:center;background:#142e52f0;border:4px solid rgba(255,255,255,.92);border-radius:28px;box-shadow:0 18px #0000002e,0 18px 48px #00000059}.char-select-title{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(28px,5vw,40px);color:#fff14d;margin:0}.char-select-sub{font-family:Fredoka,system-ui,sans-serif;font-size:clamp(15px,3vw,18px);color:#d8f1ff;margin:0 0 8px}.char-select-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.char-select-tile{display:flex;flex-direction:column;align-items:center;gap:6px;min-height:120px;min-width:48px;padding:14px 10px;border:2px solid rgba(255,255,255,.25);border-radius:16px;background:#ffffff14;cursor:pointer;touch-action:manipulation;transition:transform .12s,border-color .12s,background .12s}.char-select-tile:hover,.char-select-tile:focus-visible{transform:scale(1.03);border-color:#fff14d;background:#fff14d1f}.char-select-portrait{width:56px;height:56px;border-radius:50%;object-fit:cover;object-position:center 12%;border:2px solid rgba(255,255,255,.5);background:linear-gradient(145deg,#8fd0ff,#3a7fd4)}.char-select-emoji{font-size:48px;line-height:1}.char-select-name{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:17px;color:#fff}.char-select-tag{font-family:Fredoka,system-ui,sans-serif;font-size:12px;color:#9adcf5;line-height:1.2}@media (max-width: 420px){.char-select-grid{gap:8px}.char-select-tile{min-height:108px;padding:10px 8px}}@media (max-height: 520px) and (orientation: landscape){.char-select-card{width:min(880px,var(--ui-panel));padding:clamp(12px,3vh,18px) 18px;gap:clamp(6px,1.6vh,10px)}.char-select-title{font-size:clamp(22px,5.6vh,34px)}.char-select-sub{font-size:clamp(13px,3vh,16px);margin:0 0 4px}.char-select-grid{grid-template-columns:repeat(4,1fr);gap:10px}.char-select-tile{min-height:0;gap:4px;padding:10px 8px}.char-select-portrait{width:clamp(44px,12vh,58px);height:clamp(44px,12vh,58px)}.char-select-emoji{font-size:clamp(34px,11vh,48px)}.char-select-name{font-size:clamp(13px,3vh,16px)}.char-select-tag{font-size:clamp(10px,2.4vh,12px)}}.race-select-grid{grid-template-columns:repeat(4,1fr)}@media (max-width: 520px){.race-select-grid{grid-template-columns:repeat(3,1fr)}}.mash-btn{position:fixed;left:50%;bottom:max(16px,env(safe-area-inset-bottom));transform:translate(-50%) translateY(120%);z-index:42;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:min(92vw,420px);min-height:clamp(88px,18vh,120px);padding:12px 24px;border:none;border-radius:28px;background:linear-gradient(180deg,#ff6b9d,#e63946 55%,#c1121f);box-shadow:0 8px #8b1020,0 14px 32px #00000059;color:#fff;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;transition:transform .22s ease,opacity .22s ease;opacity:0}.mash-btn.show{transform:translate(-50%) translateY(0);opacity:1}.mash-btn .mash-emoji{font-size:clamp(28px,6vh,40px);line-height:1}.mash-btn .mash-label{font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:clamp(22px,5vh,32px);letter-spacing:.04em;text-shadow:0 2px 0 rgba(0,0,0,.25)}.mash-btn:active,.mash-btn.mash-pop{animation:mash-pop .18s ease-out}@keyframes mash-pop{0%{transform:translate(-50%) scale(1)}40%{transform:translate(-50%) scale(.92,.88)}to{transform:translate(-50%) scale(1)}}.mash-btn.show:active,.mash-btn.show.mash-pop{animation:mash-pop .18s ease-out}#hud:has(.mash-btn.show) .gauge{bottom:calc(max(16px,env(safe-area-inset-bottom)) + clamp(100px,20vh,132px))}.race-lanes-hud{position:fixed;left:max(8px,env(safe-area-inset-left));top:50%;transform:translateY(-50%) translate(-120%);z-index:38;display:flex;flex-direction:column;gap:5px;width:min(38vw,168px);padding:10px 8px;border-radius:14px;background:#0a0c1cb8;border:2px solid rgba(255,255,255,.18);box-shadow:0 8px 24px #00000059;opacity:0;transition:transform .28s ease,opacity .28s ease;pointer-events:none}.race-lanes-hud.show{transform:translateY(-50%) translate(0);opacity:1}.race-lane-row{display:flex;align-items:center;gap:6px}.race-lane-row.player .race-lane-track{box-shadow:0 0 0 2px #ffd23f}.race-lane-num{flex:0 0 22px;width:22px;height:22px;border-radius:50%;font-family:Bungee,Fredoka,system-ui,sans-serif;font-size:11px;line-height:22px;text-align:center;color:#fff;text-shadow:0 1px 0 rgba(0,0,0,.35);border:2px solid rgba(255,255,255,.85)}.race-lane-track{flex:1;height:10px;border-radius:6px;background:#ffffff1f;overflow:hidden}.race-lane-fill{height:100%;width:2%;border-radius:6px;transition:width .08s linear}@media (max-width: 520px){.race-lanes-hud{width:min(42vw,140px);gap:4px;padding:8px 6px}.race-lane-num{flex:0 0 18px;width:18px;height:18px;font-size:9px;line-height:18px}.race-lane-track{height:8px}}
