@import "https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=DM+Sans:wght@400;500;600;700;800&display=swap";*{box-sizing:border-box;margin:0;padding:0}html,body{overscroll-behavior:none;width:100%;height:100%}:root{--app-width:100vw;--app-height:100dvh;--bg:#e8e4de;--surface:#ffffffd9;--surface-2:#fff9;--border:#c8c4be;--text:#2a2a2f;--text-dim:#6b6b78;--accent:#ff6b35;--accent-glow:#ff6b3559;--danger:#e5334b;--danger-glow:#e5334b59;--success:#2aab9e;--success-glow:#2aab9e59;--gold:#d4a017}body{background:var(--bg);color:var(--text);height:var(--app-height);min-height:var(--app-height);width:var(--app-width);cursor:grab;-webkit-tap-highlight-color:transparent;font-family:DM Sans,sans-serif;overflow:hidden}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{z-index:0;touch-action:none;position:absolute;inset:0}#canvas-container.scene-hidden{visibility:hidden;pointer-events:none}canvas{touch-action:none;display:block}.hud-top{z-index:10;padding:calc(18px + env(safe-area-inset-top)) calc(24px + env(safe-area-inset-right)) 18px calc(24px + env(safe-area-inset-left));pointer-events:none;background:linear-gradient(#e8e4def2 60%,#0000);justify-content:space-between;align-items:flex-start;display:flex;position:fixed;top:0;left:0;right:0}.hud-top>*{pointer-events:auto}.game-logo{align-items:center;gap:10px;font-family:Space Mono,monospace;font-size:20px;font-weight:700;display:flex}.game-logo img{object-fit:contain;flex-shrink:0;width:auto;height:32px;display:block}.score-panel{align-items:center;gap:20px;display:flex}.stat-box{text-align:center}.stat-label{text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);margin-bottom:4px;font-family:Space Mono,monospace;font-size:9px}.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{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;background:#d0ccc6;border-radius:2px;height:4px;position:fixed;overflow:hidden}.timer-fill{background:var(--success);border-radius:2px;width:100%;height:100%;transition:width .3s linear,background .3s}.timer-fill.warning{background:var(--gold)}.timer-fill.danger{background:var(--danger)}.wave-display{top:calc(90px + env(safe-area-inset-top));z-index:10;text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:6px 18px;font-family:Space Mono,monospace;font-size:11px;position:fixed;left:50%;transform:translate(-50%)}.holes-display{top:calc(90px + env(safe-area-inset-top));right:calc(24px + env(safe-area-inset-right));z-index:10;background:var(--surface);border:1px solid var(--border);border-radius:20px;align-items:center;gap:8px;padding:6px 14px;display:flex;position:fixed}.holes-display .dot{background:var(--danger);width:8px;height:8px;box-shadow:0 0 8px var(--danger-glow);border-radius:50%;animation:1.2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.8)}}.holes-display span{color:var(--danger);letter-spacing:1px;font-family:Space Mono,monospace;font-size:11px}.pause-hud-btn{top:calc(90px + env(safe-area-inset-top));left:calc(24px + env(safe-area-inset-left));z-index:10;letter-spacing:1px;text-transform:uppercase;color:var(--text);background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:20px;min-height:44px;padding:6px 14px;font-family:Space Mono,monospace;font-size:11px;transition:transform .15s,border-color .15s,box-shadow .15s;position:fixed}.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{z-index:10;padding:16px calc(24px + env(safe-area-inset-right)) calc(24px + env(safe-area-inset-bottom)) calc(24px + env(safe-area-inset-left));background:linear-gradient(#0000,#e8e4defa 35%);flex-direction:column;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:visible}.patch-panel-scroll{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch;flex:auto;min-height:0;overflow:clip auto}.panel-header{flex-shrink:0;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;margin-bottom:12px;display:grid}.panel-title{text-transform:uppercase;letter-spacing:2px;color:var(--text-dim);font-family:Space Mono,monospace;font-size:10px}.accuracy-label{color:var(--text-dim);text-align:center;justify-self:center;font-size:12px}.panel-meta{justify-content:flex-end;justify-self:end;align-items:center;gap:10px;display:flex}.settings-popover-wrap{flex-shrink:0;position:relative}.settings-trigger{border:1px solid var(--border);background:var(--surface);width:38px;min-width:38px;height:38px;min-height:38px;color:var(--text-dim);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;font-size:18px;line-height:1;transition:transform .15s,border-color .15s,box-shadow .15s,color .15s;display:inline-flex}.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{z-index:20;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;border-radius:14px;flex-direction:column;gap:8px;min-width:164px;padding:10px;transition:opacity .18s,transform .18s,visibility .18s;display:flex;position:absolute;bottom:calc(100% + 10px);right:0;box-shadow:0 12px 36px #2a2a2f24}.settings-popover.hidden{opacity:0;pointer-events:none;visibility:hidden;transform:translateY(6px)}.setting-toggle{border:1px solid var(--border);background:var(--surface);letter-spacing:1px;text-transform:uppercase;min-height:32px;color:var(--text-dim);-webkit-user-select:none;user-select:none;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-family:Space Mono,monospace;font-size:10px;display:inline-flex}.setting-toggle--menu{justify-content:space-between;width:100%;min-height:40px;padding:8px 12px}.setting-toggle input{width:16px;height:16px;accent-color:var(--accent)}.patch-grid{box-sizing:border-box;width:100%;padding:10px 0 12px}.patch-grid--play{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;scrollbar-width:thin;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:10px;display:flex;overflow:auto hidden}.patch-grid--select{grid-template-columns:repeat(5,minmax(0,1fr));place-content:start stretch;justify-items:center;gap:clamp(6px,1.8vw,12px);width:min(100%,468px);margin:0 auto;display:grid}.patch-grid--select .patch-option{aspect-ratio:1;border-radius:clamp(10px,1.8vw,14px);width:100%;height:auto}.patch-grid--select .patch-option canvas{width:92%;max-width:78px;height:92%;max-height:78px}.patch-option{border:2px solid var(--border);background:var(--surface-2);cursor:pointer;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:60px;min-width:44px;height:60px;min-height:44px;transition:all .2s;display:flex}.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{flex-shrink:0;width:40px;height:40px;display:block}.screen-overlay{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);-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));opacity:1;background:#e8e4deeb;transition:opacity .4s;display:flex;position:fixed;inset:0;overflow-y:auto}.screen-overlay.hidden{opacity:0;pointer-events:none}.screen-overlay-content{width:min(100%,440px);min-height:calc(var(--app-height) - 32px - env(safe-area-inset-top) - env(safe-area-inset-bottom));flex-direction:column;justify-content:center;align-items:center;gap:20px;margin:auto;display:flex}.screen-overlay-content--wide{width:min(100%,640px)}.screen-title{letter-spacing:-1px;font-family:Space Mono,monospace;font-size:42px;font-weight:700}.screen-title-branded{text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px;display:flex}.screen-title-logo{object-fit:contain;flex-shrink:0;width:auto;height:64px;display:block}.screen-title-text{display:inline-block}.screen-subtitle{color:var(--text-dim);text-align:center;max-width:400px;font-size:16px;line-height:1.6}.controls-hint,.scoring-hint{border:1px solid var(--border);background:var(--surface);width:min(92vw,420px);color:var(--text-dim);border-radius:12px;padding:12px 14px;font-size:13px;line-height:1.45}.controls-hint>div+div,.scoring-hint>div+div{margin-top:4px}.controls-hint-title{letter-spacing:1.5px;text-transform:uppercase;color:var(--text);font-family:Space Mono,monospace;font-size:10px}.screen-stats{gap:32px;margin:10px 0;display:flex}.screen-stat{text-align:center}.screen-stat .val{color:var(--gold);font-family:Space Mono,monospace;font-size:28px;font-weight:700}.screen-stat .label{color:var(--text-dim);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px;font-size:11px}#gameOverScreen .screen-title{text-align:center}#gameOverScreen .play-btn{margin-top:0}.share-score-btn{letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);background:var(--surface);min-height:44px;color:var(--text);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;margin:4px auto 12px;padding:10px 20px;font-family:Space Mono,monospace;font-size:12px;font-weight:700;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.share-score-btn:hover{border-color:var(--accent);color:var(--accent)}.share-score-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.share-score-btn.copied{color:#2e7d32;background:#2e7d3214;border-color:#2e7d32}.jacket-select-grid{gap:24px;margin-top:12px;display:flex}.jacket-card{border:2px solid var(--border);background:var(--surface);cursor:pointer;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:44px;padding:32px 40px;font-family:DM Sans,sans-serif;transition:all .2s;display:flex}.jacket-card:hover{border-color:var(--accent);box-shadow:0 8px 32px var(--accent-glow);transform:translateY(-4px)}.jacket-card:active{transform:translateY(-1px)}.jacket-card-icon{justify-content:center;align-items:center;line-height:0;display:flex}.jacket-card-icon img{object-fit:contain;width:67px;height:67px;display:block}.jacket-card-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--text);font-family:Space Mono,monospace;font-size:13px;font-weight:700}.play-btn{background:var(--accent);color:#fff;cursor:pointer;min-height:44px;box-shadow:0 4px 24px var(--accent-glow);border:none;border-radius:12px;margin-top:8px;padding:14px 48px;font-family:DM Sans,sans-serif;font-size:16px;font-weight:700;transition:transform .15s,box-shadow .15s}.play-btn:hover{box-shadow:0 6px 32px var(--accent-glow);transform:translateY(-2px)}.play-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.play-btn:disabled:hover{box-shadow:none;transform:none}.patch-select-wrap{box-sizing:border-box;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;width:100%;max-width:min(92vw,640px);padding-inline:clamp(4px,1.8vw,8px);overflow-x:auto}.link-btn{min-height:44px;color:var(--text-dim);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px 24px;font-family:Space Mono,monospace;font-size:12px;font-weight:400;text-decoration:underline;transition:color .15s;display:inline-flex}.link-btn:hover{color:var(--text)}.feedback-popup{z-index:50;pointer-events:none;font-family:Space Mono,monospace;font-size:18px;font-weight:700;animation:1s forwards floatUp;position:fixed}@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 #b8860b66}.feedback-popup.great{color:#1a8f85;text-shadow:0 0 12px #1a8f8566}.feedback-popup.good{color:var(--accent)}.feedback-popup.miss{color:var(--danger)}.beta-badge{right:calc(16px + env(safe-area-inset-right));bottom:calc(16px + env(safe-area-inset-bottom));z-index:105;pointer-events:none;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);background:var(--surface);border:1px solid var(--border);border-radius:6px;margin:0;padding:5px 10px;font-family:Space Mono,monospace;font-size:9px;font-weight:700;position:fixed;box-shadow:0 2px 10px #2a2a2f0f}.wave-banner{left:0;right:0;top:calc(62px + env(safe-area-inset-top));z-index:25;pointer-events:none;opacity:0;justify-content:center;padding:0 16px;transition:transform .45s cubic-bezier(.22,1,.36,1),opacity .35s;display:flex;position:fixed;transform:translateY(-130%)}.wave-banner.show{opacity:1;transform:translateY(0)}.wave-banner-inner{background:linear-gradient(135deg, var(--accent) 0%, #e04a1f 100%);text-align:center;border:1px solid #ffffff59;border-radius:0 0 14px 14px;width:min(480px,100%);padding:12px 24px 16px;box-shadow:0 8px 32px #ff6b3559,0 2px 12px #2a2a2f1f}.wave-banner-title{letter-spacing:.06em;text-transform:uppercase;color:#fff;text-shadow:0 2px 10px #0003;font-family:Space Mono,monospace;font-size:20px;font-weight:700}.wave-banner-sub{color:#fffffff5;margin-top:6px;font-size:14px;font-weight:600;line-height:1.35}@media (prefers-reduced-motion:reduce){.wave-banner{transition:opacity .2s;transform:none}.wave-banner:not(.show){opacity:0;visibility:hidden}.wave-banner.show{opacity:1;visibility:visible}}.info-toast{z-index:120;background:var(--surface);border:1px solid var(--border);color:var(--text);opacity:0;pointer-events:none;white-space:nowrap;border-radius:10px;padding:10px 20px;font-size:13px;transition:opacity .3s,transform .3s;position:fixed;top:120px;left:50%;transform:translate(-50%)translateY(-8px)}.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:.3s shake}.loading-overlay{z-index:200;background:var(--bg);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));transition:opacity .5s;display:flex;position:fixed;inset:0;overflow-y:auto}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-overlay-content{flex-direction:column;align-items:center;gap:16px;margin:auto;display:flex}.loading-text{color:var(--text-dim);letter-spacing:2px;font-family:Space Mono,monospace;font-size:14px}.loading-bar{background:#d0ccc6;border-radius:2px;width:200px;height:3px;overflow:hidden}.loading-bar-fill{background:var(--accent);border-radius:2px;width:0%;height:100%;transition:width .3s}body.viewport-compact .hud-top{padding:calc(10px + env(safe-area-inset-top)) calc(16px + env(safe-area-inset-right)) 10px calc(16px + env(safe-area-inset-left))}body.viewport-compact .game-logo{gap:8px;font-size:17px}body.viewport-compact .game-logo img{height:28px}body.viewport-compact .score-panel{gap:14px}body.viewport-compact .stat-value{font-size:18px}body.viewport-compact .timer-container{top:calc(60px + env(safe-area-inset-top));left:calc(16px + env(safe-area-inset-left));right:calc(16px + env(safe-area-inset-right))}body.viewport-compact .wave-display,body.viewport-compact .holes-display,body.viewport-compact .pause-hud-btn{top:calc(76px + env(safe-area-inset-top))}body.viewport-compact .pause-hud-btn{left:calc(16px + env(safe-area-inset-left));min-height:40px;padding:5px 10px;font-size:10px}body.viewport-compact .holes-display{right:calc(16px + env(safe-area-inset-right));padding:5px 10px}body.viewport-compact .wave-display{text-overflow:ellipsis;max-width:calc(100vw - 172px);padding:5px 12px;font-size:10px;overflow:hidden}body.viewport-compact .patch-panel{padding:10px calc(16px + env(safe-area-inset-right)) calc(12px + env(safe-area-inset-bottom)) calc(16px + env(safe-area-inset-left))}body.viewport-compact .patch-panel .panel-header{margin-bottom:8px}body.viewport-compact .patch-panel .patch-grid--play{gap:8px;padding:6px 2px 10px}body.viewport-compact .patch-panel .patch-grid--play .patch-option{border-radius:10px;width:52px;height:52px}body.viewport-compact .patch-panel .patch-grid--play .patch-option canvas{width:34px;height:34px}body.viewport-compact .screen-overlay-content{min-height:calc(var(--app-height) - 24px - env(safe-area-inset-top) - env(safe-area-inset-bottom));gap:16px}body.viewport-short .hud-top{padding:calc(8px + env(safe-area-inset-top)) calc(12px + env(safe-area-inset-right)) 8px calc(12px + env(safe-area-inset-left))}body.viewport-short .game-logo{gap:6px;font-size:14px}body.viewport-short .game-logo img{height:24px}body.viewport-short .score-panel{gap:10px}body.viewport-short .stat-label{letter-spacing:1.5px;font-size:8px}body.viewport-short .stat-value{font-size:16px}body.viewport-short .timer-container{top:calc(50px + env(safe-area-inset-top));left:calc(12px + env(safe-area-inset-left));right:calc(12px + env(safe-area-inset-right))}body.viewport-short .wave-display,body.viewport-short .holes-display,body.viewport-short .pause-hud-btn{top:calc(66px + env(safe-area-inset-top))}body.viewport-short .wave-display{letter-spacing:1.2px;text-overflow:ellipsis;max-width:calc(100vw - 154px);padding:4px 10px;font-size:9px;overflow:hidden}body.viewport-short .holes-display{right:calc(12px + env(safe-area-inset-right));gap:6px;padding:4px 8px}body.viewport-short .holes-display span{letter-spacing:.7px;font-size:9px}body.viewport-short .pause-hud-btn{left:calc(12px + env(safe-area-inset-left));min-height:34px;padding:4px 8px;font-size:9px}body.viewport-short .patch-panel{padding:8px calc(12px + env(safe-area-inset-right)) calc(10px + env(safe-area-inset-bottom)) calc(12px + env(safe-area-inset-left));max-height:clamp(132px,34vh,210px)}body.viewport-short .panel-header{grid-template-columns:1fr auto;align-items:start;gap:8px}body.viewport-short .panel-title{letter-spacing:1.6px;font-size:9px}body.viewport-short .accuracy-label{text-align:left;grid-column:1/-1;justify-self:start;font-size:11px;line-height:1.3}body.viewport-short .panel-meta{gap:6px}body.viewport-short .setting-toggle{min-height:32px;padding:4px 8px;font-size:9px}body.viewport-short .patch-panel .patch-grid--play{gap:7px;padding:4px 1px 8px}body.viewport-short .patch-panel .patch-grid--play .patch-option{border-radius:10px;width:46px;height:46px}body.viewport-short .patch-panel .patch-grid--play .patch-option canvas{width:30px;height:30px}body.viewport-short .beta-badge{bottom:calc(clamp(132px, 34vh, 210px) + 8px + env(safe-area-inset-bottom));right:calc(12px + env(safe-area-inset-right))}body.viewport-short .screen-overlay{padding:calc(12px + env(safe-area-inset-top)) calc(12px + env(safe-area-inset-right)) calc(12px + env(safe-area-inset-bottom)) calc(12px + env(safe-area-inset-left))}body.viewport-short .screen-overlay-content{justify-content:flex-start;gap:14px;min-height:auto}body.viewport-short .screen-title{text-align:center;font-size:30px}body.viewport-short .screen-title-logo{height:44px}body.viewport-short .screen-subtitle{font-size:13px;line-height:1.5}body.viewport-short .controls-hint,body.viewport-short .scoring-hint{width:min(100%,360px);padding:10px 12px;font-size:12px}body.viewport-short .patch-select-wrap{max-width:100%}body.viewport-short .patch-grid--select{gap:6px;padding:6px 4px 8px}body.viewport-short .patch-grid--select .patch-option canvas{max-width:54px;max-height:54px}body.viewport-short .play-btn{width:min(100%,320px);margin-top:0}body.viewport-short .loading-overlay{padding:calc(12px + env(safe-area-inset-top)) calc(12px + env(safe-area-inset-right)) calc(12px + env(safe-area-inset-bottom)) calc(12px + env(safe-area-inset-left))}body.viewport-short .loading-overlay-content{gap:12px}@media (width<=900px){.jacket-select-grid{flex-wrap:wrap;justify-content:center;gap:14px;width:min(92vw,520px)}.jacket-card{width:calc(50% - 8px);min-width:220px;padding:24px 20px}}@media (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{gap:8px;font-size:16px}.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));text-overflow:ellipsis;max-width:calc(100vw - 160px);padding:5px 12px;font-size:10px;overflow:hidden}.wave-banner{top:calc(56px + env(safe-area-inset-top))}.wave-banner-inner{border-radius:0 0 12px 12px;padding:10px 18px 14px}.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));min-height:40px;padding:5px 10px;font-size:10px}.beta-badge{right:calc(12px + env(safe-area-inset-right));bottom:calc(10px + env(safe-area-inset-bottom));padding:4px 8px;font-size: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{border-radius:10px;width:48px;height:48px}.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{text-align:center;font-size:34px}.screen-title-branded{gap:12px}.screen-title-logo{height:52px}.screen-subtitle{padding:0 18px;font-size:14px}.controls-hint,.scoring-hint{width:min(92vw,360px);padding:10px 12px;font-size:12px}.screen-stats{flex-wrap:wrap;justify-content:center;gap:14px}.jacket-select-grid{flex-direction:column;gap:10px;width:min(92vw,420px)}.jacket-card{flex-direction:row;justify-content:flex-start;width:100%;min-width:0;padding:18px 20px}.jacket-card-icon img{width:48px;height:48px}.play-btn{width:min(92vw,320px)}}@media (width<=420px){.panel-header{align-items:stretch}.panel-meta{gap:6px;max-width:60%}.setting-toggle{min-height:32px;padding:4px 8px;font-size:9px}.holes-display span{letter-spacing:.8px;font-size:10px}.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);box-shadow:none;transform:none}.play-btn:hover{box-shadow:0 4px 24px var(--accent-glow);transform:none}.pause-hud-btn:hover{box-shadow:none;border-color:var(--border);transform:none}.link-btn:hover{color:var(--text-dim)}}body.thanks-page{cursor:default;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));justify-content:center;align-items:center;display:flex;overflow:auto}body.thanks-page:active{cursor:default}.thanks-card{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:20px;width:min(100%,420px);padding:40px 32px;box-shadow:0 12px 48px #2a2a2f14}.thanks-brand{justify-content:center;align-items:center;gap:10px;margin-bottom:28px;font-family:Space Mono,monospace;font-size:20px;font-weight:700;display:flex}.thanks-logo{object-fit:contain;width:auto;height:32px;display:block}.thanks-title{letter-spacing:-.02em;margin-bottom:12px;font-size:clamp(1.5rem,4vw,1.85rem);font-weight:800}.thanks-sub{color:var(--text-dim);margin-bottom:28px;font-size:16px;line-height:1.5}a.play-btn.thanks-back{justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.reward-section.hidden,.reward-section .hidden{display:none}.reward-section{text-align:center;width:100%;margin:16px 0 8px}.reward-prompt{color:var(--text);margin-bottom:8px;font-size:15px;font-weight:600}.reward-fulfillment-hint{color:var(--text-dim);margin-bottom:8px;font-size:12px;line-height:1.4}.reward-marketing-disclosure{color:var(--text-secondary);margin:14px 0 0;text-wrap:balance;max-width:320px;margin-inline:auto;font-size:10px;font-weight:400;line-height:1.45}.reward-form{flex-direction:column;align-items:stretch;gap:10px;max-width:320px;margin-inline:auto;display:flex}.reward-email-input{flex:unset;border:1.5px solid var(--border);background:var(--surface);width:100%;max-width:none;color:var(--text);border-radius:10px;outline:none;padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}.reward-email-input:focus{border-color:var(--accent,#5b7ebd)}.reward-claim-btn{background:var(--accent,#5b7ebd);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;align-self:center;width:fit-content;min-height:44px;padding:10px 20px;font-family:inherit;font-size:14px;font-weight:700;transition:opacity .15s}.reward-claim-btn:disabled{opacity:.55;cursor:not-allowed}.reward-result,.reward-not-eligible,.reward-error{padding:12px 0}.reward-result-icon{margin-bottom:4px;font-size:28px}.reward-result-message{color:var(--text);text-wrap:balance;margin-bottom:8px;font-size:15px;font-weight:600}.reward-replay-tip{color:var(--text-secondary);text-wrap:balance;margin:-4px 0 10px;font-size:13px;font-weight:500;line-height:1.35}.reward-result:focus{outline:none}.reward-result:focus-visible{border-radius:8px;box-shadow:0 0 0 3px #5b7ebd59}.reward-code-wrap{background:var(--surface-alt,#f1f0ed);border:1.5px dashed var(--border);border-radius:10px;align-items:center;gap:10px;margin-top:4px;padding:10px 14px 10px 20px;display:inline-flex}.reward-code{letter-spacing:.06em;color:var(--accent,#5b7ebd);-webkit-user-select:all;user-select:all;font-family:Space Mono,monospace;font-size:18px;font-weight:700}.reward-copy-btn{border:1.5px solid var(--border,#ddd);cursor:pointer;color:var(--text-secondary,#777);background:0 0;border-radius:6px;justify-content:center;align-items:center;padding:5px;transition:color .15s,border-color .15s,background .15s;display:inline-flex}.reward-copy-btn:hover{color:var(--accent,#5b7ebd);border-color:var(--accent,#5b7ebd);background:#5b7ebd14}.reward-copy-btn.copied{color:#2e7d32;border-color:#2e7d32}.reward-not-eligible-message{color:var(--text-dim);font-size:14px}.reward-error-message{color:#c44;margin-bottom:8px;font-size:14px}.reward-retry-btn{border:1.5px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600}
