*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--px-font:"Press Start 2P", "Courier New", monospace;--ink:#1a1a2e}html,body{height:100%;font-family:var(--px-font);touch-action:none;-webkit-user-select:none;user-select:none;image-rendering:pixelated;background:#58aee8;overflow:hidden}#game{touch-action:none;width:100vw;height:100vh;image-rendering:pixelated;position:fixed;inset:0}.hidden{display:none!important}.screen{padding:16px calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left));flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:fixed;inset:0;overflow-y:auto}#home-logo{width:min(440px,84vw);image-rendering:pixelated;filter:drop-shadow(6px 6px #0000004d);animation:2.4s steps(6,end) infinite bob}.logo-small{width:min(250px,55vw);image-rendering:pixelated;filter:drop-shadow(4px 4px #0000004d)}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.card{border:4px solid var(--ink);background:#f8f4e8;flex-direction:column;align-items:center;gap:14px;width:min(420px,94vw);max-height:86vh;padding:22px 18px;display:flex;overflow-y:auto;box-shadow:8px 8px #00000059}input{font-family:var(--px-font);text-align:center;border:4px solid var(--ink);background:#fffbe8;border-radius:0;outline:none;width:100%;padding:13px 8px;font-size:14px}input:focus{border-color:#4da3ff}#code-input{text-transform:uppercase;letter-spacing:5px;width:160px}button{font-family:var(--px-font);border:4px solid var(--ink);cursor:pointer;color:var(--ink);border-radius:0;transition:none}button:active{transform:translate(3px,3px);box-shadow:1px 1px #00000073!important}.big{text-transform:uppercase;width:100%;padding:15px 20px;font-size:14px;box-shadow:5px 5px #00000073}.yellow{background:#ffd94d}.blue{color:#fff;text-shadow:2px 2px #00000059;background:#4da3ff}.row{justify-content:center;align-items:stretch;gap:10px;width:100%;display:flex}.row .big{flex:1;width:auto}.divider{color:#777;text-transform:uppercase;font-size:9px}.hint{color:#666;text-align:center;font-size:9px;line-height:1.7}.code-box{letter-spacing:8px;background:var(--ink);color:#ffd94d;cursor:pointer;padding:12px 12px 12px 20px;font-size:30px;box-shadow:4px 4px #00000059}#qr{border:4px solid var(--ink);image-rendering:pixelated;background:#fff}.player-list{flex-direction:column;gap:8px;width:100%;display:flex}.player-row{border:3px solid var(--ink);background:#fff;align-items:center;gap:10px;padding:10px 12px;font-size:11px;display:flex}.player-row .dot{border:3px solid var(--ink);flex:none;width:14px;height:14px}.player-row .off{color:#c22;margin-left:auto;font-size:8px}.player-row .you{color:#4da3ff;margin-left:auto;font-size:8px}#hud{pointer-events:none;position:fixed;inset:0}#hud-top{top:calc(8px + env(safe-area-inset-top));justify-content:space-between;gap:8px;display:flex;position:absolute;left:10px;right:10px}.pill{border:3px solid var(--ink);color:#fff;pointer-events:auto;white-space:nowrap;background:#0a0a1abf;padding:8px 12px;font-size:10px}#hud-right{flex-direction:column;align-items:flex-end;gap:6px;display:flex}#hud-wind{align-items:center;gap:8px;font-size:11px;display:flex}#hud-wind .arrows{color:#fd3;letter-spacing:-2px;font-size:18px;line-height:1}#hud-wind .calm{color:#9ad;font-size:11px}#rounds-row{align-items:center;gap:10px;display:flex}#rounds-row .rstep{background:#f8f4e8;width:44px;height:44px;font-size:20px;box-shadow:3px 3px #00000073}#rounds-label{text-align:center;min-width:130px;font-size:12px}#hud-wait{bottom:calc(14px + env(safe-area-inset-bottom));font-size:10px;position:absolute;left:50%;transform:translate(-50%)}#hud-controls{bottom:calc(10px + env(safe-area-inset-bottom));pointer-events:auto;flex-direction:column;align-items:center;gap:8px;width:min(620px,97vw);display:flex;position:absolute;left:50%;transform:translate(-50%)}#hud-controls .hint{color:#fff;text-shadow:2px 2px #000000b3;font-size:8px}#weapons{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.weapon{background:#f8f4e8;align-items:center;gap:6px;padding:8px 10px;font-size:9px;display:flex;box-shadow:3px 3px #00000073}.weapon.sel{background:#ffd94d;outline:3px solid #fff}.weapon.empty{opacity:.4}.weapon .ammo{background:var(--ink);color:#fff;padding:2px 5px;font-size:8px}#aim-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.stepper{border:3px solid var(--ink);background:#0a0a1abf;align-items:center;gap:2px;padding:4px;display:flex}.step{background:#f8f4e8;width:40px;height:40px;font-size:18px;box-shadow:3px 3px #00000073}.step-label{color:#fff;text-align:center;min-width:70px;font-size:10px}#btn-fire{color:#fff;text-shadow:2px 2px #0006;text-transform:uppercase;background:#ff3b1f;padding:16px 18px;font-size:15px;animation:1.2s steps(4,end) infinite pulse;box-shadow:5px 5px #00000073}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}#overlay{background:#0a0a1a73;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}#overlay-card{text-align:center}#overlay-card h1{font-size:16px;line-height:1.6}#overlay-card h2{color:#555;font-size:12px}#overlay-card .theme-emoji{font-size:52px;line-height:1.1}.score-row{border:3px solid var(--ink);background:#fff;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:11px;display:flex}.score-row .dot{border:3px solid var(--ink);flex:none;width:13px;height:13px}.score-row .pts{margin-left:auto}.score-row.dead{opacity:.55}.weapon-preview{flex-wrap:wrap;justify-content:center;gap:12px;font-size:24px;display:flex}.weapon-preview span{flex-direction:column;align-items:center;gap:4px;font-size:7px;display:flex}.weapon-preview em{font-style:normal}.countdown{color:#666;font-size:9px}#toast{top:calc(12px + env(safe-area-inset-top));background:var(--ink);color:#fff;z-index:50;text-align:center;border:3px solid #fff;max-width:92vw;padding:12px 18px;font-size:10px;line-height:1.6;position:fixed;left:50%;transform:translate(-50%);box-shadow:4px 4px #00000080}@media (width<=480px){#aim-row{gap:4px}.stepper{padding:2px}.step{width:34px;height:34px;font-size:14px}.step-label{min-width:50px;font-size:8px}#btn-fire{padding:12px;font-size:11px}.weapon{padding:6px 7px;font-size:8px}.code-box{letter-spacing:6px;font-size:22px}}@media (height<=500px){#hud-controls{flex-flow:wrap;width:auto;max-width:96vw}#hud-controls .hint{display:none}#weapons{order:2;width:100%}.step{width:34px;height:34px;font-size:14px}#btn-fire{padding:12px 14px;font-size:12px}}
