:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#f7fbff;background:#005fe9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(135deg,rgba(255,255,255,.08) 0 12%,transparent 12% 34%,rgba(255,255,255,.06) 34% 46%,transparent 46%),radial-gradient(circle at 18% 20%,rgba(59,207,255,.48),transparent 30%),radial-gradient(circle at 92% 18%,rgba(64,127,255,.62),transparent 36%),linear-gradient(145deg,#0495ff,#005df0 46%,#003ec9)}button,input{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:0 clamp(14px,2vw,30px) 30px}.topbar{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:auto 1fr;align-items:center;gap:18px;min-height:82px;margin:0 calc(clamp(14px,2vw,30px)*-1) 30px;padding:0 clamp(18px,3.4vw,46px);background:linear-gradient(180deg,#071a4a,#041234);border-bottom:1px solid rgba(96,171,255,.55);box-shadow:0 10px 26px #00145257}.brand-button,.ghost-button,.primary-button,.play-button,.bell-button,.icon-button,.reaction-chip{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:42px;border:0;border-radius:8px;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}.brand-button{background:transparent;color:#fff;padding:0;font-size:clamp(1.2rem,2.2vw,1.8rem);font-weight:950;text-shadow:0 3px 0 rgba(0,0,0,.34)}.brand-button>span:last-child span{color:#ffd422}.brand-mark{display:grid;place-items:center;width:42px;height:42px;border-radius:16px;color:#fff;background:linear-gradient(145deg,#1884ff,#004bd2);border:2px solid rgba(148,212,255,.72);box-shadow:inset 0 -5px #0000003d}.topbar-actions{display:flex;align-items:center;justify-content:flex-end;gap:12px}.avatar-pill,.reaction-label{display:inline-flex;align-items:center;gap:9px;min-height:42px;padding:0 14px;border-radius:8px;color:#fff;background:#061849b8;border:1px solid rgba(112,169,255,.42);font-weight:900;box-shadow:inset 0 0 16px #166fff38}.avatar-pill svg{color:#54e4ff}.bell-button,.icon-button{width:42px;color:#fff;background:transparent}.ghost-button{background:#ffffff1f;color:#fff;padding:0 14px;font-weight:850;box-shadow:inset 0 0 0 1px #ffffff24}.primary-button{background:linear-gradient(180deg,#34db5b,#159e31);color:#fff;padding:0 16px;font-weight:950;box-shadow:0 12px 22px #002a6340,inset 0 -4px #00000038}.primary-button:disabled,.icon-button:disabled{opacity:.6;cursor:wait}.brand-button:hover,.ghost-button:hover,.primary-button:hover,.play-button:hover,.bell-button:hover,.icon-button:hover,.reaction-chip:hover{transform:translateY(-1px)}.home-grid,.game-screen{max-width:1480px;margin:0 auto}.home-grid{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1fr);gap:24px}.game-card{position:relative;min-height:560px;overflow:hidden;border-radius:24px;border:3px solid rgba(121,216,255,.82);box-shadow:0 24px 42px #001e7057,inset 0 0 30px #ffffff29}.card-copy{position:relative;z-index:2;min-height:inherit;padding:clamp(24px,3vw,46px)}.flappy-card{background:linear-gradient(180deg,rgba(255,255,255,.24) 0 1px,transparent 1px 8px),linear-gradient(180deg,#18c9ff,#82ecff 59%,#7de04b 59%,#37b83e)}.flappy-copy{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center}.flappy-copy h1{display:grid;margin:36px 0 0;color:#fff;font-size:clamp(4rem,8vw,6.8rem);line-height:.82;text-transform:uppercase;letter-spacing:0;text-shadow:4px 0 0 #ffffff,-4px 0 0 #ffffff,0 -4px 0 #ffffff,0 7px 0 #083b9b,0 12px 0 #061c53,0 18px 18px rgba(0,0,0,.38)}.flappy-copy h1 span:last-child{color:#ffd51e}.four-card{background:radial-gradient(circle at 48% 10%,rgba(55,156,255,.34) 0 2px,transparent 3px 16px),linear-gradient(180deg,#0749cf,#031e74 69%,#8c461c 69%,#bd6828);border-color:#5f96ffc7}.four-card:after{content:"";position:absolute;left:0;right:0;bottom:0;height:31%;background:linear-gradient(90deg,rgba(255,255,255,.12) 0 1px,transparent 1px 74px),linear-gradient(180deg,rgba(255,208,116,.22),transparent 34%),repeating-linear-gradient(0deg,rgba(80,32,8,.26) 0 3px,transparent 3px 18px);pointer-events:none}.four-copy{position:relative;z-index:3;min-height:inherit}.four-title{position:absolute;left:clamp(26px,4vw,58px);top:58px;text-transform:uppercase;font-weight:950;line-height:.85;text-shadow:0 8px 0 rgba(0,0,0,.35),0 18px 20px rgba(0,0,0,.3)}.four-title span{display:block;color:#fff;font-size:clamp(4.1rem,7vw,6.1rem)}.four-title strong{display:block;margin-left:86px;color:#ffd422;font-size:clamp(1.9rem,3.5vw,3rem)}.play-button{min-height:72px;padding:0 38px;border:3px solid rgba(255,255,255,.72);border-bottom-color:#042c125c;color:#fff;font-size:clamp(1rem,2vw,1.35rem);font-weight:950;text-transform:uppercase;text-shadow:0 2px 0 rgba(0,0,0,.28);box-shadow:inset 0 -8px #00000047,inset 0 3px #ffffff57,0 16px 26px #00165947}.flappy-play{margin-top:auto;width:min(100%,430px);background:linear-gradient(180deg,#83f45b,#45d83d 52%,#23a92d);border-color:#bcffa0;border-bottom-color:#137c1f}.four-play{position:absolute;left:50%;bottom:28px;transform:translate(-50%);width:min(58%,480px);height:76px;color:#07133f;background:linear-gradient(180deg,#fff979,#ffd338 54%,#f3a916);border-color:#fff7a7;border-bottom-color:#a56506;text-shadow:none;z-index:4}.four-play:hover{transform:translate(-50%) translateY(-1px)}.tictac-card{grid-column:1 / -1;min-height:430px;background:radial-gradient(circle at 16% 18%,rgba(255,207,51,.46),transparent 18%),radial-gradient(circle at 84% 14%,rgba(104,232,255,.36),transparent 22%),linear-gradient(145deg,#063fb4,#07134d 60%,#1260e4);border-color:#79d8ffc2}.tictac-copy{display:grid;align-content:center;justify-items:start;min-height:inherit}.tictac-copy h1{display:grid;margin:0;color:#fff;font-size:clamp(3.5rem,8vw,7rem);line-height:.86;text-transform:uppercase;text-shadow:0 8px 0 rgba(0,0,0,.35),0 18px 20px rgba(0,0,0,.28)}.tictac-copy h1 span:last-child{color:#ffcf33;font-size:.62em}.tictac-play{margin-top:34px;width:min(100%,440px);color:#07133f;background:linear-gradient(180deg,#fff979,#ffd338 54%,#f3a916);border-color:#fff7a7;border-bottom-color:#a56506;text-shadow:none}.tictac-card-art{position:absolute;inset:0;overflow:hidden}.tictac-card-art:before{content:"";position:absolute;right:clamp(36px,8vw,130px);top:42px;width:min(48vw,470px);aspect-ratio:1;border-radius:24px;background:linear-gradient(90deg,transparent 30%,#78e9ff 30% 35%,transparent 35% 65%,#78e9ff 65% 70%,transparent 70%),linear-gradient(0deg,transparent 30%,#78e9ff 30% 35%,transparent 35% 65%,#78e9ff 65% 70%,transparent 70%),#051754a8;border:4px solid rgba(111,190,255,.8);box-shadow:0 26px 34px #00000047,inset 0 0 28px #4b98ff42}.tictac-card-art span{position:absolute;z-index:2;color:#fff;font-size:clamp(3.8rem,8vw,7rem);font-weight:950;line-height:1;text-shadow:0 8px 0 rgba(0,0,0,.3)}.tictac-card-art span:before{content:"X"}.tictac-card-art span:nth-child(1){right:clamp(330px,34vw,470px);top:82px;color:#ffcf33}.tictac-card-art span:nth-child(2){right:clamp(190px,22vw,314px);top:82px;color:#fb4d3d}.tictac-card-art span:nth-child(2):before,.tictac-card-art span:nth-child(4):before{content:"O"}.tictac-card-art span:nth-child(3){right:clamp(50px,10vw,160px);top:204px;color:#ffcf33}.tictac-card-art span:nth-child(4){right:clamp(330px,34vw,470px);top:324px;color:#fb4d3d}.tictac-card-art span:nth-child(5){right:clamp(190px,22vw,314px);top:324px;color:#ffcf33}.flappy-preview{position:absolute;inset:0}.preview-cloud{position:absolute;width:138px;height:42px;border-radius:999px;background:#ffffffd1;box-shadow:-34px 12px #ffffffad,42px 10px #ffffffbd}.cloud-a{top:178px;left:30px}.cloud-b{right:84px;top:276px;transform:scale(.72)}.cloud-c{left:55%;top:366px;transform:scale(.5)}.pixel-city{position:absolute;left:0;right:0;bottom:96px;height:92px;opacity:.32;background:linear-gradient(90deg,transparent 0 6%,#0a8ab8 6% 12%,transparent 12% 18%,#0a8ab8 18% 25%,transparent 25% 31%,#0a8ab8 31% 38%,transparent 38% 47%,#0a8ab8 47% 54%,transparent 54% 62%,#0a8ab8 62% 70%,transparent 70% 78%,#0a8ab8 78% 85%,transparent 85%)}.grass-strip{position:absolute;left:0;right:0;bottom:0;height:66px;background:linear-gradient(180deg,#a2f145 0 18px,#2ab33e 18px 28px,#d79729 28px);box-shadow:inset 0 8px #ffffff42}.preview-bird{position:absolute;left:22%;top:47%;width:104px;height:72px;border:5px solid #0b2a59;border-radius:48% 42% 44% 50%;background:#ffe238;box-shadow:inset -20px -13px #ff8a28,0 14px #00538e38}.preview-bird:before{content:"";position:absolute;right:10px;top:6px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:inset 8px 0 #0b2a59}.preview-bird:after{content:"";position:absolute;right:-32px;top:34px;width:42px;height:18px;border:4px solid #0b2a59;background:#f05d2f}.bird-trail{position:absolute;left:15%;top:55%;width:92px;height:5px;border-radius:999px;background:#ffffff9e;transform:rotate(-30deg);box-shadow:-18px 16px #ffffff7a,-36px 32px #ffffff57}.trail-b{left:12%;top:58%;width:78px;opacity:.72;transform:rotate(-27deg)}.preview-pipe{position:absolute;right:-18px;width:128px;background:linear-gradient(90deg,#148f28,#b6ff55 24%,#42c92f 55%,#096a25);border:5px solid #08651f;box-shadow:inset 16px 0 #ffffff38}.pipe-a{top:-10px;height:146px}.pipe-b{bottom:-8px;height:262px}.preview-pipe:after{content:"";position:absolute;left:-16px;right:-16px;height:54px;background:inherit;border:inherit}.pipe-a:after{bottom:-48px}.pipe-b:after{top:-48px}.board-preview{position:absolute;z-index:2;right:clamp(12px,2vw,28px);top:72px;display:grid;grid-template-columns:repeat(7,clamp(30px,2.6vw,44px));gap:clamp(7px,.7vw,10px);padding:clamp(16px,2vw,24px) clamp(16px,2vw,24px) clamp(26px,2.5vw,36px);border-radius:22px 22px 8px 8px;background:linear-gradient(145deg,#197fff,#0646c7);border:4px solid #4da1ff;box-shadow:0 26px 30px #00000052,inset 0 -10px #0017635c}.board-preview:before,.board-preview:after{content:"";position:absolute;bottom:-56px;width:32px;height:62px;border-radius:0 0 10px 10px;background:linear-gradient(180deg,#0b59d7,#043ba7);border:3px solid #287fff;border-top:0}.board-preview:before{left:22px;transform:skew(-10deg)}.board-preview:after{right:22px;transform:skew(10deg)}.board-preview span{width:clamp(30px,2.6vw,44px);height:clamp(30px,2.6vw,44px);border-radius:999px;background:#061d64;box-shadow:inset 0 7px 12px #000000ad,0 2px #fff3}.board-preview .red-token{background:radial-gradient(circle at 35% 28%,#ff8a66,#ff3d25 58%,#b91f1d);box-shadow:inset 0 -5px #7000004d}.board-preview .yellow-token{background:radial-gradient(circle at 35% 28%,#fff280,#ffc51f 58%,#d68100);box-shadow:inset 0 -5px #703a0042}.mini-invite{position:absolute;left:clamp(20px,3vw,46px);bottom:126px;width:min(100%,300px);padding:18px;border-radius:18px;color:#fff;background:#02123ac7;box-shadow:0 18px 24px #0000003d}.table-tokens{position:absolute;z-index:3;right:clamp(56px,5vw,96px);bottom:96px;display:flex;align-items:end;gap:60px;pointer-events:none}.stack{position:relative;display:block;width:74px;height:26px;border-radius:50%;border:4px solid rgba(81,20,8,.32);box-shadow:0 -17px 0 -3px currentColor,0 -34px 0 -3px currentColor,0 8px 14px #1d0a0257}.red-stack{color:#ff432d;background:#ff432d}.yellow-stack{color:#ffcf28;background:#ffcf28}.mini-invite strong{display:block;margin-bottom:12px}.mini-invite div{display:flex;align-items:center;gap:10px;min-height:42px;padding:0 8px;border:1px solid rgba(123,180,255,.45);border-radius:12px;font-size:.78rem;font-weight:850}.mini-invite span{margin-left:auto;padding:8px 10px;border-radius:8px;color:#06123f;background:#ffdb2e;text-transform:uppercase}.coming-games{grid-column:1 / -1;display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;padding:18px;border-radius:22px;background:#030f3494;border:2px solid rgba(96,184,255,.48);box-shadow:inset 0 0 24px #2189ff29}.coming-card{position:relative;min-height:188px;overflow:hidden;border-radius:18px;padding:14px;color:#fff;background:linear-gradient(145deg,#1674f4c7,#041854eb);border:2px solid rgba(121,216,255,.54);box-shadow:0 14px 26px #00145538,inset 0 0 24px #ffffff14}.coming-card strong,.coming-card small{position:relative;z-index:2;display:block}.coming-card strong{margin-top:112px;font-size:1.05rem;font-weight:950}.coming-card small{color:#ffffffbd;font-weight:750}.coming-art{position:absolute;inset:0}.coming-art span{position:absolute;display:block}.checkers-art .coming-art{background:linear-gradient(45deg,rgba(4,18,62,.86) 25%,transparent 25% 75%,rgba(4,18,62,.86) 75%),linear-gradient(45deg,rgba(4,18,62,.86) 25%,transparent 25% 75%,rgba(4,18,62,.86) 75%),#efcf75;background-position:0 0,24px 24px;background-size:48px 48px}.checkers-art .coming-art span{width:48px;height:18px;border-radius:50%;background:#ff432d;box-shadow:0 -10px #ff6b4d,0 8px 14px #0000003d}.checkers-art .coming-art span:nth-child(1){left:18px;top:30px}.checkers-art .coming-art span:nth-child(2){right:22px;top:60px;background:#ffcf28;box-shadow:0 -10px #ffe470,0 8px 14px #0000003d}.checkers-art .coming-art span:nth-child(3){left:58px;top:92px}.checkers-art .coming-art span:nth-child(4){right:52px;top:118px;background:#ffcf28;box-shadow:0 -10px #ffe470,0 8px 14px #0000003d}.snake-art .coming-art{background:linear-gradient(180deg,#1ed6ad,#0a9e60)}.snake-art .coming-art span{width:38px;height:38px;border-radius:10px;background:#b9ff45;box-shadow:inset 0 -6px #0000002e}.snake-art .coming-art span:nth-child(1){left:28px;top:46px}.snake-art .coming-art span:nth-child(2){left:66px;top:46px}.snake-art .coming-art span:nth-child(3){left:104px;top:46px}.snake-art .coming-art span:nth-child(4){left:104px;top:84px;background:#ffcf28;border-radius:50%}.memory-art .coming-art{background:linear-gradient(145deg,#7bd8ff,#2162e8)}.memory-art .coming-art span{width:52px;height:70px;border-radius:10px;background:#fff;box-shadow:inset 0 -8px #0829742e,0 12px 16px #0003}.memory-art .coming-art span:nth-child(1){left:24px;top:28px;transform:rotate(-8deg)}.memory-art .coming-art span:nth-child(2){left:88px;top:28px;transform:rotate(7deg)}.memory-art .coming-art span:nth-child(3){left:38px;top:86px;background:#ffcf28}.memory-art .coming-art span:nth-child(4){left:104px;top:86px;background:#fb4d3d}.tictac-art .coming-art{background:linear-gradient(145deg,#063cae,#06164e)}.tictac-art .coming-art:before{content:"";position:absolute;inset:28px 44px 60px;background:linear-gradient(90deg,transparent 30%,#6de8ff 30% 36%,transparent 36% 64%,#6de8ff 64% 70%,transparent 70%),linear-gradient(0deg,transparent 30%,#6de8ff 30% 36%,transparent 36% 64%,#6de8ff 64% 70%,transparent 70%);opacity:.9}.tictac-art .coming-art span{width:30px;height:30px;color:#ffcf28;font-size:2.2rem;font-weight:950}.tictac-art .coming-art span:before{content:"X"}.tictac-art .coming-art span:nth-child(1){left:54px;top:32px}.tictac-art .coming-art span:nth-child(2){right:54px;top:82px;color:#fb4d3d}.tictac-art .coming-art span:nth-child(2):before{content:"O"}.tictac-art .coming-art span:nth-child(3){left:104px;top:82px}.tictac-art .coming-art span:nth-child(4){display:none}.golf-art .coming-art{background:linear-gradient(180deg,#7cecff 0 46%,#50cb4a 46%)}.golf-art .coming-art span:nth-child(1){left:38px;bottom:58px;width:34px;height:34px;border-radius:50%;background:#fff;box-shadow:inset -5px -5px #0000001f}.golf-art .coming-art span:nth-child(2){right:34px;bottom:54px;width:54px;height:18px;border-radius:50%;background:#063d24}.golf-art .coming-art span:nth-child(3){right:58px;bottom:72px;width:5px;height:72px;background:#fff}.golf-art .coming-art span:nth-child(4){right:28px;bottom:126px;width:44px;height:28px;background:#fb4d3d;clip-path:polygon(0 0,100% 18%,0 100%)}.active-strip{grid-column:1 / -1;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;padding:18px;border-radius:22px;background:#030f34d6;border:2px solid rgba(52,140,255,.72);box-shadow:0 18px 30px #00145547}.recent-title{grid-column:1 / -1;display:flex;align-items:center;gap:10px;color:#ffffffd1;font-weight:950;text-transform:uppercase}.recent-title button{margin-left:auto;border:0;color:#55c8ff;background:transparent;font-weight:800}.active-strip article{display:grid;grid-template-columns:auto 1fr auto;gap:6px 12px;align-items:center;min-height:98px;padding:14px;border-radius:16px;background:linear-gradient(135deg,#1c76d86b,#071c4fc7)}.active-strip article svg{grid-row:1 / 3;width:58px;height:58px;padding:12px;border-radius:50%;color:#ffe141;background:#49dff8}.active-strip strong{font-size:1.04rem}.active-strip span,.active-strip small{color:#ffffffc7}.active-strip b{color:#bbff46;font-size:1.35rem}.empty-recents{grid-column:1 / -1;display:grid;place-items:center;min-height:92px;border-radius:16px;color:#ffffffc2;background:#1c76d83d;font-weight:850}.lobby-footer{grid-column:1 / -1;display:flex;justify-content:flex-end;align-items:center}.lobby-footer div{display:inline-flex;align-items:center;gap:12px;min-height:50px;padding:0 18px;border-radius:16px;background:#0036b08f;border:1px solid rgba(96,172,255,.44);box-shadow:inset 0 0 16px #5ab3ff2e;font-weight:850}.lobby-footer button{display:grid;place-items:center;width:38px;height:38px;border:0;color:#b7d6ff;background:#02124038}.game-header{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.eyebrow{margin:0 0 8px;color:#ffe35c;font-size:.84rem;font-weight:950;text-transform:uppercase}h1,h2,p{margin-top:0}.game-header h1{margin-bottom:0;color:#fff;font-size:clamp(2rem,4vw,4.1rem);line-height:.96;letter-spacing:0;text-shadow:0 6px 0 rgba(0,0,0,.24)}.room-status-top{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:12px;align-items:center;margin:0 0 18px;padding:14px 16px;border-radius:16px;color:#fff;background:#020f36c2;border:1px solid rgba(104,173,255,.32);box-shadow:0 14px 32px #00135638}.room-status-top.needs-choice{border-color:#ffcf33b8;box-shadow:0 14px 32px #00135638,inset 0 0 0 1px #ffcf332e}.room-status-top strong,.room-status-top span{display:block}.room-status-top strong{margin-bottom:2px}.room-status-top span{color:#ffffffc2;font-weight:700}.top-choice{min-width:min(100%,430px);padding:0;background:transparent;border:0;box-shadow:none}.score-row{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap}.score-row span{display:inline-flex;align-items:center;gap:7px;min-height:42px;padding:0 13px;border-radius:8px;background:#04133eb3;color:#fff;font-weight:850}.flappy-stage{position:relative;display:grid;place-items:center;padding:clamp(14px,3vw,26px);border-radius:18px;background:#020e3480;box-shadow:0 18px 44px #00155e42}.flappy-stage canvas{width:min(100%,420px);aspect-ratio:3 / 4;height:auto;border-radius:14px;box-shadow:0 20px 38px #00125466;touch-action:manipulation}.game-overlay{position:absolute;inset:auto 0 32px;display:flex;justify-content:center;pointer-events:none}.game-overlay.centered{inset:0;align-items:center}.game-overlay span,.game-overlay button{pointer-events:auto}.game-overlay span{padding:10px 14px;border-radius:8px;color:#07133f;background:#ffffffe6;font-weight:850}.four-layout{display:grid;grid-template-columns:minmax(320px,680px) minmax(280px,1fr);gap:18px;align-items:start}.tictac-layout{display:grid;grid-template-columns:minmax(320px,620px) minmax(280px,1fr);gap:18px;align-items:start}.tictac-board{display:grid;grid-template-columns:repeat(var(--tictac-size, 3),minmax(0,1fr));gap:clamp(10px,2vw,16px);padding:clamp(16px,3vw,28px);border-radius:22px;background:radial-gradient(circle at 24% 18%,rgba(255,207,51,.3),transparent 25%),linear-gradient(145deg,#176cf6,#061e78);border:3px solid #61b6ff;box-shadow:0 20px 40px #00175f57,inset 0 -10px #00000029}.tictac-cell{aspect-ratio:1;border:0;border-radius:clamp(10px,2vw,18px);color:#fff;background:#03144ad1;box-shadow:inset 0 7px 16px #0000006b,0 4px #ffffff24}.tictac-cell span{display:grid;place-items:center;width:100%;height:100%;font-size:clamp(2rem,calc(20vw / var(--tictac-size, 3)),6.6rem);font-weight:950;line-height:1;text-shadow:0 7px 0 rgba(0,0,0,.28);animation:token-drop .28s cubic-bezier(.18,.9,.22,1.12)}.tictac-cell span.x{color:#ffcf33}.tictac-cell span.o{color:#fb4d3d}.tictac-cell.winner{outline:5px solid rgba(255,255,255,.72);background:#ffffff2e}.tictac-panel{display:grid;gap:12px}.four-board{position:relative;display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:clamp(7px,1.4vw,12px);padding:clamp(14px,2.8vw,24px);border-radius:18px;background:linear-gradient(145deg,#1685ff,#0539b3);border:3px solid #61b6ff;box-shadow:0 20px 40px #00175f57,inset 0 -10px #00000029}.slot{aspect-ratio:1;padding:7px;border:0;border-radius:999px;background:#061d64;box-shadow:inset 0 6px 12px #00000075;cursor:pointer;overflow:visible}.slot:focus-visible{outline:4px solid #ffcf33;outline-offset:2px}.slot span{display:block;width:100%;height:100%;border-radius:inherit;background:#dfeeff;box-shadow:inset 0 7px 12px #1c39562e}.slot.red span{background:radial-gradient(circle at 34% 28%,#ff9389,#fb4d3d 58%,#ca2b25)}.slot.yellow span{background:radial-gradient(circle at 34% 28%,#fff09a,#ffcf33 58%,#d99d11)}.slot.last{outline:4px solid rgba(255,255,255,.72)}.slot.dropping span{animation:token-drop .42s cubic-bezier(.18,.9,.22,1.12);transform-origin:center}@keyframes token-drop{0%{transform:translateY(calc(var(--drop-row, 6) * -118%)) scale(.96)}78%{transform:translateY(4%) scale(1.02)}to{transform:translateY(0) scale(1)}}@media(prefers-reduced-motion:reduce){.slot.dropping span{animation:none}}.room-panel{display:grid;gap:12px}.turn-card,.player-switch,.invite-box,.room-message,.chat-card{border-radius:16px;color:#fff;background:#020f36c2;border:1px solid rgba(104,173,255,.32);box-shadow:0 14px 32px #00135638}.turn-card{display:flex;gap:12px;padding:18px}.turn-card strong,.turn-card span{display:block}.turn-card strong{margin-bottom:4px}.turn-card span{color:#ffffffb8;font-weight:650;line-height:1.45}.player-switch{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:12px;font-weight:850}.player-switch.top-choice{padding:0;background:transparent;border:0;box-shadow:none}.bot-panel{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;padding:12px;border-radius:16px;color:#fff;background:#020f36c2;border:1px solid rgba(104,173,255,.32);box-shadow:0 14px 32px #00135638;font-weight:850}.difficulty-row{grid-column:1 / -1;display:flex;gap:8px}.difficulty{min-height:34px;border:0;border-radius:8px;padding:0 12px;color:#fff;background:#ffffff24;font-weight:850}.difficulty.active,.token-choice.active{color:#07133f;background:#ffcf33}.token-choice{min-height:36px;border:0;border-radius:8px;padding:0 12px;background:#ffffff24;color:#fff;font-weight:850}.token-choice:disabled{opacity:.52;cursor:not-allowed}.token-choice.active.red{background:#fb4d3d}.token-choice.active.yellow{background:#ffcf33;color:#322300}.invite-box{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:10px;align-items:center;width:100%;padding:14px;border:1px solid rgba(104,173,255,.32);text-align:left}.invite-box span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-box strong{padding:7px 10px;border-radius:8px;color:#07133f;background:#ffcf33;white-space:nowrap}.invite-box.copied strong{color:#052b13;background:#72f06d}.chat-card{display:grid;gap:12px;padding:14px}.chat-title{display:flex;align-items:center;gap:9px}.name-field{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;color:#ffffffb8;font-weight:850}.name-field input,.chat-form input{min-width:0;min-height:40px;border:1px solid rgba(112,183,255,.38);border-radius:8px;padding:0 12px;color:#fff;background:#00092661;outline:0}.chat-log{display:grid;gap:8px;min-height:132px;max-height:190px;overflow:auto;padding:10px;border-radius:12px;background:#00072047}.chat-log p{margin:auto;color:#ffffff94;font-weight:800}.chat-message{display:grid;gap:2px;padding:9px 10px;border-radius:10px;background:#2875ff3d}.chat-message strong{color:#ffe35c;font-size:.82rem}.chat-message span{overflow-wrap:anywhere}.chat-form{display:grid;grid-template-columns:1fr auto;gap:8px}.icon-button{background:#ffcf33;color:#07133f}.reaction-line{display:flex;align-items:center;gap:8px;min-width:0;overflow-x:auto}.reaction-label{min-height:34px;padding:0 10px;font-size:.84rem;white-space:nowrap}.reaction-chip{min-width:30px;min-height:30px;padding:0 3px;color:#fff;background:transparent;border:0;font-size:1.35rem;font-weight:950;box-shadow:none;text-shadow:0 3px 8px rgba(0,0,0,.34)}.gg-chip{color:#ffdf32;font-size:1rem;letter-spacing:0}.room-message{margin:0;padding:15px;color:#ffffffc7;font-weight:700;line-height:1.45}.emoji-burst{position:fixed;inset:0;z-index:50;overflow:hidden;pointer-events:none}.emoji-burst span{position:absolute;display:inline-grid;place-items:center;color:inherit;background:transparent;font-weight:950;text-shadow:0 4px 12px rgba(0,0,0,.28);animation:emoji-pop 1.2s ease-out forwards}@keyframes emoji-pop{0%{transform:translateZ(0) scale(.4) rotate(0);opacity:0}15%{opacity:1}to{transform:translate3d(var(--drift),-72vh,0) scale(1.2) rotate(28deg);opacity:0}}@media(max-width:1120px){.topbar{grid-template-columns:1fr;padding-block:14px}.topbar-actions{justify-content:flex-start;overflow-x:auto}.home-grid,.four-layout,.tictac-layout{grid-template-columns:1fr}.game-card{min-height:500px}.tictac-card{min-height:430px}.four-copy{min-height:inherit}.board-preview{right:28px;top:150px;grid-template-columns:repeat(7,38px)}.board-preview span{width:38px;height:38px}.mini-invite{bottom:110px}.active-strip,.coming-games{grid-template-columns:repeat(2,minmax(0,1fr))}.room-status-top{grid-template-columns:auto minmax(0,1fr)}.top-choice{grid-column:1 / -1;width:100%}}@media(max-width:680px){.app-shell{padding-inline:10px}.topbar{margin-bottom:16px}.avatar-pill{display:none}.game-card{min-height:440px;border-radius:18px}.tictac-card{min-height:390px}.flappy-copy h1,.four-title span,.tictac-copy h1{font-size:clamp(3.2rem,15vw,4.4rem)}.tictac-card-art{opacity:.42}.four-title strong{margin-left:58px}.preview-pipe{right:22px;width:84px}.preview-bird{left:16%;width:72px;height:52px}.board-preview{right:14px;top:178px;grid-template-columns:repeat(7,28px);gap:7px;padding:14px}.board-preview span{width:28px;height:28px}.mini-invite{display:none}.table-tokens{right:28px;bottom:90px;gap:34px;transform:scale(.72);transform-origin:bottom right}.four-play{width:calc(100% - 40px);bottom:22px}.active-strip,.coming-games{grid-template-columns:1fr}.coming-card{min-height:170px}.lobby-footer{align-items:flex-start;flex-direction:column;gap:12px}.game-header{align-items:flex-start;flex-direction:column}.four-board{gap:6px;padding:10px}.slot{padding:4px}.score-row{justify-content:flex-start}}
