@import "https://fonts.googleapis.com/css2?family=Russo+One&family=Inter:wght@400;600;700;900&display=swap";:root{color:#f0e6d3;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--panel:#140a23d1;--line:#ff50502e;--line-strong:#ff505052;--text-soft:#f0e6d3b3;--accent:#ff4136;--accent-glow:#ff413666;--neon-blue:#00d4ff;--neon-blue-glow:#00d4ff59;--neon-pink:#ff2d78;--neon-pink-glow:#ff2d784d;--gold:gold;--gold-glow:#ffd70066;--lane-wood:#c4873b;--lane-wood-dark:#8b5e2b;--shadow:0 24px 80px #00000080;background:linear-gradient(#1a0a2e 0%,#0d0d1a 40%,#0a0a12 100%);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:linear-gradient(#1a0a2e 0%,#0d0d1a 40%,#0a0a12 100%);min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}h1,h2,h3,p,ul{margin:0}ul{padding-left:1.1rem}#root{min-height:100vh}.shell{width:min(1200px,100% - 2rem);margin:0 auto;padding:1.5rem 0 3rem}.host-shell{width:100%;max-width:none;height:100dvh;padding:0;overflow:hidden}.narrow-shell{width:min(920px,100% - 1.2rem)}.hero-panel,.panel{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.hero-panel{border-color:var(--line-strong);border-radius:32px;align-content:center;gap:1rem;min-height:360px;padding:clamp(1.5rem,4vw,3.5rem);display:grid;position:relative;overflow:hidden}.hero-panel:before{content:"";background:linear-gradient(90deg, var(--accent), var(--neon-pink), var(--neon-blue), var(--gold));height:3px;box-shadow:0 0 20px var(--accent-glow), 0 0 40px var(--neon-pink-glow);position:absolute;top:0;left:0;right:0}.hero-panel:after{content:"";background:repeating-linear-gradient(90deg, var(--lane-wood) 0px, var(--lane-wood) 8px, var(--lane-wood-dark) 8px, var(--lane-wood-dark) 10px);opacity:.5;height:6px;position:absolute;bottom:0;left:0;right:0}.panel{border-radius:24px;padding:1.25rem}.hero-panel h1,.panel h1,.panel h2,.panel h3{letter-spacing:-.02em;line-height:.95}.hero-panel h1,.panel h1{background:linear-gradient(135deg, #fff 0%, var(--gold) 50%, var(--accent) 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 8px #ffd70040);-webkit-background-clip:text;background-clip:text;font-family:Russo One,sans-serif;font-size:clamp(2.8rem,8vw,5.6rem)}.panel h2{color:var(--neon-blue);text-shadow:0 0 12px var(--neon-blue-glow);font-family:Russo One,sans-serif;font-size:clamp(1.4rem,2.8vw,2rem)}.panel h3{color:var(--text-soft);letter-spacing:.08em;text-transform:uppercase;font-size:.95rem}.eyebrow{color:var(--accent);letter-spacing:.24em;text-transform:uppercase;text-shadow:0 0 10px var(--accent-glow);font-family:Russo One,sans-serif;font-size:.8rem}.lede{max-width:60ch;color:var(--text-soft);font-size:1.05rem}.lede.narrow{max-width:45ch}.hero-actions,.controller-actions,.controller-setup,.status-row,.grid,.stack-lg,.controller-list{gap:1rem;display:grid}.hero-actions,.controller-actions,.controller-setup{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:1rem}.grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.compact{gap:.75rem}.host-layout{grid-template-columns:300px minmax(0,1fr);align-items:start}.stack-lg{grid-template-columns:1fr}.host-stage-shell{gap:0;display:grid}.host-game-layout{grid-template-columns:minmax(0,1fr) 320px;align-items:start;gap:1rem;display:grid}.host-sidebar{gap:1rem;display:grid}.overlay-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--line);background:#0f0519e0;padding:.95rem;box-shadow:0 18px 50px #0006,inset 0 1px #ffffff0d}.topbar,.row-between{justify-content:space-between;align-items:center;gap:1rem;display:flex}.topbar{margin-bottom:1rem}.button,.controller-pill{border:1px solid #0000;border-radius:999px;padding:.9rem 1.15rem;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}.button{cursor:pointer;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.button:hover,.controller-pill:hover{transform:translateY(-1px)}.button:disabled{cursor:default;opacity:.5;transform:none}.button.primary{background:linear-gradient(135deg, var(--accent) 0%, #c20 100%);color:#fff;text-transform:uppercase;letter-spacing:.06em;box-shadow:0 4px 20px var(--accent-glow), inset 0 1px 0 #ffffff26;border:1px solid #ff64504d;font-weight:700}.button.primary:hover:not(:disabled){box-shadow:0 6px 30px var(--accent-glow), 0 0 60px #ff413633, inset 0 1px 0 #fff3}.button.grip-button{letter-spacing:.06em;touch-action:none;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;border-radius:28px;width:100%;min-height:104px;font-size:1.25rem;position:relative;overflow:hidden}.button.grip-button:before{content:"";background:#00000059;border-radius:50%;width:14px;height:14px;position:absolute;top:18px;right:32px;box-shadow:18px 8px #00000059,8px 20px #00000059}.button.grip-button.active{background:linear-gradient(135deg, var(--gold) 0%, #ff8c00 100%);color:#1a0a2e;box-shadow:0 0 40px var(--gold-glow), 0 0 80px #ff8c0033, inset 0 1px 0 #ffffff4d;border-color:#ffd70080;transform:translateY(2px)scale(.98)}.button.secondary,.controller-pill{border-color:var(--line);color:#f0e6d3;background:#140a23e0}.button.secondary:hover:not(:disabled){border-color:var(--neon-blue);box-shadow:0 0 12px var(--neon-blue-glow)}.controller-pill{text-align:left;justify-content:space-between;align-items:center;width:100%;display:flex}.controller-pill.active{box-shadow:0 0 12px var(--neon-blue-glow);border-color:#00d4ff99}.controller-pill-meta{color:var(--text-soft);font-size:.85rem}.status-pill{border:1px solid var(--line);color:#f0e6d3;background:#0f0519b3;border-radius:999px;align-items:center;gap:.4rem;padding:.45rem .8rem;font-size:.85rem;display:inline-flex}.status-pill.connecting,.status-pill.idle{color:var(--gold);border-color:#ffd70066}.status-pill.open{color:#0f8;text-shadow:0 0 6px #00ff884d;border-color:#0f86}.status-pill.closed,.status-pill.error{color:var(--neon-pink);border-color:#ff2d7873}.status-row.compact{grid-template-columns:1fr;gap:.6rem}.qr-shell{background:linear-gradient(135deg,#fff 0%,#f5efe6 100%);border:2px solid #ffd70033;border-radius:18px;justify-content:center;align-items:center;margin:1.25rem 0;padding:1rem;display:inline-flex;box-shadow:0 0 30px #ffd70026}.qr-shell-compact{margin:.75rem 0 .6rem;padding:.65rem}.mono-wrap{color:var(--text-soft);word-break:break-all;font-family:SFMono-Regular,ui-monospace,Cascadia Code,Source Code Pro,monospace}.text-link,.note,.empty-state{color:var(--text-soft)}.error-text{color:var(--neon-pink);text-shadow:0 0 8px var(--neon-pink-glow)}.invitation{position:sticky;top:1.5rem}.controller-shell{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;flex-direction:column;min-height:100dvh;padding-bottom:8rem;display:flex}.controller-panel{gap:1rem;display:grid}.step-progress{justify-content:center;gap:0;padding:1rem .5rem .5rem;display:flex;position:relative}.step-progress:before{content:"";background:var(--line);height:2px;position:absolute;top:calc(1rem + 14px);left:15%;right:15%}.step-dot{z-index:1;flex-direction:column;flex:1;align-items:center;gap:.35rem;display:flex;position:relative}.step-dot-circle{border:2px solid var(--line);width:30px;height:30px;color:var(--text-soft);background:#140a23e6;border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;transition:all .3s;display:flex}.step-dot.active .step-dot-circle{border-color:var(--accent);background:linear-gradient(135deg, var(--accent) 0%, #c20 100%);color:#fff;box-shadow:0 0 16px var(--accent-glow)}.step-dot.done .step-dot-circle{color:#fff;background:#22c55e;border-color:#22c55e}.step-dot-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-size:.6rem;transition:color .3s}.step-dot.active .step-dot-label{color:#f0e6d3}.step-dot.done .step-dot-label{color:#22c55e}.step-card{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1rem;min-height:50dvh;padding:2rem 1.5rem;display:flex}.step-icon{margin-bottom:.25rem;font-size:3rem;line-height:1}.step-title{margin:0;font-size:1.5rem}.step-desc{color:var(--text-soft);max-width:32ch;margin:0;line-height:1.5}.step-action{width:100%;max-width:320px;min-height:56px;margin-top:.5rem;font-size:1.05rem}.step-form{text-align:left;gap:1.25rem;width:100%;max-width:320px;display:grid}.step-loader{background:var(--line);border-radius:4px;width:100%;max-width:200px;height:4px;overflow:hidden}.step-loader-bar{background:linear-gradient(90deg, var(--accent), var(--neon-blue));border-radius:4px;width:40%;height:100%;animation:1.2s ease-in-out infinite step-loader-slide}@keyframes step-loader-slide{0%{transform:translate(-100%)}to{transform:translate(350%)}}.stance-visual{justify-content:center;padding:1rem 0;display:flex}.stance-phone-flat{border:2px solid var(--text-soft);background:#140a2380;border-radius:8px;width:72px;height:40px;position:relative;box-shadow:0 4px 12px #0000004d}.stance-phone-flat:after{content:"";border:1.5px solid var(--text-soft);border-radius:50%;width:10px;height:10px;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.stance-phone-flat:before{content:"";filter:blur(2px);background:#ffffff0d;border-radius:2px;height:4px;position:absolute;bottom:-8px;left:10%;right:10%}.bowl-header{gap:.5rem;padding:.75rem 1rem}.bowl-player-info{align-items:center;gap:.5rem;display:flex}.bowl-player-name{font-size:1.1rem;font-weight:700}.bowl-player-dot{border:2px solid #fff3;border-radius:50%;width:14px;height:14px}.controller-turn-card{border:1px solid var(--line);background:#ffffff0a;border-radius:18px;gap:.2rem;padding:.85rem 1rem;display:grid}.controller-turn-card span{color:var(--text-soft);text-transform:uppercase;letter-spacing:.08em;font-size:.8rem}.controller-turn-card strong{color:var(--text);font-size:1.25rem}.controller-turn-card.active{background:#00ff881a;border-color:#00ff8873;box-shadow:0 0 28px #00ff8824}.controller-turn-card.active strong{color:var(--success)}.button-link{color:var(--neon-blue);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:.4rem .6rem;font-size:.8rem;font-weight:600;transition:background .15s}.button-link:hover{background:#00d4ff1a}.bowl-controls{gap:.65rem;padding:.75rem 1rem}.grip-dock{z-index:10;padding:.75rem;padding-bottom:max(.75rem, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--line-strong);background:#0f0519f2;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 30px #00000080}.controller-name-form{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:.75rem;display:grid}.field-stack{gap:.45rem;display:grid}.field-label{color:var(--text-soft);letter-spacing:.12em;text-transform:uppercase;font-size:.72rem}.text-input{border:1px solid var(--line);color:#f0e6d3;background:#0f0519d1;border-radius:18px;width:100%;padding:.9rem 1rem}.text-input:focus{border-color:var(--neon-blue);box-shadow:0 0 12px var(--neon-blue-glow);outline:none}.copy-invite-button{width:100%;margin:0 0 .75rem}.controller-qr-label{margin-top:.85rem}.controller-qr-note{margin:-.25rem 0 .75rem;font-size:.85rem}.mobile-controller-link{display:none}.join-setup-backdrop{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#08040c6b;place-items:center;padding:1rem;display:grid;position:absolute;inset:0}.join-setup-card{text-align:center;gap:.8rem;width:min(340px,100vw - 2rem);display:grid}.join-setup-card h2{font-size:clamp(1.8rem,5vw,2.8rem)}.join-setup-line{color:var(--text-soft);font-weight:700}.join-setup-qr{margin:0 auto}.controller-status{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.controller-hint{color:var(--text-soft);font-weight:600}.controller-dock{z-index:4;border:1px solid var(--line-strong);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0f0519f0;border-radius:28px;margin-top:1rem;padding:.85rem;position:sticky;bottom:.75rem;box-shadow:0 -8px 40px #00000080,0 0 60px #ff413614}.dock-controls{flex-direction:column;gap:.5rem;margin-bottom:.65rem;display:flex}.dock-control-row{align-items:center;gap:.5rem;display:flex}.dock-control-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-soft);flex-shrink:0;width:52px;font-size:.7rem}.lane-arrow{touch-action:manipulation;flex-shrink:0;min-width:48px;min-height:48px;padding:0;font-size:1.1rem;line-height:1}.lane-position-indicator{flex:1;align-items:center;display:flex}.lane-position-track{background:repeating-linear-gradient(90deg, var(--lane-wood-dark) 0px, var(--lane-wood) 3px, var(--lane-wood-dark) 6px);opacity:.6;border-radius:4px;width:100%;height:8px;position:relative}.lane-position-track:after{content:"";background:#ffffff59;border-radius:1px;width:2px;position:absolute;top:-4px;bottom:-4px;left:50%;transform:translate(-50%)}.lane-position-dot{background:var(--accent);width:20px;height:20px;box-shadow:0 0 12px var(--accent-glow), 0 0 24px #ff413633;border:2px solid #ffffff4d;border-radius:50%;transition:left .12s ease-out;position:absolute;top:50%;transform:translate(-50%,-50%)}.controller-debug{color:var(--text-soft)}.controller-debug summary{cursor:pointer}.metric-chip,.metric-card,.value-list,.score-frame{border:1px solid var(--line);background:#140a23bd;border-radius:16px}.metric-chip{flex-direction:column;align-items:flex-end;padding:.8rem .95rem;display:flex}.metric-chip-label,.metric-label{color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.metric-card{gap:.25rem;padding:1rem;display:grid}.metric-card strong{color:var(--neon-blue);text-shadow:0 0 8px var(--neon-blue-glow);font-family:Russo One,sans-serif;font-size:1.6rem}.meter-card{border:1px solid var(--line);background:#140a23bd;border-radius:16px;gap:.3rem;padding:.4rem .5rem;display:grid}.meter-header{justify-content:space-between;align-items:baseline;display:flex}.meter-header .metric-label{font-size:.65rem}.meter-header strong{color:var(--neon-blue);text-shadow:0 0 8px var(--neon-blue-glow);font-family:Russo One,sans-serif;font-size:.9rem}.meter-track{background:#ffffff0f;border-radius:3px;height:6px;overflow:hidden}.meter-fill{background:linear-gradient(90deg, var(--neon-blue), var(--accent));height:100%;box-shadow:0 0 8px var(--neon-blue-glow);border-radius:3px;transition:width .15s ease-out}.meter-fill.high{background:linear-gradient(90deg, var(--gold), var(--accent));box-shadow:0 0 8px var(--gold-glow)}.pin-rack-visual{border:1px solid var(--line);background:#140a23bd;border-radius:16px;justify-items:center;gap:2px;padding:.4rem .5rem;display:grid}.pin-row{justify-content:center;gap:4px;display:flex}.pin-dot{background:#f0e6d3;border-radius:50%;width:8px;height:8px;transition:opacity .3s,transform .3s;box-shadow:0 0 4px #f0e6d366}.pin-dot.down{opacity:.12;box-shadow:none;background:#fff3;transform:scale(.5)}.pin-rack-label{color:var(--text-soft);text-transform:uppercase;letter-spacing:.06em;text-align:center;font-size:.65rem}.value-list{padding:1rem}.value-row{border-top:1px solid #ff505017;justify-content:space-between;gap:1rem;padding:.45rem 0;display:flex}.value-row:first-of-type{border-top:0}.scoreboard{grid-template-columns:repeat(5,minmax(0,1fr));gap:.5rem;margin-top:.75rem;display:grid}.scoreboard.compact{grid-template-columns:repeat(5,minmax(0,1fr));gap:.35rem}.score-frame{gap:.3rem;padding:.6rem;display:grid;position:relative}.score-frame.active{border-color:var(--gold);box-shadow:0 0 12px var(--gold-glow), inset 0 0 8px #ffd7000f}.score-frame-index{color:var(--text-soft);letter-spacing:.12em;text-transform:uppercase;text-align:center;font-size:.65rem}.score-rolls{grid-template-columns:repeat(3,minmax(0,1fr));gap:.25rem;display:grid}.score-rolls span{background:#ffffff0a;border-radius:6px;justify-content:center;align-items:center;min-height:1.6rem;font-size:.8rem;font-weight:700;display:inline-flex}.score-rolls .roll-strike{color:var(--gold);text-shadow:0 0 8px var(--gold-glow)}.score-rolls .roll-spare{color:var(--neon-blue);text-shadow:0 0 8px var(--neon-blue-glow)}.score-frame strong{text-align:center;color:#f0e6d3;font-family:Russo One,sans-serif;font-size:.85rem}.scoreboard-panel{position:sticky;top:1.5rem}.player-score-section{text-align:left;width:100%;color:inherit;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:16px;margin-bottom:.35rem;padding:.4rem;transition:border-color .18s,background .18s,transform .18s}.player-score-section:hover{background:#00d4ff08;border-color:#00d4ff33}.player-score-section.active{border-color:var(--gold);background:#ffd7000a;box-shadow:0 0 12px #ffd70014}.player-score-section:focus-visible{border-color:var(--gold);box-shadow:0 0 0 2px var(--gold-glow);outline:none}.player-score-header{justify-content:space-between;align-items:center;padding:.3rem .2rem;font-size:.8rem;display:flex}.player-score-summary{align-items:center;gap:.5rem;display:flex}.player-score-meta{color:var(--text-soft);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem}.player-name{color:var(--text-soft)}.player-name.active{color:var(--gold);text-shadow:0 0 8px var(--gold-glow);font-weight:700}.scoreboard-panel .button.secondary{padding:.65rem .9rem}.scoreboard-panel .score-frame{padding:.5rem}.scoreboard-panel .score-rolls span{min-height:1.4rem;font-size:.75rem}.scoreboard-panel .score-frame strong{font-size:.8rem}.lane-visual{border:1px solid var(--line-strong);background:linear-gradient(#ff41360a,#0000 20%),linear-gradient(#0003,#0000 50%),linear-gradient(#1a0e28 0%,#0f0a18 30%,#0a0812 100%);border-radius:28px;min-height:520px;margin:1rem 0;transition:box-shadow .6s;position:relative;overflow:hidden}.lane-visual.lane-glow-idle{box-shadow:inset 0 0 80px #00d4ff0a,0 0 40px #0000004d}.lane-visual.lane-glow-holding{border-color:#00d4ff40;box-shadow:inset 0 0 80px #00d4ff14,0 0 50px #00d4ff0f}.lane-visual.lane-glow-armed{border-color:#ff413659;animation:.8s ease-in-out infinite alternate armed-pulse;box-shadow:inset 0 0 100px #ff41361a,0 0 60px #ff413614}.lane-visual.lane-glow-rolling{box-shadow:inset 0 0 60px #00d4ff0f,0 0 40px #0000004d}.lane-visual.lane-glow-strike{border-color:#ffd70066;animation:.3s ease-out strike-flash;box-shadow:inset 0 0 120px #ffd7001f,0 0 80px #ffd70014}.lane-visual.lane-glow-spare{border-color:#00d4ff66;box-shadow:inset 0 0 100px #00d4ff1a,0 0 60px #00d4ff0f}@keyframes armed-pulse{0%{box-shadow:inset 0 0 80px #ff41360f,0 0 40px #ff41360a}to{box-shadow:inset 0 0 120px #ff413624,0 0 80px #ff41361a}}@keyframes strike-flash{0%{box-shadow:inset 0 0 200px #ffd70059,0 0 120px #ffd70033}to{box-shadow:inset 0 0 120px #ffd7001f,0 0 80px #ffd70014}}.lane-visual-stage{height:100dvh;min-height:0;box-shadow:none;border:0;border-radius:0;margin:0}.lane-scene{z-index:0;position:absolute;inset:0}.lane-scene canvas{display:block}.replay-badge{z-index:4;letter-spacing:.12em;text-transform:uppercase;color:#fff;pointer-events:none;background:#dc1e1ed9;border:1px solid #ff3c3c99;border-radius:4px;padding:4px 14px;font-family:Russo One,sans-serif;font-size:.85rem;font-weight:700;animation:.8s ease-in-out infinite alternate replay-pulse;position:absolute;top:16px;left:16px;box-shadow:0 0 12px #ff282866}@keyframes replay-pulse{0%{opacity:.85}to{opacity:1;box-shadow:0 0 20px #ff282899}}.roll-callout{z-index:3;letter-spacing:.06em;text-transform:uppercase;pointer-events:none;font-family:Russo One,sans-serif;font-size:clamp(3rem,8vw,7rem);font-weight:900;animation:.5s cubic-bezier(.2,1.4,.4,1) forwards callout-pop;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.roll-callout-strike{color:var(--gold);text-shadow:0 0 30px var(--gold-glow), 0 0 60px #ffd7004d, 0 0 100px #ff8c0033, 0 4px 20px #0009;animation:.5s cubic-bezier(.2,1.4,.4,1) forwards callout-pop,1.5s ease-in-out infinite alternate strike-glow}.roll-callout-spare{color:var(--neon-blue);text-shadow:0 0 20px var(--neon-blue-glow), 0 0 50px #00d4ff33, 0 4px 20px #0009}.roll-callout-gutter{color:#6b5b73;text-shadow:none;font-size:clamp(1.5rem,4vw,3rem)}.roll-callout-pins{color:var(--text-soft);text-shadow:0 2px 10px #00000080;font-size:clamp(1.5rem,4vw,3rem)}.roll-callout-split{color:#ff4136;text-shadow:0 0 20px #ff4136cc,0 0 40px #ff413666}@keyframes callout-pop{0%{opacity:0;transform:translate(-50%,-50%)scale(.2)rotate(-5deg)}60%{opacity:1;transform:translate(-50%,-50%)scale(1.15)rotate(1deg)}to{opacity:1;transform:translate(-50%,-50%)scale(1)rotate(0)}}@keyframes strike-glow{0%{filter:brightness()}to{filter:brightness(1.3)}}.lane-visual:before,.lane-visual:after{display:none}.host-overlay{z-index:2;position:absolute}.host-overlay-room{width:min(300px,100% - 1.7rem);top:.85rem;left:.85rem}.turn-banner{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;pointer-events:none;background:#0a0612b3;border:1px solid #ff505033;border-radius:2rem;align-items:center;gap:.6rem;padding:.45rem 1.2rem;display:flex;position:absolute;top:.75rem;left:50%;transform:translate(-50%)}.turn-banner-name{color:gold;font-family:Russo One,sans-serif;font-size:clamp(.9rem,1.8vw,1.2rem)}.turn-banner-detail{color:var(--text-soft);font-size:clamp(.75rem,1.4vw,.95rem)}.event-toast{z-index:10;color:#ffe3ad;pointer-events:none;background:#23120cc2;border:1px solid #ffd70047;border-radius:999px;padding:.45rem 1rem;font-weight:700;animation:.35s ease-out forwards callout-pop;position:absolute;top:4rem;left:50%;transform:translate(-50%)}.host-overlay-scoreboard{width:min(300px,100% - 1.7rem);max-height:calc(100% - 1.7rem);top:.85rem;right:.85rem;overflow:hidden auto}.host-overlay-scoreboard .row-between{align-items:flex-start;gap:.55rem}.host-overlay-scoreboard .row-between>div{flex-wrap:wrap;justify-content:flex-end;gap:.4rem;min-width:0;display:flex}.host-overlay-hud{width:min(340px,100% - 19rem);bottom:.85rem;left:.85rem}.host-hud-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:.35rem;margin-bottom:.4rem;display:grid}.host-hud-grid .metric-card{padding:.4rem .5rem}.host-hud-grid .metric-card strong{font-size:.9rem}.host-hud-grid .metric-card small{font-size:.65rem}.host-overlay-room h1{font-variant-numeric:lining-nums slashed-zero;font-feature-settings:"lnum" 1, "zero" 1;letter-spacing:.04em;font-family:SFMono-Regular,ui-monospace,Cascadia Code,Source Code Pro,monospace;font-size:clamp(2rem,4.5vw,3.4rem)}.host-overlay-room .lede,.host-overlay-hud .note{font-size:.95rem}.host-overlay-scoreboard .button.secondary{white-space:normal;padding:.58rem .72rem;font-size:.78rem;line-height:1.05}.host-overlay-scoreboard .score-frame{padding:.5rem}.host-overlay-scoreboard .score-rolls span{min-height:1.3rem;font-size:.72rem}.host-overlay-scoreboard .score-frame strong{font-size:.78rem}.host-debug-panel summary{cursor:pointer;color:var(--text-soft)}.host-debug-panel{width:min(1200px,100% - 2rem);margin:1rem auto 2rem}.host-debug-stack{gap:1rem;margin-top:1rem;display:grid}.aim-marker,.power-ball,.backswing-arm{position:absolute}.aim-marker{width:56px;height:56px;box-shadow:0 0 30px var(--accent-glow);background:#ff41361f;border:2px solid #ff4136b3;border-radius:50%;top:12%}.power-ball{background:radial-gradient(circle at 32% 26%, #fef9c3 0%, var(--accent) 24%, #900 62%, #2a0000 100%);border-radius:50%;width:68px;height:68px;box-shadow:0 24px 60px #00000080}.backswing-arm{transform-origin:bottom;background:linear-gradient(180deg, var(--gold), var(--accent));border-radius:999px;width:10px;height:180px;bottom:6%;left:50%}.stack li{color:var(--text-soft);margin-top:.4rem}.stack li::marker{color:var(--accent)}.scorecard-empty{text-align:center;padding:1.25rem .75rem}.scorecard-empty-pins{justify-content:center;gap:3px;margin-bottom:.6rem;display:flex}.scorecard-empty-pin{background:var(--text-soft);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite pin-blink}.scorecard-empty-pin:nth-child(2){animation-delay:.15s}.scorecard-empty-pin:nth-child(3){animation-delay:.3s}.scorecard-empty-pin:nth-child(4){animation-delay:.45s}.scorecard-empty-pin:nth-child(5){animation-delay:.6s}.scorecard-empty-pin:nth-child(6){animation-delay:.75s}.scorecard-empty-pin:nth-child(7){animation-delay:.9s}.scorecard-empty-pin:nth-child(8){animation-delay:1.05s}.scorecard-empty-pin:nth-child(9){animation-delay:1.2s}.scorecard-empty-pin:nth-child(10){animation-delay:1.35s}@keyframes pin-blink{0%,to{opacity:.3}50%{opacity:1}}.scorecard-empty .empty-state{font-size:.85rem}.button.grip-button{background:radial-gradient(circle at 65% 35%, #ffffff1a 0%, transparent 50%), linear-gradient(135deg, var(--accent) 0%, #c20 100%)}.button.grip-button.active{background:radial-gradient(circle at 65% 35%, #ffffff26 0%, transparent 50%), linear-gradient(135deg, var(--gold) 0%, #ff8c00 100%)}.winner-overlay{z-index:5;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);background:#0f0519f0;border:1px solid #ffd70059;border-radius:28px;flex-direction:column;align-items:center;gap:1.5rem;width:min(480px,100% - 2rem);padding:2.5rem 2rem;animation:.5s cubic-bezier(.2,1.4,.4,1) forwards callout-pop;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 80px #ffd7001f,0 32px 80px #0009,inset 0 1px #ffffff0f}.winner-heading{background:linear-gradient(135deg, #fff 0%, var(--gold) 50%, var(--accent) 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 8px #ffd70040);text-align:center;-webkit-background-clip:text;background-clip:text;font-family:Russo One,sans-serif;font-size:clamp(2rem,5vw,3.2rem)}.winner-list{flex-direction:column;gap:.5rem;width:100%;display:flex}.winner-entry{border:1px solid var(--line);background:#140a2399;border-radius:14px;align-items:center;gap:.75rem;padding:.7rem 1rem;display:flex}.winner-entry.first-place{background:#ffd70014;border-color:#ffd70080;box-shadow:0 0 20px #ffd7001a}.winner-rank{width:2rem;height:2rem;color:var(--text-soft);background:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;font-family:Russo One,sans-serif;font-size:.85rem;display:flex}.winner-entry.first-place .winner-rank{background:var(--gold);color:#1a0a2e;box-shadow:0 0 12px var(--gold-glow)}.winner-name{flex:1;font-weight:600}.winner-entry.first-place .winner-name{color:var(--gold);text-shadow:0 0 8px var(--gold-glow)}.winner-score{color:var(--neon-blue);text-shadow:0 0 8px var(--neon-blue-glow);font-family:Russo One,sans-serif;font-size:1.3rem}.winner-entry.first-place .winner-score{color:var(--gold);text-shadow:0 0 8px var(--gold-glow)}.winner-overlay-perfect .winner-heading{color:gold;text-shadow:0 0 30px #ffd700e6,0 0 60px #ffd70080;-webkit-text-fill-color:gold;background:0 0;animation:1.5s ease-in-out infinite perfect-pulse}@keyframes perfect-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.ball-color-picker{flex-direction:column;gap:.4rem;display:flex}.ball-color-options{flex-wrap:wrap;gap:.5rem;display:flex}.ball-color-swatch{cursor:pointer;border:2px solid #ffffff26;border-radius:50%;width:2.2rem;height:2.2rem;transition:transform .15s,border-color .15s}.ball-color-swatch:hover{transform:scale(1.15)}.ball-color-swatch.active{border-color:gold;transform:scale(1.1);box-shadow:0 0 12px #ffd70080}.bumper-btn{letter-spacing:.04em;font-size:.78rem;padding:.65rem .9rem!important}.fullscreen-btn{min-width:40px;font-size:1.1rem;line-height:1;padding:.65rem .75rem!important}.last-throw-section{gap:.6rem;display:grid}.last-throw-section .eyebrow{margin-bottom:-.2rem}@media (width<=960px){.host-layout,.host-game-layout,.grid.two,.grid.three{grid-template-columns:1fr}.host-hud-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.scoreboard,.scoreboard.compact{grid-template-columns:repeat(5,minmax(0,1fr))}.invitation,.scoreboard-panel{position:static}.lane-visual-stage{border:1px solid var(--line-strong);border-radius:28px;gap:1rem;min-height:auto;padding:1rem;display:grid}.host-overlay{width:auto;max-height:none;position:static;transform:none}.mobile-controller-link{display:inline-flex}.shell{width:min(100% - 1rem,1200px);padding-top:.75rem}.host-shell{width:100%}.topbar,.row-between{flex-direction:column;align-items:flex-start}.controller-name-form{grid-template-columns:1fr}.metric-chip{align-items:flex-start}.controller-dock{border-radius:24px 24px 0 0;bottom:0;left:0;right:0}}
