@import"https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=DM+Sans:wght@400;500;600;700;800&display=swap";*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overscroll-behavior:none}:root{--bg: #e8e4de;--surface: rgba(255,255,255,.85);--surface-2: rgba(255,255,255,.6);--border: #c8c4be;--text: #2a2a2f;--text-dim: #6b6b78;--accent: #ff6b35;--accent-glow: rgba(255,107,53,.35);--danger: #e5334b;--danger-glow: rgba(229,51,75,.35);--success: #2aab9e;--success-glow: rgba(42,171,158,.35);--gold: #d4a017}body{background:var(--bg);color:var(--text);font-family:DM Sans,sans-serif;overflow:hidden;height:100vh;height:100dvh;min-height:100dvh;width:100vw;cursor:grab;-webkit-tap-highlight-color:transparent}body.aiming{cursor:crosshair}body:active{cursor:grabbing}body.prelude .hud-top,body.prelude .timer-container,body.prelude .wave-display,body.prelude .holes-display,body.prelude .patch-panel{visibility:hidden;pointer-events:none}#canvas-container{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;touch-action:none}#canvas-container.scene-hidden{visibility:hidden;pointer-events:none}canvas{display:block;touch-action:none}.hud-top{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:flex-start;justify-content:space-between;padding:calc(18px + env(safe-area-inset-top)) calc(24px + env(safe-area-inset-right)) 18px calc(24px + env(safe-area-inset-left));background:linear-gradient(to bottom,rgba(232,228,222,.95) 60%,transparent);pointer-events:none}.hud-top>*{pointer-events:auto}.game-logo{font-family:Space Mono,monospace;font-weight:700;font-size:20px;display:flex;align-items:center;gap:10px}.game-logo img{height:32px;width:auto;object-fit:contain;display:block;flex-shrink:0}.score-panel{display:flex;gap:20px;align-items:center}.stat-box{text-align:center}.stat-label{font-family:Space Mono,monospace;font-size:9px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:4px}.stat-value{font-family:Space Mono,monospace;font-size:22px;font-weight:700}.stat-value.score{color:var(--gold)}.stat-value.combo{color:var(--accent)}.timer-container{position:fixed;top:calc(72px + env(safe-area-inset-top));left:calc(24px + env(safe-area-inset-left));right:calc(24px + env(safe-area-inset-right));z-index:10;height:4px;background:#d0ccc6;border-radius:2px;overflow:hidden}.timer-fill{height:100%;border-radius:2px;background:var(--success);transition:width .3s linear,background .3s ease;width:100%}.timer-fill.warning{background:var(--gold)}.timer-fill.danger{background:var(--danger)}.wave-display{position:fixed;top:calc(90px + env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:10;font-family:Space Mono,monospace;font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);background:var(--surface);padding:6px 18px;border-radius:20px;border:1px solid var(--border)}.holes-display{position:fixed;top:calc(90px + env(safe-area-inset-top));right:calc(24px + env(safe-area-inset-right));z-index:10;display:flex;align-items:center;gap:8px;background:var(--surface);padding:6px 14px;border-radius:20px;border:1px solid var(--border)}.holes-display .dot{width:8px;height:8px;border-radius:50%;background:var(--danger);box-shadow:0 0 8px var(--danger-glow);animation:pulse 1.2s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.holes-display span{font-family:Space Mono,monospace;font-size:11px;color:var(--danger);letter-spacing:1px}.pause-hud-btn{position:fixed;top:calc(90px + env(safe-area-inset-top));left:calc(24px + env(safe-area-inset-left));z-index:10;font-family:Space Mono,monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--text);background:var(--surface);padding:6px 14px;border-radius:20px;border:1px solid var(--border);cursor:pointer;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease;min-height:44px}.pause-hud-btn:hover{border-color:var(--text-dim);transform:translateY(-1px);box-shadow:0 4px 16px #2a2a2f14}.pause-hud-btn:active{transform:translateY(0)}.pause-hud-btn.hidden{opacity:0;pointer-events:none;visibility:hidden}.patch-panel{position:fixed;bottom:0;left:0;right:0;z-index:10;background:linear-gradient(to top,rgba(232,228,222,.98) 65%,transparent);padding:16px calc(24px + env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) calc(24px + env(safe-area-inset-left))}.panel-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:12px}.panel-title{font-family:Space Mono,monospace;font-size:10px;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim)}.accuracy-label{font-size:12px;color:var(--text-dim);text-align:center;justify-self:center}.panel-meta{display:flex;align-items:center;justify-content:flex-end;gap:10px;justify-self:end}.settings-popover-wrap{position:relative;flex-shrink:0}.settings-trigger{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;min-width:38px;min-height:38px;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text-dim);cursor:pointer;font-size:18px;line-height:1;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease,color .15s ease}.settings-trigger:hover{border-color:var(--text-dim);color:var(--text);transform:translateY(-1px);box-shadow:0 4px 16px #2a2a2f14}.settings-trigger:active{transform:translateY(0)}.settings-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.settings-trigger.open{border-color:var(--accent);color:var(--accent);box-shadow:0 0 20px var(--accent-glow)}.settings-popover{position:absolute;right:0;bottom:calc(100% + 10px);z-index:20;display:flex;flex-direction:column;gap:8px;min-width:164px;padding:10px;border:1px solid var(--border);border-radius:14px;background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 12px 36px #2a2a2f24;transition:opacity .18s ease,transform .18s ease,visibility .18s ease}.settings-popover.hidden{opacity:0;pointer-events:none;visibility:hidden;transform:translateY(6px)}.setting-toggle{display:inline-flex;align-items:center;gap:6px;min-height:32px;padding:4px 10px;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-family:Space Mono,monospace;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);-webkit-user-select:none;user-select:none}.setting-toggle--menu{width:100%;justify-content:space-between;min-height:40px;padding:8px 12px}.setting-toggle input{width:16px;height:16px;accent-color:var(--accent)}.patch-grid{width:100%;box-sizing:border-box;padding:10px 0 12px}.patch-grid--play{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:10px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin}.patch-grid--select{display:grid;width:min(100%,468px);margin:0 auto;grid-template-columns:repeat(5,minmax(0,1fr));justify-content:stretch;justify-items:center;align-content:start;gap:clamp(6px,1.8vw,12px)}.patch-grid--select .patch-option{width:100%;height:auto;aspect-ratio:1 / 1;border-radius:clamp(10px,1.8vw,14px)}.patch-grid--select .patch-option canvas{width:92%;height:92%;max-width:78px;max-height:78px}.patch-option{flex-shrink:0;width:60px;height:60px;border-radius:12px;min-width:44px;min-height:44px;border:2px solid var(--border);background:var(--surface-2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.patch-option:hover{border-color:var(--text-dim);transform:translateY(-2px)}.patch-option.selected{border-color:var(--accent);box-shadow:0 0 20px var(--accent-glow);transform:translateY(-3px)}.patch-option canvas{display:block;width:40px;height:40px;flex-shrink:0}.screen-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#e8e4deeb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px;opacity:1;transition:opacity .4s ease}.screen-overlay.hidden{opacity:0;pointer-events:none}.screen-title{font-family:Space Mono,monospace;font-size:42px;font-weight:700;letter-spacing:-1px}.screen-title-branded{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;text-align:center}.screen-title-logo{height:64px;width:auto;object-fit:contain;display:block;flex-shrink:0}.screen-title-text{display:inline-block}.screen-subtitle{font-size:16px;color:var(--text-dim);max-width:400px;text-align:center;line-height:1.6}.controls-hint,.scoring-hint{width:min(92vw,420px);padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:13px;line-height:1.45}.controls-hint>div+div,.scoring-hint>div+div{margin-top:4px}.controls-hint-title{font-family:Space Mono,monospace;font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text)}.screen-stats{display:flex;gap:32px;margin:10px 0}.screen-stat{text-align:center}.screen-stat .val{font-family:Space Mono,monospace;font-size:28px;font-weight:700;color:var(--gold)}.screen-stat .label{font-size:11px;color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}#gameOverScreen.screen-overlay{justify-content:flex-start;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:calc(16px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) calc(16px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left));box-sizing:border-box}#gameOverScreen .screen-title{text-align:center}#gameOverScreen .play-btn{margin-top:0}.game-over-klaviyo-wrap{width:min(92vw,420px);max-width:100%;flex-shrink:0}#gameOverScreen.hidden .game-over-klaviyo-wrap{visibility:hidden;pointer-events:none}.jacket-select-grid{display:flex;gap:24px;margin-top:12px}.jacket-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 40px;border-radius:16px;min-height:44px;border:2px solid var(--border);background:var(--surface);cursor:pointer;transition:all .2s ease;font-family:DM Sans,sans-serif}.jacket-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 32px var(--accent-glow)}.jacket-card:active{transform:translateY(-1px)}.jacket-card-icon{line-height:0;display:flex;align-items:center;justify-content:center}.jacket-card-icon img{width:67px;height:67px;object-fit:contain;display:block}.jacket-card-label{font-family:Space Mono,monospace;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text)}.play-btn{font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;padding:14px 48px;border:none;border-radius:12px;min-height:44px;background:var(--accent);color:#fff;cursor:pointer;margin-top:8px;box-shadow:0 4px 24px var(--accent-glow);transition:transform .15s ease,box-shadow .15s ease}.play-btn:hover{transform:translateY(-2px);box-shadow:0 6px 32px var(--accent-glow)}.play-btn:disabled{opacity:.45;cursor:not-allowed;transform:none;box-shadow:none}.play-btn:disabled:hover{transform:none;box-shadow:none}.patch-select-wrap{width:100%;max-width:min(92vw,640px);box-sizing:border-box;padding-inline:clamp(4px,1.8vw,8px);overflow-x:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.link-btn{display:inline-flex;align-items:center;justify-content:center;font-family:Space Mono,monospace;font-size:12px;font-weight:400;padding:8px 24px;border:none;border-radius:8px;min-height:44px;background:transparent;color:var(--text-dim);cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .15s ease}.link-btn:hover{color:var(--text)}.feedback-popup{position:fixed;z-index:50;font-family:Space Mono,monospace;font-weight:700;font-size:18px;pointer-events:none;animation:floatUp 1s ease forwards}@keyframes floatUp{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-60px) scale(1.2)}}.feedback-popup.perfect{color:#b8860b;text-shadow:0 0 12px rgba(184,134,11,.4)}.feedback-popup.great{color:#1a8f85;text-shadow:0 0 12px rgba(26,143,133,.4)}.feedback-popup.good{color:var(--accent)}.feedback-popup.miss{color:var(--danger)}.beta-badge{position:fixed;right:calc(16px + env(safe-area-inset-right));bottom:calc(16px + env(safe-area-inset-bottom));z-index:105;margin:0;pointer-events:none;font-family:Space Mono,monospace;font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:5px 10px;box-shadow:0 2px 10px #2a2a2f0f}.wave-banner{position:fixed;left:0;right:0;top:calc(62px + env(safe-area-inset-top));z-index:25;pointer-events:none;display:flex;justify-content:center;padding:0 16px;transform:translateY(-130%);opacity:0;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .35s ease}.wave-banner.show{transform:translateY(0);opacity:1}.wave-banner-inner{width:min(480px,100%);background:linear-gradient(135deg,var(--accent) 0%,#e04a1f 100%);border:1px solid rgba(255,255,255,.35);border-radius:0 0 14px 14px;padding:12px 24px 16px;box-shadow:0 8px 32px #ff6b3559,0 2px 12px #2a2a2f1f;text-align:center}.wave-banner-title{font-family:Space Mono,monospace;font-weight:700;font-size:20px;letter-spacing:.06em;text-transform:uppercase;color:#fff;text-shadow:0 2px 10px rgba(0,0,0,.2)}.wave-banner-sub{margin-top:6px;font-size:14px;font-weight:600;color:#fffffff5;line-height:1.35}@media (prefers-reduced-motion: reduce){.wave-banner{transition:opacity .2s ease;transform:none}.wave-banner:not(.show){opacity:0;visibility:hidden}.wave-banner.show{opacity:1;visibility:visible}}.info-toast{position:fixed;top:120px;left:50%;transform:translate(-50%) translateY(-8px);z-index:20;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-size:13px;color:var(--text);opacity:0;transition:opacity .3s ease,transform .3s ease;pointer-events:none;white-space:nowrap}.info-toast.show{opacity:1;transform:translate(-50%) translateY(0)}@keyframes shake{0%,to{transform:translate(0)}10%{transform:translate(-3px,2px)}30%{transform:translate(3px,-2px)}50%{transform:translate(-2px,-1px)}70%{transform:translate(2px,1px)}90%{transform:translate(-1px,2px)}}.shake{animation:shake .3s ease}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;transition:opacity .5s ease}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-text{font-family:Space Mono,monospace;font-size:14px;color:var(--text-dim);letter-spacing:2px}.loading-bar{width:200px;height:3px;background:#d0ccc6;border-radius:2px;overflow:hidden}.loading-bar-fill{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .3s ease}@media (max-width: 900px){.jacket-select-grid{flex-wrap:wrap;justify-content:center;width:min(92vw,520px);gap:14px}.jacket-card{width:calc(50% - 8px);min-width:220px;padding:24px 20px}}@media (max-width: 768px){.hud-top{padding:calc(12px + env(safe-area-inset-top)) calc(14px + env(safe-area-inset-right)) 12px calc(14px + env(safe-area-inset-left))}.game-logo{font-size:16px;gap:8px}.game-logo img{height:28px}.score-panel{gap:12px}.stat-value{font-size:18px}.timer-container{top:calc(58px + env(safe-area-inset-top));left:calc(14px + env(safe-area-inset-left));right:calc(14px + env(safe-area-inset-right))}.wave-display{top:calc(74px + env(safe-area-inset-top));font-size:10px;padding:5px 12px;max-width:calc(100vw - 160px);overflow:hidden;text-overflow:ellipsis}.wave-banner{top:calc(56px + env(safe-area-inset-top))}.wave-banner-inner{padding:10px 18px 14px;border-radius:0 0 12px 12px}.wave-banner-title{font-size:17px}.wave-banner-sub{font-size:13px}.holes-display{top:calc(74px + env(safe-area-inset-top));right:calc(14px + env(safe-area-inset-right));padding:5px 10px}.pause-hud-btn{top:calc(74px + env(safe-area-inset-top));left:calc(14px + env(safe-area-inset-left));font-size:10px;padding:5px 10px;min-height:40px}.beta-badge{right:calc(12px + env(safe-area-inset-right));bottom:calc(10px + env(safe-area-inset-bottom));font-size:8px;padding:4px 8px}.patch-panel{padding:8px calc(14px + env(safe-area-inset-right)) calc(10px + env(safe-area-inset-bottom)) calc(14px + env(safe-area-inset-left))}.patch-panel .panel-header{margin-bottom:8px}.patch-panel .patch-grid--play{gap:8px;padding:6px 2px 10px}.patch-panel .patch-grid--play .patch-option{width:48px;height:48px;border-radius:10px}.patch-panel .patch-grid--play .patch-option canvas{width:32px;height:32px}.patch-grid--select{gap:clamp(6px,1.8vw,10px);padding:8px 6px 10px}.patch-grid--select .patch-option{border-radius:clamp(10px,1.8vw,12px)}.patch-grid--select .patch-option canvas{max-width:62px;max-height:62px}.panel-header{align-items:flex-start}.panel-meta{flex-direction:column;align-items:flex-end;gap:6px}.setting-toggle{min-height:34px;padding:5px 10px}.screen-title{font-size:34px;text-align:center}.screen-title-branded{gap:12px}.screen-title-logo{height:52px}.screen-subtitle{font-size:14px;padding:0 18px}.controls-hint,.scoring-hint{width:min(92vw,360px);font-size:12px;padding:10px 12px}.screen-stats{gap:14px;flex-wrap:wrap;justify-content:center}.jacket-select-grid{flex-direction:column;width:min(92vw,420px);gap:10px}.jacket-card{width:100%;min-width:0;padding:18px 20px;flex-direction:row;justify-content:flex-start}.jacket-card-icon img{width:48px;height:48px}.play-btn{width:min(92vw,320px)}}@media (max-width: 420px){.panel-header{align-items:stretch}.panel-meta{gap:6px;max-width:60%}.setting-toggle{font-size:9px;padding:4px 8px;min-height:32px}.holes-display span{font-size:10px;letter-spacing:.8px}.wave-display{letter-spacing:1.2px}.panel-header{gap:8px}.accuracy-label{font-size:11px}}@media (hover: none) and (pointer: coarse){.patch-option:hover{border-color:var(--border);transform:none}.jacket-card:hover{border-color:var(--border);transform:none;box-shadow:none}.play-btn:hover{transform:none;box-shadow:0 4px 24px var(--accent-glow)}.pause-hud-btn:hover{transform:none;box-shadow:none;border-color:var(--border)}.link-btn:hover{color:var(--text-dim)}}body.thanks-page{overflow:auto;cursor:default;display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:calc(24px + env(safe-area-inset-top)) calc(24px + env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) calc(24px + env(safe-area-inset-left))}body.thanks-page:active{cursor:default}.thanks-card{width:min(100%,420px);text-align:center;padding:40px 32px;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:0 12px 48px #2a2a2f14}.thanks-brand{font-family:Space Mono,monospace;font-weight:700;font-size:20px;display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px}.thanks-logo{height:32px;width:auto;object-fit:contain;display:block}.thanks-title{font-size:clamp(1.5rem,4vw,1.85rem);font-weight:800;letter-spacing:-.02em;margin-bottom:12px}.thanks-sub{color:var(--text-dim);font-size:16px;line-height:1.5;margin-bottom:28px}a.play-btn.thanks-back{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
