:root{color:#f9fafb;background:#030712;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#site-root{min-height:100%;margin:0}body{background:radial-gradient(circle at 78% 14%,#60a5fa33,#0000 28rem),radial-gradient(circle at 17% 26%,#facc151a,#0000 24rem),linear-gradient(#061126 0%,#07142b 48%,#020617 100%);position:relative;overflow-x:hidden}body:before{z-index:0;pointer-events:none;content:"";opacity:.36;mix-blend-mode:screen;background:linear-gradient(#02061729,#020617b8),url(/assets/homepage-background.webp) top/cover no-repeat;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000f2,#0000 92%);mask-image:linear-gradient(#000000f2,#0000 92%)}body:after{z-index:0;pointer-events:none;content:"";background:radial-gradient(#1e40af5c,#0000 64%),linear-gradient(#0000,#020617eb);height:34vh;position:fixed;inset:auto 0 0}button{color:inherit;font:inherit;cursor:pointer;border:0;transition:background-color .16s,border-color .16s,box-shadow .16s,color .16s,opacity .16s,transform .16s}button:disabled{cursor:not-allowed}#game-root{display:none}#site-root{z-index:1;position:relative}.is-playing{overflow:hidden}.is-playing #site-root{z-index:2;pointer-events:none;position:fixed;inset:0}.is-playing #game-root{padding:max(92px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(64px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));background:linear-gradient(#02061794,#020617e6),url(/assets/homepage-background.webp) top/cover no-repeat,radial-gradient(circle at 50% 16%,#38bdf829,#0000 26rem),#020617;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.is-playing #game-root canvas{border-radius:8px;max-width:min(100%,1080px,177.78dvh - 277.337px);max-height:calc(100dvh - 156px);box-shadow:0 24px 70px #0006,0 0 0 1px #7dd3fc1f;width:min(100%,1080px,177.78dvh - 277.337px)!important;height:auto!important;margin:0 auto!important;display:block!important}.home-screen{width:min(1280px,100% - 48px);margin:0 auto;padding:28px 0 18px}.top-bar,.play-bar{justify-content:space-between;align-items:center;gap:18px;min-height:52px;display:flex}.brand{transform-origin:0;align-items:center;width:188px;height:52px;transition:filter .18s,transform .18s;display:inline-flex;overflow:hidden}.brand img{object-fit:cover;object-position:47% 48%;width:100%;height:100%;transition:transform .18s}.brand:hover{filter:drop-shadow(0 10px 18px #facc1529);transform:translateY(-1px)}.brand:hover img{transform:scale(1.03)}.nav-links,.action-row{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.nav-button{color:#aeb8ca;transform-origin:50%;background:0 0;border-radius:0;min-height:38px;padding:0 4px;font-weight:900;position:relative}.nav-button.active,.nav-button:hover:not(:disabled){color:#facc15}.nav-button.active:after{content:"";transform-origin:0;background:#facc15;height:2px;transition:transform .16s;position:absolute;bottom:2px;left:0;right:0;transform:scaleX(1)}.nav-button:not(.active):after{content:"";transform-origin:0;background:#facc15;height:2px;transition:transform .16s;position:absolute;bottom:2px;left:0;right:0;transform:scaleX(0)}.nav-button:hover:not(:disabled){transform:translateY(-1px)}.nav-button:hover:not(:disabled):after{transform:scaleX(1)}.nav-button:focus-visible,.primary-button:focus-visible,.secondary-button:focus-visible,.ghost-button:focus-visible,.preview-play:focus-visible{outline-offset:4px;outline:2px solid #f8fafc}.nav-button:disabled{color:#8792a6}.with-badge{align-items:center;gap:8px;display:inline-flex}.with-badge span,.coming-soon{color:#facc15;background:#facc1529;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:950;transition:background-color .16s,color .16s,transform .16s}.with-badge:hover span{transform:translateY(-1px)}.home-layout{grid-template-columns:minmax(320px,.72fr) minmax(540px,1.28fr);align-items:center;gap:44px;min-height:460px;padding:52px 0 36px;display:grid}.intro-panel{align-content:center;gap:22px;display:grid}h1,h2,p{margin:0}.hero-logo-heading{line-height:0}.hero-logo{object-fit:cover;object-position:43% 48%;filter:drop-shadow(0 22px 34px #02061757);transform-origin:0;width:min(100%,520px);height:220px;transition:filter .22s,transform .22s}.hero-logo:hover{filter:drop-shadow(0 24px 34px #02061766)drop-shadow(0 0 18px #facc151a);transform:translateY(-2px)scale(1.01)}h2{color:#f8fafc;text-transform:uppercase;align-items:center;gap:12px;font-size:22px;line-height:1.1;display:flex}.intro-copy{color:#d7deeb;max-width:420px;font-size:24px;font-weight:700;line-height:1.34}.primary-button,.secondary-button,.ghost-button{text-transform:uppercase;border-radius:8px;justify-content:center;align-items:center;gap:12px;min-height:58px;padding:0 34px;font-weight:950;display:inline-flex}.primary-button{color:#0f172a;background:linear-gradient(#fde68a 0%,#facc15 100%);width:min(100%,280px);font-size:20px;box-shadow:0 18px 40px #facc1538,inset 0 -2px #92400e47}.primary-button:hover{background:linear-gradient(#fef3c7 0%,#facc15 100%);transform:translateY(-2px);box-shadow:0 22px 48px #facc154d,inset 0 -2px #92400e47}.primary-button:active,.secondary-button:active,.ghost-button:active,.preview-play:active{transform:translateY(0)scale(.98)}.secondary-button,.ghost-button{color:#7dd3fc;background:#0f172ab8;border:1px solid #7dd3fc47}.secondary-button:hover,.ghost-button:hover{color:#bae6fd;background:#0f172ae6;border-color:#7dd3fc8f;transform:translateY(-2px);box-shadow:0 12px 28px #0ea5e91f}.ghost-button{text-transform:none;min-height:40px;padding:0 18px}.compact-button{min-height:38px;padding:0 18px}.play-icon{border-top:8px solid #0000;border-bottom:8px solid #0000;border-left:13px solid;width:0;height:0;transition:transform .16s}button:hover .play-icon{transform:translate(2px)}.no-signup{color:#cbd5e1;padding-left:58px;font-size:15px;font-weight:700}.hero-preview{aspect-ratio:16/9;background:radial-gradient(circle at 50% 58%,#2563eb33,#0000 42%),linear-gradient(#0f172a9e,#0f172ae6);border:1px solid #94a3b857;border-radius:16px;transition:border-color .2s,box-shadow .2s,transform .2s;position:relative;box-shadow:0 28px 80px #0206177a,inset 0 0 0 1px #ffffff0d}.hero-preview:hover{border-color:#7dd3fc66;transform:translateY(-2px);box-shadow:0 34px 90px #0206178a,0 0 44px #0ea5e914,inset 0 0 0 1px #ffffff12}.preview-stage,.mini-preview{border-radius:inherit;background:linear-gradient(#02061724,#02061761 58%,#0000 59%),repeating-linear-gradient(90deg,#f8fafc0a 0 9px,#0000 9px 20px),linear-gradient(#10265b 0%,#12346d 56%,#e7775c 57%,#f29a79 86%,#0e7490 87%);width:100%;height:100%;position:relative;overflow:hidden}.preview-stage:before,.mini-preview:before{content:"";background:radial-gradient(circle,#facc1552 0 2px,#0000 3px) 0 0/34px 18px,linear-gradient(#0f172acc,#0f172a47);height:18%;position:absolute;bottom:35%;left:0;right:0}.scoreboard{z-index:3;color:#f8fafc;text-transform:uppercase;align-items:center;gap:14px;font-size:20px;font-weight:950;display:flex;position:absolute;top:8%;left:50%;transform:translate(-50%)}.scoreboard.mini{gap:8px;font-size:12px;top:6%}.score-chip{color:#fff;border-radius:6px;padding:7px 12px;transition:box-shadow .16s,transform .16s;box-shadow:inset 0 -2px #00000038}.scoreboard.mini .score-chip{padding:4px 7px}.score-chip.blue{background:#0284c7}.score-chip.yellow{color:#172554;background:#eab308}.stadium-lights{z-index:2;filter:drop-shadow(0 0 16px #ffffff7a);background:radial-gradient(circle,#fff7ed 0 5px,#0000 7px) 0 0/24px 22px,radial-gradient(circle,#fff9,#0000 62%);width:76px;height:66px;position:absolute}.stadium-lights.left{top:13%;left:7%;transform:rotate(-9deg)}.stadium-lights.right{top:13%;right:7%;transform:rotate(9deg)}.arc{z-index:2;border-top:24px solid #cbd5e157;border-radius:50%;position:absolute;transform:rotate(-24deg)}.arc-large{width:260px;height:130px;top:36%;left:23%}.arc-small{opacity:.7;border-top-width:14px;width:72px;height:42px;top:27%;left:48%}.preview-court{position:absolute;inset:0}.court-line{background:#ffffffad;width:3px;height:20%;position:absolute;bottom:6%;transform:skew(-13deg)}.court-line.center{left:50%}.court-line.left{left:38%}.court-line.right{right:38%}.preview-net{z-index:4;background:linear-gradient(90deg,#0000 36%,#02061752 37% 63%,#0000 64%),#f8fafc;width:10px;height:37%;position:absolute;bottom:7%;left:calc(50% - 5px);box-shadow:0 18px 18px #02061752}.preview-player,.preview-ball{z-index:4;transition:filter .18s,transform .18s;position:absolute}.preview-player{aspect-ratio:.58;width:7%;min-width:34px;bottom:14%}.preview-player:before,.preview-player:after,.preview-player span:before,.preview-player span:after{content:"";image-rendering:pixelated;position:absolute}.preview-player:before{aspect-ratio:1;background:#fecaca;border-radius:3px;width:42%;top:0;left:28%}.preview-player:after{background:var(--kit);border-radius:4px;width:58%;height:34%;top:28%;left:20%;box-shadow:-10px 8px 0 -5px #fecaca,10px 8px 0 -5px #fecaca}.preview-player span:before,.preview-player span:after{background:#e5e7eb;width:16%;height:30%;bottom:0}.preview-player span:before{left:28%;transform:rotate(9deg)}.preview-player span:after{right:28%;transform:rotate(-9deg)}.preview-player-left{--kit:#38bdf8;left:22%}.preview-player-right{--kit:#facc15;right:20%}.preview-ball{aspect-ratio:1;background:linear-gradient(135deg,#0000 42%,#60a5fa 43% 58%,#0000 59%),linear-gradient(45deg,#0000 42%,#facc15 43% 58%,#0000 59%),#e5e7eb;border:4px solid #f8fafc;border-radius:50%;width:6%;min-width:28px;box-shadow:0 14px 22px #02061761}.hero-ball{animation:1.8s ease-in-out infinite ball-bounce;top:32%;left:50%}.info-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.info-panel,.build-focus{background:linear-gradient(#0f172adb,#0f172aa8),#0f172ab8;border:1px solid #94a3b838;border-radius:12px;transition:border-color .18s,box-shadow .18s,transform .18s;box-shadow:inset 0 1px #ffffff0a}.info-panel{min-height:330px;padding:26px}.info-panel:hover,.build-focus:hover{border-color:#7dd3fc57;transform:translateY(-3px);box-shadow:0 18px 44px #0206173d,inset 0 1px #ffffff0f}.info-panel p,.control-list{color:#d4dbe8;margin-top:16px;line-height:1.55}.panel-icon,.focus-icon{color:#67e8f9;flex:none;place-items:center;transition:color .16s,filter .16s,transform .16s;display:inline-grid;position:relative}.panel-icon{width:34px;height:34px}.gamepad-icon:before{content:"";background:#e5e7eb;border-radius:8px;width:28px;height:18px}.gamepad-icon:after{content:"";background:#0f172a;width:4px;height:4px;position:absolute;box-shadow:-7px 0 #0f172a,8px 0 #0f172a}.monitor-icon:before{content:"";border:3px solid #e5e7eb;border-radius:2px;width:28px;height:18px}.monitor-icon:after{content:"";background:#e5e7eb;width:18px;height:3px;position:absolute;bottom:3px}.trophy-icon:before{color:#facc15;content:"#";font-size:30px}.rocket-icon:before{content:"";background:#67e8f9;border-radius:50% 50% 50% 0;width:22px;height:22px;transform:rotate(-45deg)}.control-list{gap:12px;display:grid}.player-control-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.player-control-card{background:#0f172a7a;border:1px solid #94a3b833;border-radius:8px;gap:9px;margin:0;padding:14px;display:grid}.player-control-card.blue{border-color:#38bdf842}.player-control-card.yellow{border-color:#facc1547}.player-control-card dt{margin-bottom:2px;font-size:18px;font-weight:950}.player-control-card.blue dt{color:#7dd3fc}.player-control-card.yellow dt{color:#fde68a}.player-control-card dd{grid-template-columns:minmax(64px,1fr) auto;align-items:center;gap:7px;margin:0;display:grid}.player-control-card dd span{color:#d4dbe8;font-size:14px;font-weight:800}.control-keys{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.key-row{align-items:center;gap:14px;transition:transform .16s;display:flex}.key-row dt{gap:8px;display:flex}kbd{color:#fff;min-width:34px;height:34px;font:inherit;background:linear-gradient(#7dd3fc,#3b82f6);border-radius:6px;place-items:center;padding:0 8px;font-size:14px;font-weight:950;transition:box-shadow .16s,transform .16s;display:inline-grid;box-shadow:inset 0 -2px #1e3a8a57}.key-row:hover{transform:translate(3px)}.key-row:hover kbd{transform:translateY(-1px);box-shadow:0 8px 18px #3b82f62e,inset 0 -2px #1e3a8a57}.key-row dd{margin:0;font-weight:800}.how-panel{padding-bottom:134px;padding-right:26px;position:relative;overflow:hidden;container-type:inline-size}.how-panel>:not(.mascot){z-index:2;position:relative}.mascot{z-index:1;width:104px;height:144px;image-rendering:pixelated;opacity:.72;transform-origin:100% 100%;transition:opacity .18s,filter .18s,transform .18s;position:absolute;bottom:16px;right:24px;transform:scale(.76)}.how-panel:hover .mascot{filter:drop-shadow(0 14px 18px #38bdf829);opacity:.9;transform:translateY(-4px)scale(.78)}@container (width>=720px){.how-panel{padding-bottom:28px;padding-right:112px}.mascot{bottom:18px;right:20px}}@container (width<=480px){.player-control-grid{grid-template-columns:1fr}.how-panel{padding-bottom:126px}.mascot{opacity:.54;transform:scale(.58)}.how-panel:hover .mascot{transform:translateY(-3px)scale(.6)}}.mascot span{display:block;position:absolute}.mascot-head{background:linear-gradient(#111827 0 0) 10px 15px/6px 6px no-repeat,linear-gradient(#111827 0 0) 27px 15px/6px 6px no-repeat,linear-gradient(#ef4444 0 0) 17px 28px/10px 4px no-repeat,#fecaca;border-radius:14px 14px 18px 18px;width:42px;height:42px;top:0;left:34px}.mascot-head:before,.mascot-head:after{content:"";background:#111827;border-radius:6px;width:14px;height:18px;position:absolute;top:-4px}.mascot-head:before{left:2px;transform:rotate(-20deg)}.mascot-head:after{right:2px;transform:rotate(20deg)}.mascot-body{background:linear-gradient(#ffffff80 0 0) 19px 0/10px 52px no-repeat,#38bdf8;border-radius:6px 6px 4px 4px;width:48px;height:52px;top:47px;left:30px;box-shadow:inset 0 -8px #0284c76b}.mascot-arm{background:#fecaca;border-radius:10px;width:18px;height:48px;top:54px}.mascot-arm.left{left:17px;transform:rotate(28deg)}.mascot-arm.right{right:14px;transform:rotate(-34deg)}.mascot-leg{background:linear-gradient(#1f2937 0 0) 0 34px/18px 10px no-repeat,#e5e7eb;width:18px;height:44px;bottom:0}.mascot-leg.left{left:34px;transform:rotate(4deg)}.mascot-leg.right{right:28px;transform:rotate(-4deg)}.mascot-ball{background:linear-gradient(135deg,#0000 42%,#60a5fa 43% 58%,#0000 59%),linear-gradient(45deg,#0000 42%,#facc15 43% 58%,#0000 59%),#e5e7eb;border:4px solid #f8fafc;border-radius:50%;width:32px;height:32px;top:18px;right:0;box-shadow:0 12px 16px #0206174d}.ghost-button{margin-top:34px}.mini-preview{border:1px solid #94a3b847;border-radius:10px;height:190px;margin-top:24px;transition:background .18s,box-shadow .18s,transform .18s}.preview-panel:hover .mini-preview{transform:translateY(-2px);box-shadow:0 18px 38px #0206173d}.mini-preview .stadium-lights{width:52px;height:44px}.mini-preview .preview-net{height:40%}.mini-preview .preview-player{width:9%;min-width:28px;bottom:12%}.mini-preview .preview-ball{width:7%;transition:top .18s,left .18s;top:38%;left:48%}.mini-preview .preview-player,.mini-preview .preview-net,.mini-preview .scoreboard{transition:transform .18s,opacity .18s}.mini-preview[data-slide="1"]{background:linear-gradient(#02061714,#02061752 58%,#0000 59%),repeating-linear-gradient(90deg,#f8fafc0d 0 9px,#0000 9px 20px),linear-gradient(#0f2a55 0%,#0e3a6c 56%,#0f766e 57%,#14b8a6 86%,#0369a1 87%)}.mini-preview[data-slide="1"] .preview-ball{top:26%;left:66%}.mini-preview[data-slide="1"] .preview-player-left{transform:translateY(-18px)}.mini-preview[data-slide="2"]{background:linear-gradient(#0206172e,#0206176b 58%,#0000 59%),repeating-linear-gradient(90deg,#f8fafc0a 0 9px,#0000 9px 20px),linear-gradient(#171339 0%,#312e81 56%,#c2410c 57%,#fb923c 86%,#164e63 87%)}.mini-preview[data-slide="2"] .preview-ball{top:52%;left:34%}.mini-preview[data-slide="2"] .preview-player-right{transform:translateY(-20px)}.mini-preview[data-slide="3"]{background:linear-gradient(#02061742,#0206177a 58%,#0000 59%),repeating-linear-gradient(90deg,#f8fafc0a 0 9px,#0000 9px 20px),linear-gradient(#082f49 0%,#155e75 56%,#eab308 57%,#f97316 86%,#0f172a 87%)}.mini-preview[data-slide="3"] .preview-ball{top:18%;left:50%}.mini-preview[data-slide="3"] .preview-net{transform:scaleY(1.08)}.preview-play{z-index:7;color:#fff;background:#0f172a47;border:4px solid #ffffffe6;border-radius:50%;place-items:center;width:70px;height:70px;transition:background-color .16s,border-color .16s,box-shadow .16s,transform .16s;display:grid;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.preview-play:hover{background:#0f172a7a;border-color:#facc15;transform:translate(-50%,-50%)scale(1.06);box-shadow:0 0 34px #facc1533}.preview-play .play-icon{margin-left:4px}.pager{justify-content:center;gap:10px;margin-top:22px;display:flex}.pager button{background:#64748b;border-radius:50%;width:10px;height:10px;padding:0;transition:background-color .16s,transform .16s,width .16s}.pager button:hover{background:#cbd5e1;transform:translateY(-1px)}.pager button:focus-visible{outline-offset:3px;outline:2px solid #f8fafc}.pager .active{background:#facc15;width:16px}.leaderboard-panel h2{justify-content:space-between}.leaderboard-list{background:#1e293bbd;border-radius:10px;gap:0;margin:20px 0 0;padding:12px 18px;list-style-position:inside;transition:background-color .16s,box-shadow .16s;display:grid}.leaderboard-list li{color:#e5e7eb;border-bottom:1px solid #94a3b821;border-radius:6px;justify-content:space-between;align-items:center;min-height:38px;padding:0 8px;font-weight:800;transition:background-color .16s,color .16s,transform .16s;display:flex}.leaderboard-list li:hover{color:#fff;background:#7dd3fc14;transform:translate(3px)}.leaderboard-list li:last-child{border-bottom:0}.leaderboard-list strong{color:#f8fafc;transition:color .16s}.leaderboard-list li:hover strong{color:#facc15}.build-focus{margin-top:18px;padding:26px}.build-focus h2{color:#67e8f9}.focus-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:24px;margin-top:24px;display:grid}.focus-grid div{border-right:1px solid #94a3b82e;grid-template-columns:42px 1fr;align-items:center;gap:4px 14px;min-height:66px;transition:border-color .16s,transform .16s;display:grid}.focus-grid div:last-child{border-right:0}.focus-icon{grid-row:span 2;width:38px;height:38px;font-size:26px}.focus-grid strong{color:#f8fafc;font-size:17px}.focus-grid p{color:#cbd5e1}.focus-grid div:hover{border-color:#7dd3fc4d;transform:translateY(-2px)}.focus-grid div:hover .focus-icon{color:#facc15;filter:drop-shadow(0 0 14px #facc152e);transform:scale(1.08)}.focus-grid div:hover strong{color:#fff}.local-settings{grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:18px;margin-top:18px;display:grid}.local-profile,.settings-panel{background:linear-gradient(#0f172adb,#0f172aa8),#0f172ab8;border:1px solid #94a3b838;border-radius:12px;gap:18px;padding:24px;display:grid;box-shadow:inset 0 1px #ffffff0a}.local-profile label{color:#cbd5e1;gap:8px;font-size:14px;font-weight:900;display:grid}.local-profile input[type=text]{color:#f8fafc;width:100%;min-height:46px;font:inherit;background:#0206178a;border:1px solid #7dd3fc3d;border-radius:8px;outline:none;padding:0 14px;font-weight:800;transition:border-color .16s,box-shadow .16s}.local-profile input[type=text]:focus{border-color:#7dd3fcb8;box-shadow:0 0 0 3px #38bdf81f}.local-stats{flex-wrap:wrap;gap:10px;display:flex}.local-stats span{color:#94a3b8;background:#0f172ab8;border-radius:8px;align-items:center;gap:8px;min-height:38px;padding:0 12px;font-size:14px;font-weight:900;display:inline-flex}.local-stats strong{color:#facc15}.toggle-row{color:#dbeafe;align-items:center;gap:12px;font-weight:900;display:flex}.toggle-row input{accent-color:#38bdf8;width:20px;height:20px}.setting-field{color:#dbeafe;gap:8px;font-size:14px;font-weight:900;display:grid}.setting-field select{color:#f8fafc;width:100%;min-height:44px;font:inherit;background:#020617b8;border:1px solid #7dd3fc3d;border-radius:8px;outline:none;padding:0 12px;font-weight:850}.speed-options{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.speed-option{color:#bae6fd;background:#0206179e;border:1px solid #7dd3fc38;border-radius:8px;min-height:40px;font-size:14px;font-weight:950}.speed-option:hover{background:#0ea5e924;border-color:#7dd3fc85;transform:translateY(-1px)}.speed-option.active{color:#0f172a;background:linear-gradient(#fde68a,#facc15);border-color:#facc15b8;box-shadow:0 12px 28px #facc1529}.speed-option:focus-visible{outline-offset:3px;outline:2px solid #f8fafc}.effects-disabled *,.effects-disabled :before,.effects-disabled :after{transition-duration:.01ms!important;animation:none!important}.target-icon:before{color:#fb7185;content:"O"}.duel-icon:before{color:#5eead4;content:"2P";font-weight:950}.shield-icon:before{content:"";border:4px solid #4ade80;border-radius:14px 14px 18px 18px;width:26px;height:30px}.bolt-icon:before{clip-path:polygon(48% 0,100% 0,62% 42%,100% 42%,22% 100%,44% 54%,0 54%);content:"";background:#facc15;width:16px;height:30px}.site-footer{color:#9ca3af;justify-content:center;align-items:center;gap:22px;min-height:58px;display:flex}.play-screen{pointer-events:none;position:fixed;inset:0}.play-bar{top:max(16px, env(safe-area-inset-top));pointer-events:auto;width:min(1080px,100% - 32px);position:absolute;left:50%;transform:translate(-50%)}.play-brand{background:0 0;padding:0}.play-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.play-viewport-note{right:max(16px, env(safe-area-inset-right));bottom:max(16px, env(safe-area-inset-bottom));color:#cbd5e1;pointer-events:none;background:#020617c7;border:1px solid #7dd3fc33;border-radius:8px;max-width:min(320px,100vw - 32px);padding:12px 14px;display:none;position:absolute;box-shadow:0 16px 34px #0000003d}.play-viewport-note strong,.play-viewport-note span{display:block}.play-viewport-note strong{color:#f8fafc;font-size:13px;line-height:1.2}.play-viewport-note span{color:#94a3b8;margin-top:4px;font-size:12px;line-height:1.25}.pause-overlay,.result-overlay,.settings-overlay,.credits-overlay{z-index:20;pointer-events:none;opacity:0;place-items:center;padding:24px;transition:opacity .18s;display:grid;position:absolute;inset:0}.pause-overlay:before,.result-overlay:before,.settings-overlay:before,.credits-overlay:before{content:"";-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:radial-gradient(circle at 50% 35%,#60a5fa33,#0000 26rem),#02061794;position:absolute;inset:0}.pause-overlay.visible,.result-overlay.visible,.settings-overlay.visible,.credits-overlay.visible{pointer-events:auto;opacity:1}.pause-card,.result-card,.settings-card,.credits-card{text-align:center;background:linear-gradient(#0f172af5,#020617f5),radial-gradient(circle at 50% 0,#facc1529,#0000 18rem);border:1px solid #94a3b857;border-radius:8px;justify-items:center;width:min(460px,100%);max-height:min(760px,100vh - 48px);padding:34px;transition:transform .18s;display:grid;position:relative;overflow:auto;transform:translateY(10px)scale(.98);box-shadow:0 28px 70px #00000061,inset 0 1px #ffffff14}.pause-overlay.visible .pause-card,.result-overlay.visible .result-card,.settings-overlay.visible .settings-card,.credits-overlay.visible .credits-card{transform:translateY(0)scale(1)}.result-eyebrow{color:#7dd3fc;letter-spacing:0;text-transform:uppercase;font-size:13px;font-weight:950}.pause-card h2,.result-card h2,.settings-card h2,.credits-card h2{color:#f8fafc;justify-content:center;margin-top:12px;font-size:34px}.result-score{color:#f8fafc;text-shadow:0 10px 28px #38bdf833;margin-top:16px;font-size:58px;font-weight:950;line-height:1}.result-local-best{color:#fef3c7;background:#facc151a;border:1px solid #facc1542;border-radius:8px;margin-top:12px;padding:8px 12px;font-size:14px;font-weight:950}.result-overlay[data-winner=left] .result-card{background:linear-gradient(#0f172af5,#020617f5),radial-gradient(circle at 50% 0,#38bdf82e,#0000 18rem);border-color:#38bdf87a}.result-overlay[data-winner=right] .result-card{background:linear-gradient(#0f172af5,#020617f5),radial-gradient(circle at 50% 0,#facc152e,#0000 18rem);border-color:#facc157a}.result-overlay[data-winner=left] .result-eyebrow,.result-overlay[data-winner=left] .result-card h2{color:#7dd3fc}.result-overlay[data-winner=right] .result-eyebrow,.result-overlay[data-winner=right] .result-card h2{color:#facc15}.pause-card p,.result-card p,.settings-card p,.credits-card p{color:#cbd5e1;margin-top:18px;font-size:17px;font-weight:700}.result-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:26px;display:flex}.result-card .primary-button,.settings-card .primary-button{width:auto}.credits-card{width:min(560px,100%)}.credits-list{text-align:left;gap:14px;width:100%;margin-top:22px;display:grid}.credits-list article{background:#02061761;border:1px solid #7dd3fc2e;border-radius:8px;padding:16px}.credits-list strong{color:#f8fafc;font-size:17px;font-weight:950}.credits-list p{color:#cbd5e1;margin-top:8px;font-size:14px}.credits-list a{color:#7dd3fc;font-weight:900}.match-setup-card{text-align:left;justify-items:stretch;width:min(760px,100%)}.match-setup-card .result-eyebrow,.match-setup-card h2,.match-setup-card>p,.match-setup-card>.result-actions,.match-setup-card>.shortcut-hint{text-align:center;justify-self:center}.settings-form{gap:20px;width:100%;margin-top:22px;display:grid}.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.play-speed-options{width:min(360px,100%);margin-top:24px}.key-settings{border-top:1px solid #94a3b82e;gap:14px;width:100%;padding-top:18px;display:grid}.key-settings-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.key-settings h3{color:#f8fafc;margin:0;font-size:18px;font-weight:950}.key-settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.key-settings-card{background:#0206175c;border:1px solid #94a3b82e;border-radius:8px;gap:8px;padding:14px;display:grid}.key-settings-card.blue{border-color:#38bdf83d}.key-settings-card.yellow{border-color:#facc153d}.key-settings-card strong{color:#f8fafc;font-size:15px;font-weight:950}.key-settings-card label{color:#cbd5e1;grid-template-columns:minmax(72px,1fr) minmax(74px,auto);align-items:center;gap:8px;font-size:13px;font-weight:850;display:grid}.key-bind-button{color:#bae6fd;background:#0f172ac7;border:1px solid #7dd3fc3d;border-radius:7px;min-height:34px;padding:0 10px;font-size:13px;font-weight:950}.key-bind-button:hover{border-color:#7dd3fc94;transform:translateY(-1px)}.key-bind-button.listening{color:#fef3c7;background:#facc1529;border-color:#facc15c2}.result-submit{opacity:.72;margin-top:14px}.shortcut-hint{color:#94a3b8!important;font-size:13px!important}@keyframes ball-bounce{0%,to{transform:translate(-50%,8%)}50%{transform:translate(-50%,-60%)}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.brand:hover,.brand:hover img,.hero-logo:hover,.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.hero-preview:hover,.info-panel:hover,.build-focus:hover,.preview-panel:hover .mini-preview,.preview-play:hover,.leaderboard-list li:hover,.focus-grid div:hover,.how-panel:hover .mascot{transform:none}}@media (width<=1040px){.home-layout,.info-grid,.focus-grid,.local-settings{grid-template-columns:1fr}.home-layout{gap:28px;min-height:auto;padding:36px 0 28px}.focus-grid div{border-bottom:1px solid #94a3b82e;border-right:0;padding-bottom:18px}.focus-grid div:last-child{border-bottom:0}}@media (width<=720px){.home-screen{width:min(100% - 24px,560px);padding-top:18px}.top-bar{align-items:flex-start}.nav-links{justify-content:flex-end;gap:12px}.nav-button.active{display:none}.brand{width:150px;height:42px}.hero-logo{height:160px}.intro-copy{font-size:20px}.hero-preview{border-radius:10px}.info-panel{min-height:auto}.how-panel{padding-bottom:122px;padding-right:26px}.mascot{opacity:.62;bottom:16px;right:22px;transform:scale(.62)}.how-panel:hover .mascot{transform:translateY(-3px)scale(.64)}.player-control-grid{grid-template-columns:1fr}.site-footer{flex-direction:column;gap:12px;padding:22px 0}.is-playing #game-root{padding:max(104px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(96px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left))}.is-playing #game-root canvas{border-radius:6px;max-width:min(100%,1080px,177.78dvh - 355.56px);max-height:calc(100dvh - 200px);width:min(100%,1080px,177.78dvh - 355.56px)!important}.play-bar{align-items:flex-start;gap:10px}.play-actions{gap:8px}.play-actions .compact-button{min-height:34px;padding:0 12px;font-size:13px}.play-viewport-note{display:block}.pause-card,.result-card,.settings-card,.credits-card{padding:24px}.settings-grid,.key-settings-grid{grid-template-columns:1fr}.pause-card h2,.result-card h2,.settings-card h2,.credits-card h2{font-size:28px}.result-score{font-size:48px}.result-actions{width:100%}.result-actions .compact-button{flex:132px}}@media (height<=560px){.is-playing #game-root{padding:max(72px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(12px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left))}.is-playing #game-root canvas{max-width:min(100%,177.78dvh - 163.558px);max-height:calc(100dvh - 92px);width:min(100%,177.78dvh - 163.558px)!important}.play-bar .brand{width:132px;height:38px}.play-actions .compact-button{min-height:32px;padding:0 10px;font-size:12px}.play-viewport-note{display:none}}@media (orientation:portrait) and (width<=900px){.play-viewport-note{display:block}}
