:root{--bg: #0b0913;--panel: #171223;--panel-2: #211936;--line: #322a4c;--grass-a: #115c3a;--grass-b: #0e5034;--chalk: rgba(255, 255, 255, .55);--gold: #f2c14e;--accent: #8b5cf6;--you: #4ea8ff;--cpu: #ff7a45;--text: #ece9f7;--muted: #9a90b6;--radius: 14px;font-synthesis:none}*{box-sizing:border-box;margin:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{background:radial-gradient(120% 80% at 50% -10%,#201545 0%,var(--bg) 62%);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;overflow:hidden}.screen{max-width:440px;margin:0 auto;height:100%;display:flex;flex-direction:column;padding:12px 12px calc(12px + env(safe-area-inset-bottom));gap:10px}.screen.game{height:100dvh;max-height:100dvh;padding:8px 8px calc(6px + env(safe-area-inset-bottom));gap:8px;overflow:hidden}.screen.game .gameover{flex:1;min-height:0;overflow-y:auto}.home{justify-content:flex-start;align-items:center;text-align:center;gap:20px;overflow-y:auto;padding-top:24px;padding-bottom:28px}.home>:first-child{margin-top:auto}.home>:last-child{margin-bottom:auto}.logo{font-weight:900;font-size:44px;letter-spacing:1px;line-height:1}.logo span{color:var(--gold)}.tagline{color:var(--muted);margin-top:10px;font-style:italic}.home-actions{display:flex;flex-direction:column;gap:12px;width:260px}.home-foot{color:var(--muted);font-size:12px}.menu-list{display:flex;flex-direction:column;gap:10px;width:300px;max-width:88vw}.menu-item{display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;padding:13px 14px;border-radius:14px;border:1px solid var(--line);background:var(--panel);color:var(--text);font:inherit;transition:border-color .12s,background .12s}.menu-item:hover{border-color:var(--accent);background:var(--panel-2)}.menu-item.menu-online{border-color:#2c6f52}.menu-item.menu-online:hover{border-color:#35c98c}.menu-icon{font-size:24px;width:30px;text-align:center}.menu-text{display:flex;flex-direction:column;flex:1;gap:2px}.menu-label{font-weight:800;font-size:16px}.menu-sub{font-size:12px;color:var(--muted)}.menu-arrow{color:var(--muted);font-size:22px;font-weight:700}.continue-chip{display:flex;align-items:center;gap:10px;width:300px;max-width:88vw;cursor:pointer;padding:11px 14px;border-radius:14px;border:1px solid var(--gold);font:inherit;color:var(--text);background:#f2c14e1a}.cc-word{font-weight:800;color:var(--gold)}.cc-meta{flex:1;text-align:left;font-size:13px;color:var(--muted);font-family:ui-monospace,monospace}.home.sub{justify-content:flex-start;gap:16px;padding-top:14px}.home.sub>:first-child{margin-top:0}.home.sub>:last-child{margin-bottom:auto}.sub-head{display:flex;align-items:center;width:100%;max-width:380px;padding:0 4px}.sub-back{appearance:none;background:none;border:none;color:var(--accent);font:inherit;font-weight:700;font-size:15px;cursor:pointer;padding:6px 2px}.sub-title{flex:1;text-align:center;font-weight:900;font-size:16px;letter-spacing:1px;margin-right:48px}.empty-note{color:var(--muted);font-size:13px;text-align:center;line-height:1.5;padding:20px 8px}.tp-matchup.solo{justify-content:center}.play-clock{position:absolute;top:8px;left:10px;right:10px;z-index:30;height:20px;border-radius:10px;overflow:hidden;background:#00000073;border:1px solid var(--line)}.play-clock.theirs{opacity:.72}.pc-bar{position:absolute;inset:0 auto 0 0;transition:width .1s linear}.pc-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;letter-spacing:.5px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6)}.rejoin-btn{display:flex;flex-direction:column;gap:2px;line-height:1.2}.rejoin-meta{font-size:11px;font-weight:600;opacity:.85;font-family:ui-monospace,monospace}.mp-sms{text-decoration:none;text-align:center;margin-top:4px}.btn{appearance:none;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font:inherit;font-weight:700;padding:14px 16px;border-radius:12px;cursor:pointer;transition:transform .06s ease,background .15s ease,border-color .15s ease}.btn:active{transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:linear-gradient(180deg,#7c4ddb,#5628a8);border-color:#9a6cec;color:#fff}.scoreboard{display:flex;flex-direction:column;gap:6px;background:linear-gradient(180deg,#0d1512,#0a100d);border:1px solid var(--line);border-radius:var(--radius);padding:8px 10px;position:relative}.sb-main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}.sb-sub{display:flex;justify-content:space-between;align-items:center;gap:10px;border-top:1px solid var(--line);padding-top:5px;font-size:11px}.sb-poss{color:var(--muted);font-weight:800;letter-spacing:1px;white-space:nowrap}.sb-poss.poss-you{color:var(--you)}.sb-poss.poss-cpu{color:var(--cpu)}.sb-last{color:var(--muted);font-weight:600;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border-radius:10px;border:1px solid transparent}.team.has-ball{border-color:var(--gold);background:#f2c14e14}.team-name{display:flex;align-items:center;justify-content:center;gap:5px;font-size:12px;letter-spacing:2px;color:var(--muted);font-weight:800}.team-score{font-family:Calc,ui-monospace,SF Mono,Menlo,monospace;font-size:36px;font-weight:800;line-height:1;color:#fff;text-shadow:0 0 16px rgba(120,255,190,.3)}.team-to{color:var(--gold);font-size:11px;height:12px;letter-spacing:2px}.game-clock{text-align:center;min-width:92px}.clock-time{font-family:Calc,ui-monospace,SF Mono,Menlo,monospace;font-size:24px;font-weight:800;color:var(--gold);letter-spacing:1px}.clock-qtr{font-size:12px;color:var(--muted);font-weight:800;letter-spacing:1px}.dd{margin-top:4px;font-size:12px;font-weight:700;color:var(--text);background:var(--panel-2);border-radius:8px;padding:3px 6px}.stage{position:relative;flex:1;min-height:0;border-radius:var(--radius);border:1px solid var(--line);overflow:hidden}.field{position:absolute;inset:0;background:repeating-linear-gradient(0deg,var(--grass-a) 0px,var(--grass-a) 24px,var(--grass-b) 24px,var(--grass-b) 48px);overflow:hidden}.field-cam{position:absolute;inset:0;transition:transform .5s cubic-bezier(.3,.8,.3,1)}.field-cam:before,.field-cam:after{content:"";position:absolute;top:-100%;bottom:-100%;width:7px;background:repeating-linear-gradient(0deg,transparent 0 22px,var(--chalk) 22px 24px);opacity:.22;pointer-events:none}.field-cam:before{left:33%}.field-cam:after{left:64%}.sheet{position:absolute;left:0;right:0;bottom:0;z-index:5;background:linear-gradient(180deg,#17132a,#0b0913);border-top:1px solid var(--line);border-radius:16px 16px 0 0;box-shadow:0 -14px 34px #0000008c;padding:10px;display:flex;flex-direction:column;animation:sheet-up .3s cubic-bezier(.2,.9,.3,1)}@keyframes sheet-up{0%{transform:translateY(24px);opacity:.3}}.sheet-hand{max-height:52dvh;overflow-y:auto}.sheet-choices{padding-bottom:12px}.sheet-action{height:50dvh;background:linear-gradient(180deg,#1a1430,#0b0913)}.tok.carrier{z-index:4}.tok.carrier .helmet{width:32px;height:30px}.ball.playball{z-index:4}.ball.playball.pass img{animation:pass-arc var(--pd, .9s) ease-out}@keyframes pass-arc{0%{transform:translateY(0) scale(.9)}45%{transform:translateY(-24px) scale(1.15)}to{transform:translateY(0) scale(1)}}.sheet>.hand-area,.sheet>.prompt,.sheet>.reveal{background:transparent;border:none;border-radius:0;padding:0;flex:1;min-height:0}.hand-area{position:relative;display:flex;flex-direction:column;gap:8px}.endzone{position:absolute;left:0;right:0;height:8%;display:flex;align-items:center;justify-content:center;font-weight:900;letter-spacing:3px;font-size:12px;color:#ffffffbf;background:#00000047}.endzone-top{top:0;border-bottom:2px solid var(--chalk)}.endzone-bottom{bottom:0;border-top:2px solid var(--chalk)}.yardline{position:absolute;left:0;right:0;height:1px;background:var(--chalk);opacity:.5}.yardnum{position:absolute;left:6px;top:-8px;font-size:10px;color:var(--chalk);font-weight:700}.first-down{position:absolute;left:0;right:0;height:3px;background:var(--gold);box-shadow:0 0 8px #f2c14ecc;z-index:3}.ball{position:absolute;left:50%;transform:translate(-50%);font-size:22px;z-index:4;filter:drop-shadow(0 2px 3px rgba(0,0,0,.6));transition:bottom .5s cubic-bezier(.3,.8,.3,1)}.ball-you{filter:drop-shadow(0 0 6px var(--you))}.ball-cpu{filter:drop-shadow(0 0 6px var(--cpu))}.field-caption{display:flex;gap:6px;justify-content:center;font-size:13px;color:var(--muted);font-weight:700}.poss-you{color:var(--you)}.poss-cpu{color:var(--cpu)}.flash{text-align:center;font-weight:900;letter-spacing:1px;color:#06120d;background:linear-gradient(90deg,var(--gold),#ffe08a);border-radius:10px;padding:8px;animation:pop .3s ease}@keyframes pop{0%{transform:scale(.92);opacity:0}}.prompt{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px}.prompt-title{text-align:center;color:var(--muted);font-weight:700;font-size:13px;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}.choices{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.choices .btn{flex:1;min-width:90px}.hand-area{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:10px}.side-badge{text-align:center;font-weight:900;letter-spacing:1px;font-size:13px;padding:6px;border-radius:10px;margin-bottom:8px}.side-badge.offense{color:#06120d;background:var(--you)}.side-badge.defense{color:#06120d;background:var(--cpu)}.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.card{appearance:none;border:1px solid var(--line);background:linear-gradient(180deg,var(--panel-2),#101915);color:var(--text);border-radius:12px;padding:12px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;font:inherit;transition:transform .06s ease,border-color .15s ease}.card:active{transform:translateY(1px) scale(.98)}.card:hover{border-color:var(--gold)}.card-glyph{font-size:26px}.card-name{font-weight:800;font-size:14px}.card-count{font-size:12px;color:var(--muted);font-weight:700}.actions-row{display:flex;gap:6px;margin-top:8px}.act{flex:1 1 0;min-width:0;appearance:none;font:inherit;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 3px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer;transition:transform .06s ease,border-color .15s ease}.act:active{transform:translateY(1px) scale(.98)}.act-icon{width:21px;height:21px;display:block}.act-label{font-size:10px;font-weight:800;letter-spacing:.3px;white-space:nowrap}.act-tp{color:#bb8fe6;border-color:#59407f}.act-hm{color:var(--gold);border-color:#6a5a2a}.act-fg,.act-punt{color:#5cc98a;border-color:#2f6a48}.act-timeout{color:var(--muted)}.feed{height:52px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:0 4px;gap:2px}.feed-line{font-size:12px;color:var(--muted);opacity:.5}.feed-line.latest{color:var(--text);opacity:1;font-weight:700}.gameover{text-align:center}.go-title{font-size:26px;font-weight:900;margin-bottom:4px}.go-score{font-family:ui-monospace,monospace;font-size:30px;font-weight:800;color:var(--gold);margin-bottom:14px}.tier-row{display:flex;gap:6px}.tier{flex:1;appearance:none;font:inherit;font-weight:700;font-size:13px;padding:9px 6px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer;position:relative}.tier.active{border-color:var(--gold);color:var(--gold)}.tier:disabled{opacity:.45;cursor:not-allowed}.tier .soon{display:block;font-size:9px;letter-spacing:1px;color:var(--muted);margin-top:2px}.timer-toggle{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:600;justify-content:center}.timer-toggle input{width:16px;height:16px;accent-color:var(--gold)}.saves{width:300px;max-width:90%}.saves-title,.lifetime-title,.overlay-title{color:var(--muted);font-size:12px;font-weight:800;letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;text-align:center}.save-row{display:flex;gap:6px;margin-bottom:6px}.save-main{flex:1;display:flex;justify-content:space-between;align-items:center;appearance:none;font:inherit;text-align:left;cursor:pointer;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;color:var(--text)}.save-score{font-weight:800;font-family:ui-monospace,monospace}.save-meta{font-size:12px;color:var(--muted)}.save-del{appearance:none;width:40px;border:1px solid var(--line);border-radius:10px;background:var(--panel-2);color:var(--muted);cursor:pointer;font-size:14px}.lifetime{width:300px;max-width:90%}.lifetime-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.stat{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 4px}.stat-v{font-weight:800;font-size:18px}.stat-k{font-size:10px;color:var(--muted);letter-spacing:1px}.pause-btn{position:absolute;top:6px;right:8px;appearance:none;border:none;background:transparent;color:var(--muted);font-size:14px;cursor:pointer;padding:4px}.scoreboard{position:relative}.overlay{position:fixed;inset:0;background:#040806d1;display:flex;align-items:center;justify-content:center;padding:16px;z-index:20}.overlay-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;width:340px;max-width:100%;display:flex;flex-direction:column;gap:12px}.statspanel{background:var(--panel-2);border:1px solid var(--line);border-radius:12px;padding:10px 12px;margin:4px 0}.sp-head,.sp-row{display:grid;grid-template-columns:44px 1fr 44px;align-items:center}.sp-head{padding-bottom:6px;margin-bottom:4px;border-bottom:1px solid var(--line)}.sp-you{color:var(--you);font-weight:800;font-size:12px}.sp-cpu{color:var(--cpu);font-weight:800;font-size:12px;text-align:right}.sp-label{text-align:center;color:var(--muted);font-size:11px;letter-spacing:1px}.sp-row{padding:3px 0}.sp-num{font-family:ui-monospace,monospace;font-weight:700;font-size:14px;color:var(--muted)}.sp-row .sp-num:last-child{text-align:right}.sp-num.lead{color:var(--text)}.sp-stat{text-align:center;font-size:12px;color:var(--muted)}.timer{height:4px;border-radius:2px;background:var(--line);margin:0 0 10px;overflow:hidden}.timer-bar{height:100%;transition:width .1s linear}.replay-caption{text-align:center;font-weight:700;font-size:13px;color:var(--gold);min-height:18px;padding:4px}.replay-panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:12px}.scrubber{width:100%;accent-color:var(--gold)}.replay-controls{display:flex;gap:8px;justify-content:center}.rc{appearance:none;width:48px;height:44px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);font-size:16px;cursor:pointer}.rc-play{background:linear-gradient(180deg,#7c4ddb,#5628a8);border-color:#9a6cec;width:64px}@font-face{font-family:Calc;src:url(/fonts/calc.ttf) format("truetype");font-display:swap}.helmet{display:inline-block;width:22px;height:20px;overflow:visible;filter:drop-shadow(0 0 1.1px rgba(255,255,255,.5)) drop-shadow(0 2px 2px rgba(0,0,0,.5))}.helmet.flip{transform:scaleX(-1)}.hm-sm{width:19px;height:18px}.ball{width:30px;height:22px;display:flex;align-items:center;justify-content:center}.ball-img{width:100%;height:100%;object-fit:contain}.ball-you{filter:drop-shadow(0 0 7px var(--you)) drop-shadow(0 2px 2px rgba(0,0,0,.6))}.ball-cpu{filter:drop-shadow(0 0 7px var(--cpu)) drop-shadow(0 2px 2px rgba(0,0,0,.6))}.tok{position:absolute;transform:translate(-50%);z-index:2;transition:bottom .55s cubic-bezier(.3,.8,.3,1);filter:drop-shadow(0 2px 2px rgba(0,0,0,.55))}.tok .helmet{width:28px;height:26px}.tok.def .helmet{opacity:.92}.tok.off.run .helmet{animation:bob .35s ease-in-out infinite}@keyframes bob{50%{transform:translateY(-2px) rotate(-4deg)}}.playcard{appearance:none;font:inherit;color:var(--text);border:1px solid var(--line);border-radius:12px;background:#0d1512;padding:6px 6px 8px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:default;overflow:hidden}.playcard{padding:4px 5px 6px;gap:4px}button.playcard{cursor:pointer;transition:transform .06s ease,border-color .15s ease,box-shadow .15s ease}button.playcard:active{transform:translateY(1px) scale(.98)}button.playcard:hover{border-color:var(--gold)}.playcard.you{box-shadow:inset 0 0 0 1px #4ea8ff40}.playcard.cpu{box-shadow:inset 0 0 0 1px #ff7a4540}.card-art{position:relative;width:100%;aspect-ratio:5 / 6;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.4)}.cards .card-art{aspect-ratio:auto;height:clamp(64px,11vh,96px)}.play-art{width:100%;height:100%;display:block}.card-tag{position:absolute;top:4px;left:5px;font-size:11px;font-weight:900;letter-spacing:.5px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}.card-n{position:absolute;top:3px;right:4px;min-width:16px;height:16px;padding:0 3px;border-radius:8px;background:#0000008c;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}.card-label{font-size:11px;font-weight:800}.playcard.facedown{justify-content:center}.card-back{width:100%;aspect-ratio:5 / 6;border-radius:8px;background:repeating-linear-gradient(45deg,#14261d 0 8px,#102019 8px 16px),linear-gradient(180deg,#16302300,#000);border:1px solid #26402f;display:flex;align-items:center;justify-content:center}.card-back-ball{width:46%;opacity:.9;filter:drop-shadow(0 2px 3px rgba(0,0,0,.5))}.playcard.nodef{width:100%;aspect-ratio:5 / 6;display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:800;font-size:13px}.reveal{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:10px;cursor:pointer;animation:banner-up .28s cubic-bezier(.2,.9,.3,1);user-select:none}@keyframes banner-up{0%{transform:translateY(14px);opacity:.3}}.reveal-duel{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}.duel-side{display:flex;flex-direction:column;align-items:center;gap:4px}.duel-side .playcard{width:96px}.duel-vs{font-weight:900;font-size:15px;color:var(--muted);letter-spacing:1px}.duel-tag{font-size:11px;font-weight:900;letter-spacing:2px}.duel-tag.you{color:var(--you)}.duel-tag.cpu{color:var(--cpu)}.duel-side .playcard{transition:transform .32s ease;transform-style:preserve-3d}.duel-side .playcard.facedown{transform:rotateY(180deg)}.reveal-stage{min-height:92px;display:flex;align-items:center;justify-content:center}.stage-snap,.stage-route{font-weight:900;font-size:22px;letter-spacing:1px;color:var(--gold);animation:pop .25s ease}.quality{font-weight:900;font-size:18px;text-transform:uppercase;letter-spacing:1px;padding:6px 14px;border-radius:999px;animation:pop .25s ease}.q-best{color:#06120d;background:#46d38a}.q-good{color:#06120d;background:#9fe0b0}.q-decent{color:#06120d;background:#d8e0c0}.q-okay{color:#fff;background:#8a6a44}.q-worst{color:#fff;background:#a33}.stage-rng{display:flex;flex-direction:column;align-items:center;gap:8px;animation:pop .25s ease}.rng-label{font-size:12px;font-weight:800;letter-spacing:1px;color:var(--muted);text-transform:uppercase}.stage-result{display:flex;flex-direction:column;align-items:center;gap:3px;animation:pop .3s ease}.res-head{font-weight:900;font-size:26px;letter-spacing:.5px}.res-detail{font-size:13px;font-weight:800;color:var(--muted)}.stage-result.good .res-head{color:#46d38a;text-shadow:0 0 16px rgba(70,211,138,.4)}.stage-result.bad .res-head{color:var(--cpu);text-shadow:0 0 16px rgba(255,122,69,.35)}.stage-result.neutral .res-head{color:var(--text)}.reveal-foot{display:flex;align-items:center;justify-content:space-between}.beat-dots{display:flex;gap:5px}.bd{width:6px;height:6px;border-radius:50%;background:var(--line);transition:background .2s}.bd.on{background:var(--gold)}.skip-hint{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:.5px}.coin{width:68px;height:68px;perspective:300px}.coin-face{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 3px 5px rgba(0,0,0,.5))}.coin.flipping{animation:coinflip .6s ease-out}@keyframes coinflip{0%{transform:rotateX(0) scale(.8)}70%{transform:rotateX(900deg) scale(1.05)}to{transform:rotateX(1080deg) scale(1)}}.die{width:60px;height:60px;border-radius:12px;background:linear-gradient(160deg,#fdfdfd,#d8ddd9);box-shadow:inset 0 -3px 6px #0003,0 3px 6px #00000080;display:flex;align-items:center;justify-content:center;padding:8px;animation:diein .35s cubic-bezier(.2,1.3,.4,1)}@keyframes diein{0%{transform:rotate(-30deg) scale(.5);opacity:0}}.die-num{font-weight:900;font-size:28px;color:#14261d}.pips{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px}.pip{width:9px;height:9px;border-radius:50%;background:#14261d;align-self:center;justify-self:center}.pips-1 .pip:nth-child(1){grid-area:2 / 2}.pips-2 .pip:nth-child(1){grid-area:1 / 1}.pips-2 .pip:nth-child(2){grid-area:3 / 3}.pips-3 .pip:nth-child(1){grid-area:1 / 1}.pips-3 .pip:nth-child(2){grid-area:2 / 2}.pips-3 .pip:nth-child(3){grid-area:3 / 3}.pips-4 .pip:nth-child(1){grid-area:1 / 1}.pips-4 .pip:nth-child(2){grid-area:1 / 3}.pips-4 .pip:nth-child(3){grid-area:3 / 1}.pips-4 .pip:nth-child(4){grid-area:3 / 3}.pips-5 .pip:nth-child(1){grid-area:1 / 1}.pips-5 .pip:nth-child(2){grid-area:1 / 3}.pips-5 .pip:nth-child(3){grid-area:2 / 2}.pips-5 .pip:nth-child(4){grid-area:3 / 1}.pips-5 .pip:nth-child(5){grid-area:3 / 3}.pips-6 .pip:nth-child(1){grid-area:1 / 1}.pips-6 .pip:nth-child(2){grid-area:1 / 3}.pips-6 .pip:nth-child(3){grid-area:2 / 1}.pips-6 .pip:nth-child(4){grid-area:2 / 3}.pips-6 .pip:nth-child(5){grid-area:3 / 1}.pips-6 .pip:nth-child(6){grid-area:3 / 3}.multcard{min-width:52px;height:68px;padding:0 10px;border-radius:9px;background:linear-gradient(180deg,#fff,#e6ebe6);color:#14261d;font-weight:900;font-size:26px;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 6px #00000080;animation:diein .35s cubic-bezier(.2,1.3,.4,1)}.multcard.yard{color:#0f6b43}.celebration{position:fixed;inset:0;z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:radial-gradient(60% 50% at 50% 45%,#0f6b438c,#040806d9);animation:fade .25s ease;pointer-events:none}.cel-img{width:68%;max-width:320px;animation:celpop .5s cubic-bezier(.2,1.4,.4,1)}.cel-word{font-weight:900;font-size:34px;letter-spacing:2px;color:var(--gold);text-shadow:0 0 24px rgba(242,193,78,.6);animation:pop .4s ease .1s both}@keyframes celpop{0%{transform:scale(.4) rotate(-8deg);opacity:0}}@keyframes fade{0%{opacity:0}}.speed-row{display:flex;flex-direction:column;gap:6px;align-items:center}.speed-label{font-size:12px;font-weight:700;color:var(--muted);letter-spacing:1px}.speed-seg{display:flex;width:100%;border:1px solid var(--line);border-radius:10px;overflow:hidden}.seg{flex:1;appearance:none;font:inherit;font-weight:700;font-size:12px;padding:8px 4px;background:var(--panel-2);color:var(--muted);border:none;border-right:1px solid var(--line);cursor:pointer}.seg:last-child{border-right:none}.seg.active{background:#f2c14e29;color:var(--gold)}.pick-hint{align-self:center;max-height:0;opacity:0;overflow:hidden;transform:translateY(8px);border-radius:999px;font-size:12px;font-weight:900;letter-spacing:1px;transition:max-height .3s ease,opacity .3s ease,transform .3s ease,padding .3s ease;pointer-events:none}.pick-hint.show{max-height:32px;opacity:1;transform:translateY(0);padding:6px 16px;margin-top:2px}.pick-hint.offense{color:#06120d;background:var(--you)}.pick-hint.defense{color:#06120d;background:var(--cpu)}.team-picker{width:min(360px,92vw);display:flex;flex-direction:column;gap:10px}.tp-matchup{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}.tp-team{display:flex;flex-direction:column;align-items:center;gap:2px;appearance:none;font:inherit;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 6px;color:var(--text)}.tp-hel{width:42px;height:38px}.tp-city{font-weight:900;font-size:15px;line-height:1.1}.tp-name{font-size:12px;color:var(--muted);font-weight:700}.tp-tag{font-size:9px;letter-spacing:1px;color:var(--muted);font-weight:800;margin-top:3px;text-transform:uppercase}.tp-vs{font-weight:900;color:var(--muted);font-size:13px}.tp-cpu{cursor:pointer;transition:transform .06s ease,border-color .15s}.tp-cpu:active{transform:scale(.98)}.tp-cpu:hover{border-color:var(--muted)}.team-strip{display:flex;gap:8px;overflow-x:auto;padding:2px 2px 8px;scrollbar-width:none}.team-strip::-webkit-scrollbar{display:none}.team-chip{flex:0 0 auto;appearance:none;font:inherit;display:flex;flex-direction:column;align-items:center;gap:3px;width:52px;padding:7px 2px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;color:var(--text);cursor:pointer}.team-chip.active{border-color:var(--tc);box-shadow:0 0 0 1px var(--tc);background:color-mix(in srgb,var(--tc) 12%,var(--panel-2))}.chip-hel{width:30px;height:27px}.chip-abbr{font-size:11px;font-weight:800}.team-you{font-size:8px;font-weight:900;letter-spacing:.5px;color:#0b0913;background:var(--gold);border-radius:4px;padding:1px 3px;line-height:1}.playoffs-cta{display:flex;flex-direction:column;gap:8px;margin-top:4px}.or-sep{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:1px}.fmt-row{display:flex;gap:6px}.fmt{flex:1;appearance:none;font:inherit;font-weight:700;font-size:12px;padding:9px 4px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer}.fmt.active{border-color:var(--gold);color:var(--gold)}.btn-cup{background:linear-gradient(180deg,#caa03a,#9c7a1e);border-color:#e0be5a;color:#1a1305}.btn-season{background:linear-gradient(180deg,var(--accent),#6d3fd6);border-color:#a37bf5;color:#fff}.screen.season{overflow-y:auto;align-items:stretch;gap:12px;padding-bottom:8px}.season-head{text-align:center;padding-top:8px}.season-title{font-weight:900;font-size:18px;letter-spacing:2px;color:var(--accent)}.season-week{margin-top:3px;font-size:12px;font-weight:800;color:var(--muted);letter-spacing:.5px}.season-game{display:flex;flex-direction:column;gap:10px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.season-game.bye{gap:12px}.sg-bye{font-weight:900;font-size:16px;letter-spacing:2px;color:var(--muted)}.sg-teams{display:flex;align-items:center;justify-content:center;gap:16px;width:100%}.sg-team{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1}.sg-team .tp-hel{width:46px;height:42px}.sg-abbr{font-weight:900;font-size:18px}.sg-tag{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.sg-at{font-weight:800;font-size:13px;color:var(--muted)}.season-game .btn{width:100%}.season-quit{margin-top:2px}.season-berth{text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;align-items:center;gap:8px}.season-berth.in{border-color:var(--accent);box-shadow:0 0 24px #8b5cf638}.season-berth.out{border-color:var(--cpu)}.berth-word{font-weight:900;font-size:19px;letter-spacing:.5px}.season-berth.in .berth-word{color:var(--accent)}.season-berth.out .berth-word{color:var(--cpu)}.berth-sub{font-size:12px;color:var(--muted);font-weight:700}.berth-champ{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:800;color:var(--gold)}.season-berth .btn{width:100%;margin-top:4px}.standings{display:flex;flex-direction:column;gap:12px}.stand-conf{display:flex;flex-direction:column;gap:8px}.stand-conf-name{font-size:12px;font-weight:900;color:var(--accent);letter-spacing:2px}.stand-div{display:flex;flex-direction:column;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;overflow:hidden}.stand-div-name{font-size:10px;font-weight:800;letter-spacing:1px;color:var(--muted);padding:5px 10px;background:#ffffff08;text-transform:uppercase}.stand-row{display:flex;align-items:center;gap:8px;padding:5px 10px;border-top:1px solid var(--line);font-size:13px}.stand-row.in{background:#8b5cf614}.stand-row.you{background:#f2c14e1a}.stand-row.you .stand-abbr{color:var(--gold)}.stand-seed{width:16px;display:flex;justify-content:center}.seed-badge{display:inline-flex;align-items:center;justify-content:center;min-width:15px;height:15px;padding:0 3px;border-radius:4px;background:var(--accent);color:#fff;font-size:10px;font-weight:800}.seed-badge.sm{width:13px;height:13px;min-width:0;vertical-align:middle;margin-right:4px}.stand-abbr{font-weight:800;width:42px}.stand-name{flex:1;color:var(--muted);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stand-rec{font-family:ui-monospace,monospace;font-weight:800;font-size:13px}.stand-legend{font-size:10px;color:var(--muted);font-weight:600;text-align:center;padding-top:2px}.friend-cta{display:flex;flex-direction:column;gap:8px;margin-top:4px}.btn-friend{background:linear-gradient(180deg,#1f9e6b,#147a51);border-color:#35c98c;color:#fff}.join-row{display:flex;gap:6px}.join-input{flex:1;appearance:none;font:inherit;font-weight:800;font-size:16px;letter-spacing:3px;text-align:center;text-transform:uppercase;padding:9px 8px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text)}.join-input::placeholder{letter-spacing:2px;color:var(--muted)}.btn-join{flex:0 0 84px}.btn-join:disabled{opacity:.45}.screen.mp-lobby{align-items:center;justify-content:center;gap:20px;text-align:center}.mp-lobby-head{display:flex;flex-direction:column;align-items:center;gap:6px}.logo.sm{font-size:30px}.mp-tag{font-size:12px;font-weight:900;letter-spacing:3px;color:#35c98c}.mp-status{display:flex;flex-direction:column;gap:6px;color:var(--muted);font-weight:700}.mp-status.err .mp-status-word{color:var(--cpu);font-size:18px;font-weight:900}.mp-status-sub{font-size:13px;color:var(--muted)}.mp-share{display:flex;flex-direction:column;align-items:center;gap:8px}.mp-share-label{font-size:13px;color:var(--muted);font-weight:700}.mp-code{appearance:none;font:inherit;cursor:pointer;font-size:46px;font-weight:900;letter-spacing:10px;padding:14px 10px 14px 20px;border-radius:14px;border:2px dashed var(--accent);background:var(--panel);color:#fff;box-shadow:0 0 24px #8b5cf633}.mp-share-hint{font-size:11px;color:var(--muted);font-weight:600}.mp-waiting{display:flex;align-items:center;gap:6px;margin-top:8px}.mp-waiting-text{font-size:13px;color:var(--muted);font-weight:700;margin-left:4px}.mp-dot{width:7px;height:7px;border-radius:50%;background:var(--accent);animation:mp-bounce 1s infinite}.mp-dot:nth-child(2){animation-delay:.15s}.mp-dot:nth-child(3){animation-delay:.3s}@keyframes mp-bounce{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.waiting-opp{color:var(--muted)}.chat-dock{position:fixed;right:10px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:45}.chat-fab{position:relative;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--panel-2);font-size:20px;cursor:pointer;box-shadow:0 4px 14px #0006}.chat-badge{position:absolute;top:-3px;right:-3px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:var(--cpu);color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center}.chat-panel{width:min(86vw,320px);height:340px;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 8px 30px #00000080}.chat-head{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--line);font-weight:800;font-size:13px}.chat-x{appearance:none;background:none;border:none;color:var(--muted);font-size:15px;cursor:pointer}.chat-body{flex:1;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:6px}.chat-empty{color:var(--muted);font-size:12px;text-align:center;margin:auto}.chat-msg{max-width:78%;padding:6px 10px;border-radius:12px;font-size:14px;font-weight:600;word-break:break-word}.chat-msg.me{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:3px}.chat-msg.them{align-self:flex-start;background:var(--panel-2);border:1px solid var(--line);border-bottom-left-radius:3px}.chat-taunts{display:flex;flex-wrap:wrap;gap:4px;padding:6px 8px;border-top:1px solid var(--line)}.taunt{appearance:none;font:inherit;font-size:12px;font-weight:700;padding:4px 8px;border-radius:12px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);cursor:pointer}.chat-input-row{display:flex;gap:6px;padding:8px;border-top:1px solid var(--line)}.chat-input{flex:1;appearance:none;font:inherit;font-size:14px;padding:8px 10px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);color:var(--text)}.chat-send{flex:0 0 40px;appearance:none;border:none;border-radius:10px;background:var(--accent);color:#fff;font-size:15px;cursor:pointer}.screen.tourney{overflow-y:auto;align-items:stretch;gap:12px;padding-bottom:8px}.tourney-head{text-align:center;padding-top:8px}.tourney-title{font-weight:900;font-size:18px;letter-spacing:2px;color:var(--gold)}.tourney-result{margin-top:6px;font-weight:800;font-size:13px;padding:6px 10px;border-radius:8px}.tourney-result.adv{color:#46d38a;background:#46d38a1f}.champ-card,.elim-card{text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;align-items:center;gap:6px}.champ-card{border-color:var(--gold);box-shadow:0 0 24px #f2c14e33}.champ-word{font-weight:900;font-size:22px;letter-spacing:1px;color:var(--gold)}.champ-hel{width:64px;height:58px}.champ-name{font-weight:900;font-size:20px}.champ-sub,.elim-champ{font-size:12px;color:var(--muted);font-weight:700}.elim-word{font-weight:900;font-size:17px;color:var(--cpu)}.elim-champ{display:flex;align-items:center;gap:6px}.bracket{display:flex;flex-direction:column;gap:12px}.brk-round{display:flex;flex-direction:column;gap:6px}.brk-round-name{font-size:11px;font-weight:900;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--line);padding-bottom:3px}.brk-confs{display:flex;flex-direction:column;gap:8px}.brk-conf-name{font-size:10px;font-weight:800;color:var(--accent);letter-spacing:1px;margin:2px 0}.brk-matchups,.brk-conf{display:flex;flex-direction:column;gap:6px}.brk-match{display:flex;flex-direction:column;gap:2px;background:var(--panel-2);border:1px solid var(--line);border-radius:10px;padding:5px 8px}.brk-match.live{border-color:var(--gold);box-shadow:0 0 0 1px #f2c14e66}.brk-team{display:flex;align-items:center;gap:8px;padding:3px 2px;opacity:.72}.brk-team.won{opacity:1}.brk-team.you .brk-abbr{color:var(--gold)}.brk-seed{font-size:10px;font-weight:800;color:var(--muted);width:14px;text-align:center}.brk-hel{width:22px;height:20px}.brk-abbr{font-weight:800;font-size:13px;flex:1}.brk-score{font-family:ui-monospace,monospace;font-weight:800;font-size:14px}.brk-team.won .brk-score{color:#46d38a}.brk-bye{font-size:11px;color:var(--muted);font-weight:700;letter-spacing:1px}.tourney-actions{position:sticky;bottom:0;display:flex;flex-direction:column;gap:8px;padding:10px 0 calc(6px + env(safe-area-inset-bottom));background:linear-gradient(180deg,transparent,var(--bg) 35%)}.confetti{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:40}.confetti-piece{position:absolute;top:-24px;border-radius:2px;opacity:0;animation-name:confetti-a;animation-timing-function:linear;animation-iteration-count:infinite}.confetti-piece.sway-b{animation-name:confetti-b}@keyframes confetti-a{0%{transform:translateY(-24px) rotate(0);opacity:0}8%{opacity:1}to{transform:translate(26px,104vh) rotate(680deg);opacity:.85}}@keyframes confetti-b{0%{transform:translateY(-24px) rotate(0);opacity:0}8%{opacity:1}to{transform:translate(-30px,104vh) rotate(-720deg);opacity:.85}}.sheet-action .reveal{height:100%;justify-content:space-between;gap:8px}.sheet-action .reveal-stage{flex:1;min-height:0}.sheet-action .duel-side .playcard{width:min(96px,26vw)}
