:root{--bg:#f4f4f2;--surface:#fff;--surface2:#fafaf8;--ink:#0e0e10;--ink2:#46474b;--ink3:#86878d;--accent:#0e0e10;--accentInk:#fff;--tile:#f1f1ee;--tileMark:#0e0e10;--tileMarkInk:#fff;--hl:#ffd84d;--hlInk:#0e0e10;--border:#00000012;--font-sans:-apple-system, "SF Pro Display", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;height:100%;margin:0;padding:0;overflow-x:hidden}body{background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-variant-numeric:tabular-nums;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior-y:none;font-size:15px;line-height:1.4}button{cursor:pointer;color:inherit;background:0 0;border:none;padding:0;font-family:inherit}input{font-family:inherit}a{color:inherit;text-decoration:none}.screen{width:100%;max-width:440px;padding:env(safe-area-inset-top,0) 18px 24px;padding-top:max(env(safe-area-inset-top,0), 24px);box-sizing:border-box;flex-direction:column;gap:18px;min-height:100dvh;margin:0 auto;display:flex}.screen-cta{flex-direction:column;gap:10px;margin-top:auto;padding-top:24px;display:flex}.display{letter-spacing:-.8px;margin:0;font-size:clamp(28px,8vw,34px);font-weight:800;line-height:1.05}.title{letter-spacing:-.6px;margin:0;font-size:clamp(24px,7vw,30px);font-weight:800;line-height:1.05}.section-title{margin:0;font-size:17px;font-weight:700}.body{color:var(--ink);margin:0;font-size:15px;font-weight:500;line-height:1.45}.body-muted{color:var(--ink2);margin:0;font-size:15px;font-weight:500;line-height:1.45}.eyebrow{text-transform:uppercase;letter-spacing:1.2px;color:var(--ink3);font-size:11px;font-weight:700}.avatar{color:#000000c7;letter-spacing:-.4px;-webkit-user-select:none;user-select:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.btn{letter-spacing:-.2px;border-radius:14px;justify-content:center;align-items:center;gap:10px;height:50px;padding:0 20px;font-size:15px;font-weight:700;transition:transform 80ms,opacity .15s,background .15s;display:inline-flex}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-full{width:100%}.btn-primary{background:var(--accent);color:var(--accentInk)}.btn-secondary{background:var(--surface);color:var(--ink);border:.5px solid var(--border)}.btn-ghost{color:var(--ink2);background:0 0}.btn-highlight{background:var(--hl);color:var(--hlInk);box-shadow:0 8px 22px #ffb80073}.btn-leading{align-items:center;display:inline-flex}.btn-icon-circle{background:var(--accentInk);width:26px;height:26px;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.icon-btn{width:40px;height:40px;color:var(--ink);background:var(--surface);border:.5px solid var(--border);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.icon-btn:active{transform:scale(.94)}.link-btn{color:var(--accent);font-size:14px;font-weight:600}.field{flex-direction:column;gap:8px;display:flex}.text-input{background:var(--surface);border:.5px solid var(--border);height:48px;color:var(--ink);border-radius:14px;outline:none;width:100%;padding:0 14px;font-size:16px;font-weight:600;transition:border-color .15s}.text-input:focus{border-color:var(--accent)}.onboarding{padding-top:32px}.onboarding-header{flex-direction:column;gap:6px;display:flex}.onboarding-avatar{justify-content:center;margin:0;display:flex}.onboarding-cta{margin-top:auto;padding-top:16px}.color-grid{grid-template-columns:repeat(8,1fr);gap:8px;display:grid}.color-swatch{aspect-ratio:1;border:2px solid #0000;border-radius:999px;transition:transform .1s,border-color .15s}.color-swatch:active{transform:scale(.92)}.color-swatch-active{border-color:var(--ink);transform:scale(1.05)}.home-topbar{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.profile-chip{background:var(--surface);border:.5px solid var(--border);border-radius:999px;align-items:center;gap:10px;padding:6px 14px 6px 6px;display:inline-flex}.profile-chip-name{font-size:14px;font-weight:600}.home-hero{flex-direction:column;gap:6px;display:flex}.stats-card{background:var(--surface);border:.5px solid var(--border);border-radius:18px;align-items:stretch;padding:18px 8px;display:flex}.stat-col{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.stat-value{letter-spacing:-.8px;font-size:28px;font-weight:800}.stat-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--ink3);font-size:11px;font-weight:700}.stat-divider{background:var(--border);width:.5px}.home-actions{flex-direction:column;gap:10px;margin-top:6px;display:flex}.topbar{grid-template-columns:40px 1fr 40px;align-items:center;gap:8px;margin-bottom:4px;display:grid}.topbar-side{align-items:center;display:flex}.topbar-side-right{justify-content:flex-end}.topbar-title{text-align:center;margin:0;font-size:17px;font-weight:700}.settings-profile{background:var(--surface);border:.5px solid var(--border);border-radius:18px;align-items:center;gap:16px;padding:14px 16px;display:flex}.settings-name-btn{flex:1;justify-content:space-between;align-items:center;display:flex}.settings-name-edit{flex:1;align-items:center;gap:10px;display:flex}.settings-name-edit .text-input{flex:1;height:44px}.settings-group-label{text-transform:uppercase;letter-spacing:1.2px;color:var(--ink3);justify-content:space-between;align-items:center;margin-top:4px;margin-bottom:-10px;padding-left:18px;padding-right:8px;font-size:11px;font-weight:700;display:flex}.settings-group{background:var(--surface);border:.5px solid var(--border);border-radius:18px;overflow:hidden}.settings-row{border-bottom:.5px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.settings-row:last-child{border-bottom:none}.settings-row-stacked{flex-direction:column;align-items:stretch;gap:10px}.settings-row-static{pointer-events:none}.settings-row-label{color:var(--ink);font-size:15px;font-weight:600}.settings-row-value{color:var(--ink2);font-size:14px;font-weight:500}.settings-row-control{width:100%}.settings-row-colors{gap:6px;display:flex}.color-dot{border:2px solid #0000;border-radius:999px;width:24px;height:24px;transition:transform .1s,border-color .15s}.color-dot-active{border-color:var(--ink);transform:scale(1.1)}.segmented{background:var(--surface2);border-radius:11px;gap:2px;padding:3px;display:flex}.segmented-opt{height:32px;color:var(--ink2);border-radius:9px;flex:1;font-size:13px;font-weight:600;transition:background .15s,color .15s}.segmented-opt-active{background:var(--surface);color:var(--ink);box-shadow:0 1px 2px #0000000f}.palette-row{flex-wrap:wrap;gap:8px;display:flex}.palette-chip{opacity:.6;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:700;transition:opacity .15s,transform .1s}.palette-chip-active{opacity:1;transform:scale(1.04)}.toggle{background:var(--surface2);border:.5px solid var(--border);border-radius:999px;width:50px;height:30px;transition:background .2s;position:relative}.toggle-on{background:var(--accent);border-color:#0000}.toggle-thumb{background:var(--surface);border-radius:999px;width:24px;height:24px;transition:transform .18s;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #00000026}.toggle-on .toggle-thumb{transform:translate(20px)}.join-sub{margin-top:-10px}.otp-grid{grid-template-columns:repeat(5,1fr);gap:8px;display:grid}.otp-cell{aspect-ratio:1;background:var(--surface);border:.5px solid var(--border);text-align:center;color:var(--ink);border-radius:14px;outline:none;width:100%;min-width:0;padding:0;font-size:clamp(20px,6vw,26px);font-weight:800;transition:border-color .15s}.otp-cell:focus{border-color:var(--accent)}.join-divider{color:var(--ink3);align-items:center;gap:12px;font-size:13px;font-weight:600;display:flex}.join-divider:before,.join-divider:after{content:"";background:var(--border);flex:1;height:.5px}.scan-card{background:var(--surface);border:.5px solid var(--border);text-align:left;border-radius:16px;align-items:center;gap:14px;width:100%;padding:16px 18px;display:flex}.scan-card-icon{background:var(--surface2);width:40px;height:40px;color:var(--ink);border-radius:12px;justify-content:center;align-items:center;display:inline-flex}.scan-card-label{flex:1;font-size:15px;font-weight:600}.scan-card-chev{color:var(--ink3)}.lobby-sub{margin-top:-10px}.qr-card{background:var(--surface);border:.5px solid var(--border);border-radius:22px;flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.qr-placeholder{aspect-ratio:1;background:#fff;border-radius:14px;justify-content:center;align-items:center;width:min(180px,60vw);padding:10px;display:flex}.qr-placeholder>svg{width:100%;height:100%}.qr-svg{shape-rendering:crispedges;width:100%;height:100%;image-rendering:pixelated}.code-chip{background:var(--surface2);border:.5px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;padding:10px 18px;display:inline-flex}.code-chip-value{letter-spacing:4px;font-size:22px;font-weight:800}.lobby-live{text-transform:none;letter-spacing:0;color:var(--ink2);align-items:center;gap:6px;font-size:12px;font-weight:600;display:inline-flex}.live-dot{background:#2bb673;border-radius:999px;width:8px;height:8px;animation:1.4s ease-in-out infinite dotPulse}.players-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.player-tile{flex-direction:column;align-items:center;gap:8px;animation:.35s cubic-bezier(.2,.9,.3,1.2) titleIn;display:flex}.player-tile-name{color:var(--ink);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:12px;font-weight:600;overflow:hidden}.player-tile-empty{opacity:.6}.player-slot-dashed{border:1.5px dashed var(--ink3);width:56px;height:56px;color:var(--ink3);border-radius:999px;justify-content:center;align-items:center;display:flex}.placeholder-card{background:var(--surface);border:.5px solid var(--border);border-radius:18px;flex-direction:column;gap:8px;padding:20px;display:flex}.game-screen{gap:16px;padding-top:28px}.game-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.game-round{flex-direction:column;gap:2px;display:flex}.game-round-num{letter-spacing:-.6px;font-size:26px;font-weight:800;line-height:1}.game-history{flex-wrap:nowrap;gap:4px;max-width:60%;display:flex;overflow:hidden}.history-pill{background:var(--surface2);color:var(--ink2);border-radius:999px;align-items:center;gap:3px;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.history-pill small{opacity:.6;font-size:10px}.player-tiles-row{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;padding:4px 0;display:flex;overflow-x:auto}.player-tiles-row::-webkit-scrollbar{display:none}.player-tile-mini{border:2px solid #0000;border-radius:999px;flex-shrink:0;padding:2px;transition:border-color .2s;position:relative}.player-tile-waiting{border-color:var(--hl);animation:1.4s ease-in-out infinite tilePulse}.player-tile-offline{opacity:.4;filter:grayscale(.7)}.player-tile-check{color:#fff;border:2px solid var(--bg);background:#2bb673;border-radius:999px;justify-content:center;align-items:center;width:20px;height:20px;font-size:13px;font-weight:800;display:inline-flex;position:absolute;top:-2px;right:-2px}.player-tile-you{display:none}.called-ball{background:var(--accent);width:clamp(80px,24vw,100px);height:clamp(80px,24vw,100px);color:var(--accentInk);border-radius:999px;flex-direction:column;justify-content:center;align-self:center;align-items:center;gap:0;margin:0;display:flex;box-shadow:0 12px 30px #0000002e}.called-ball-active{animation:.55s cubic-bezier(.2,.9,.3,1.2) bingoBallIn}.called-ball-empty{background:var(--surface2);color:var(--ink3);box-shadow:none}.called-letter{letter-spacing:1.5px;opacity:.8;font-size:12px;font-weight:800}.called-number{letter-spacing:-1.5px;font-size:clamp(28px,9vw,38px);font-weight:800;line-height:1}.bingo-card-wrap{flex-direction:column;gap:6px;display:flex}.bingo-card-headers{grid-template-columns:repeat(5,1fr);gap:6px;padding:0 2px;display:grid}.bingo-card-header{text-align:center;letter-spacing:1.5px;color:var(--ink3);font-size:14px;font-weight:800}.bingo-card-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.bingo-cell{aspect-ratio:1;background:var(--tile);color:var(--ink);border-radius:11px;justify-content:center;align-items:center;min-width:0;font-size:clamp(14px,4.5vw,18px);font-weight:700;transition:transform 80ms,background .15s,color .15s;display:flex}.bingo-cell:active{transform:scale(.94)}.bingo-cell-marked{background:var(--tileMark);color:var(--tileMarkInk);animation:.25s ease-out markIn}.bingo-cell-free{background:var(--tileMark);color:var(--tileMarkInk);font-size:22px}.bingo-cell-current{outline:2px solid var(--hl);outline-offset:1px;animation:1.4s ease-in-out infinite tilePulse}.bingo-cell-pending{opacity:.6}.bingo-cell-idle{opacity:.7}.bingo-cell:disabled{cursor:default}.reactions-bar{justify-content:space-between;gap:8px;padding:6px 4px;display:flex}.reaction-btn{background:var(--surface);border:.5px solid var(--border);border-radius:14px;flex:1;justify-content:center;align-items:center;height:48px;font-size:24px;transition:transform 80ms;display:flex}.reaction-btn:active{transform:scale(.94)}.reactions-overlay{pointer-events:none;z-index:50;position:fixed;inset:0;overflow:hidden}.reaction-float{text-shadow:0 0 12px;font-size:38px;animation:2.5s ease-out forwards floatUp;position:absolute;bottom:100px}.winner{text-align:center;align-items:center;padding-top:32px;position:relative;overflow:hidden}.trophy-icon{font-size:clamp(40px,12vw,56px);animation:.6s cubic-bezier(.2,.9,.3,1.2) trophyIn}.winner-title{letter-spacing:-2px;font-size:clamp(48px,14vw,64px);animation:.5s cubic-bezier(.2,.9,.3,1.2) titleIn}.winner-card{background:var(--surface);border:.5px solid var(--border);border-radius:22px;flex-direction:column;align-items:center;gap:12px;width:100%;padding:18px;display:flex}.winner-name-block{flex-direction:column;align-items:center;gap:2px;display:flex}.mini-card{grid-template-columns:repeat(5,1fr);gap:3px;width:160px;margin-top:6px;display:grid}.mini-cell{aspect-ratio:1;background:var(--tile);color:var(--ink);border-radius:4px;justify-content:center;align-items:center;font-size:9px;font-weight:700;display:inline-flex}.mini-cell-win{background:var(--hl);color:var(--hlInk)}.leaderboard{flex-direction:column;gap:8px;width:100%;display:flex}.leaderboard-list{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.leaderboard-row{background:var(--surface);border:.5px solid var(--border);border-radius:14px;align-items:center;gap:12px;padding:10px 14px;display:flex}.leaderboard-row-winner{background:var(--hl);color:var(--hlInk);border-color:#0000}.leaderboard-rank{width:18px;color:var(--ink3);font-size:14px;font-weight:800}.leaderboard-row-winner .leaderboard-rank{color:var(--hlInk);opacity:.6}.leaderboard-name{text-align:left;flex:1;font-size:15px;font-weight:600}.confetti{pointer-events:none;position:absolute;inset:0;overflow:hidden}.confetti-piece{border-radius:2px;width:8px;height:14px;animation:3s linear forwards confettiFall;position:absolute;top:-20px}.host-tag{color:var(--hl);margin-left:4px}.lobby-waiting-host{text-align:center;margin:0}.field-error{color:#d9542b;margin-top:4px;font-size:13px}.bingo-claim-fab{left:50%;bottom:max(20px, env(safe-area-inset-bottom,20px));background:var(--hl);width:calc(100% - 32px);max-width:360px;height:60px;color:var(--hlInk);letter-spacing:1px;z-index:60;border-radius:999px;font-size:22px;font-weight:800;animation:1.4s ease-in-out infinite bingoBtnPulse;position:fixed;transform:translate(-50%);box-shadow:0 8px 22px #ffb8008c}@keyframes bingoBtnPulse{0%,to{transform:translate(-50%)scale(1);box-shadow:0 8px 22px #ffb8008c}50%{transform:translate(-50%)scale(1.04);box-shadow:0 12px 30px #ffb800d9}}.video-tile{background:var(--surface2);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.video-tile-stream{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.av-card{background:var(--surface);border:.5px solid var(--border);border-radius:18px;flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.av-preview{justify-content:center;align-items:center;display:flex}.av-toggles{gap:10px;width:100%;display:flex}.av-pill{background:var(--surface2);border:.5px solid var(--border);height:46px;color:var(--ink);border-radius:999px;flex:1;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:600;transition:background .15s,color .15s;display:inline-flex}.av-pill-on{background:var(--accent);color:var(--accentInk);border-color:#0000}.av-pill:disabled{opacity:.5}.av-error{color:#d9542b;text-align:center;margin:0;font-size:12px}.solo-link{color:var(--ink2);border-radius:12px;justify-content:center;align-self:center;align-items:center;gap:8px;margin-top:4px;padding:12px;font-size:14px;font-weight:600;display:inline-flex}.solo-link:active{opacity:.6}.player-slot-dashed-lg{width:72px;height:72px}.winner-call-strip{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;width:100%;padding:4px 2px 12px;display:flex;overflow-x:auto}.winner-call-strip::-webkit-scrollbar{display:none}.winner-call-tile{flex-direction:column;flex-shrink:0;align-items:center;gap:6px;display:flex}.winner-call-name{color:var(--ink2);text-overflow:ellipsis;white-space:nowrap;max-width:70px;font-size:11px;font-weight:600;overflow:hidden}.reconnect{text-align:center;align-items:center;padding-top:80px}.reconnect-radar{width:140px;height:140px;margin-bottom:8px;position:relative}.reconnect-ring{border:2px solid var(--accent);opacity:0;border-radius:999px;animation:2.4s ease-out infinite reconnRing;position:absolute;inset:0}.reconnect-icon{color:var(--accent);justify-content:center;align-items:center;display:flex;position:absolute;inset:0}@keyframes titleIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes dotPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}@keyframes reconnRing{0%{opacity:.6;transform:scale(.4)}to{opacity:0;transform:scale(1.4)}}@keyframes bingoBallIn{0%{opacity:0;transform:scale(.4)rotate(-12deg)}60%{opacity:1;transform:scale(1.08)rotate(2deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes tilePulse{0%,to{box-shadow:0 0 0 0 var(--hl)}50%{box-shadow:0 0 0 4px #ffd84d66}}@keyframes markIn{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}@keyframes floatUp{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-300px)scale(1.4)}}@keyframes trophyIn{0%{opacity:0;transform:scale(.2)rotate(-12deg)}60%{opacity:1;transform:scale(1.1)rotate(8deg)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes confettiFall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:.7;transform:translateY(120vh)rotate(720deg)}}.decks-section{flex-direction:column;gap:10px;display:flex}.decks-section-header{justify-content:space-between;align-items:center;display:flex}.decks-empty{text-align:center;background:var(--surface);border:1px dashed var(--border);border-radius:14px;padding:24px 12px}.decks-list{flex-direction:column;gap:8px;display:flex}.deck-card{background:var(--surface);border:.5px solid var(--border);text-align:left;border-radius:16px;align-items:center;gap:12px;width:100%;padding:10px 12px;transition:transform 80ms;display:flex}.deck-card:active{transform:scale(.98)}.deck-card-selected{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.deck-card-thumb{background:var(--surface2);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;display:flex;overflow:hidden}.deck-card-thumb img{object-fit:cover;width:100%;height:100%}.deck-card-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.deck-card-name{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:700;overflow:hidden}.deck-card-meta{color:var(--ink3);font-size:12px}.decks-actions{flex-direction:column;gap:8px;margin-top:4px;display:flex}.load-by-code{background:var(--surface);border:.5px solid var(--border);border-radius:14px;flex-direction:column;gap:6px;padding:10px;display:flex}.deck-editor-headerrow{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.photos-grid{grid-template-columns:repeat(3,1fr);gap:8px;margin-top:8px;display:grid}.photo-item{flex-direction:column;gap:4px;display:flex}.photo-thumb{aspect-ratio:1;background:var(--surface2);border-radius:12px;position:relative;overflow:hidden}.photo-thumb img{object-fit:cover;width:100%;height:100%}.photo-remove{color:#fff;background:#000000a6;border-radius:999px;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;font-weight:700;display:inline-flex;position:absolute;top:4px;right:4px}.photo-name-input{background:var(--surface);border:.5px solid var(--border);height:32px;color:var(--ink);border-radius:8px;outline:none;padding:0 8px;font-size:13px}.success-card{background:var(--surface);border:.5px solid var(--border);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:8px;padding:28px 18px;display:flex}.success-emoji{font-size:56px}.deck-picker{flex-direction:column;gap:8px;display:flex}.deck-preview{flex-direction:column;gap:6px;display:flex}.deck-preview-strip{scrollbar-width:none;gap:6px;padding:2px;display:flex;overflow-x:auto}.deck-preview-strip::-webkit-scrollbar{display:none}.deck-preview-thumb{object-fit:cover;border-radius:10px;flex-shrink:0;width:44px;height:44px}.deck-preview-more{background:var(--surface2);width:44px;height:44px;color:var(--ink2);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.players-grid-2{grid-template-columns:repeat(2,1fr)}.qe-game-header{flex-direction:column;gap:8px;display:flex}.qe-game-players{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.qe-game-player{flex-direction:column;align-items:center;gap:4px;display:flex}.qe-turn-banner{justify-content:center;display:flex}.turn-pill{background:var(--surface2);color:var(--ink2);text-transform:uppercase;letter-spacing:.6px;border-radius:999px;padding:6px 16px;font-size:13px;font-weight:700}.turn-pill-you{background:var(--hl);color:var(--hlInk);animation:1.4s ease-in-out infinite tilePulse}.secret-strip{flex-direction:column;gap:4px;display:flex}.secret-card{background:var(--surface);border:1px solid var(--accent);border-radius:14px;align-items:center;gap:10px;padding:8px 10px;display:flex}.secret-card img{object-fit:cover;border-radius:10px;width:56px;height:56px}.secret-card span{color:var(--ink);font-size:15px;font-weight:700}.flip-hint{text-align:center;margin:0;font-size:13px}.face-grid{gap:6px;display:grid}.face-grid-3{grid-template-columns:repeat(3,1fr)}.face-grid-4{grid-template-columns:repeat(4,1fr)}.face-grid-5{grid-template-columns:repeat(5,1fr)}.face-cell{aspect-ratio:1;background:var(--tile);border-radius:10px;padding:0;transition:transform 80ms,opacity .2s;position:relative;overflow:hidden}.face-cell:active{transform:scale(.94)}.face-cell img{object-fit:cover;width:100%;height:100%;transition:filter .2s}.face-cell-flipped img{filter:grayscale()brightness(.4)}.face-overlay{color:#ffffffd9;text-shadow:0 2px 6px #000000b3;justify-content:center;align-items:center;font-size:32px;font-weight:800;display:flex;position:absolute;inset:0}.face-name{color:#fff;text-align:center;text-overflow:ellipsis;white-space:nowrap;background:linear-gradient(#0000,#000000b3);padding:10px 4px 3px;font-size:10px;font-weight:700;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.face-secret-badge{background:var(--hl);color:var(--hlInk);border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:11px;font-weight:800;display:inline-flex;position:absolute;top:3px;right:3px}.face-cell-secret{outline:2px solid var(--hl);outline-offset:-2px}.face-cell-guessmode{cursor:pointer;outline:1px dashed var(--accent);outline-offset:-1px}.face-cell-picked{outline:3px solid var(--accent);outline-offset:-3px}.reveal-grid{grid-template-columns:1fr 1fr;gap:12px;width:100%;display:grid}.reveal-cell{background:var(--surface);border:.5px solid var(--border);border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:10px;display:flex;position:relative}.reveal-cell img{aspect-ratio:1;object-fit:cover;border-radius:10px;width:100%}.reveal-name{color:var(--ink);font-size:14px;font-weight:700}.reveal-video{border-radius:999px;width:48px;height:48px;position:absolute;top:6px;right:6px;overflow:hidden}
