:root{--bg: #0f1419;--bg-2: #1a2028;--fg: #e6e6e6;--muted: #8a94a3;--accent: #4ade80;--danger: #f87171;--border: #2a3240;--card-bg: #f8f8f6;--card-red: #c0392b;--card-black: #111}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,button{touch-action:manipulation}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;min-height:100vh}button{background:var(--bg-2);color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:8px 14px;font:inherit;cursor:pointer}button:hover:not(:disabled){background:#222a35;border-color:#3a475a}button:disabled{opacity:.4;cursor:not-allowed}button.big{padding:14px 24px;font-size:1.1em;background:var(--accent);color:#0b1218;border:none;font-weight:600}input{background:var(--bg-2);color:var(--fg);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font:inherit}.lobby-page{max-width:900px;margin:0 auto;padding:16px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;min-height:100vh;min-height:100dvh}.lobby-hero{width:100%;text-align:center}.lobby{width:100%;max-width:480px;padding:16px 20px;background:var(--bg-2);border:1px solid var(--border);border-radius:12px}.lobby-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:2px}.lobby-logo{font-size:1.8em;color:var(--accent);line-height:1;filter:drop-shadow(0 2px 6px rgba(74,222,128,.4))}.lobby-brand h1{margin:0;font-size:1.6em}.hero-tag{color:var(--muted);margin:0 0 10px;font-size:.85em}.feature-cards{display:flex;gap:10px;margin-bottom:0}.feature-card{flex:1;background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:10px 12px;display:flex;align-items:flex-start;gap:8px;text-align:left}.feature-icon{font-size:1.3em;flex:0 0 auto}.feature-text{flex:1}.feature-title{font-weight:700;font-size:.85em;color:var(--fg);margin-bottom:2px}.feature-desc{font-size:.74em;color:var(--muted);line-height:1.3}.feature-soon{font-size:.68em;color:var(--accent);margin-top:3px;font-weight:600}.how-it-works{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:10px;padding:6px 10px;background:#4ade800f;border:1px solid rgba(74,222,128,.15);border-radius:8px}.create-settings{display:flex;flex-direction:column;gap:12px}.pill-wide{min-width:52px}.pill-blind{min-width:0;padding-left:8px;padding-right:8px;white-space:nowrap}.game-settings-tags{display:flex;gap:6px;flex:0 0 auto}.game-tag{font-size:.72em;color:var(--muted);background:var(--bg-2);border:1px solid var(--border);border-radius:10px;padding:2px 8px;white-space:nowrap}.step{font-size:.82em;color:var(--fg);display:flex;align-items:center;gap:6px}.step-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:var(--accent);color:#0b1218;font-weight:800;font-size:.85em;flex:0 0 auto}.step-arrow{color:var(--muted);font-size:.9em}.lobby .hint{color:var(--muted);font-size:.85em;margin-top:12px}.lobby code{background:var(--bg);padding:2px 6px;border-radius:4px}.lobby-help-btn{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;font-size:.75em;font-weight:700;background:#2a3040;color:#9ecdff;border:1px solid #3a475a;border-radius:50%;cursor:pointer;margin-left:6px;vertical-align:middle}.lobby-help-btn:hover{background:#3a475a;color:#fff}.lobby-tutorial-btn{display:inline-flex;align-items:center;padding:4px 10px;font-size:.78em;font-weight:600;background:#2a3040;color:#9ecdff;border:1px solid #3a475a;border-radius:999px;cursor:pointer;margin-left:8px;vertical-align:middle}.lobby-tutorial-btn:hover{background:#3a475a;color:#fff}.join-error{background:#f871711f;border:1px solid rgba(248,113,113,.4);border-radius:6px;padding:8px 12px;color:#fca5a5;font-size:.88em;line-height:1.35}.lobby-name{display:flex;flex-direction:column;gap:6px;font-size:.9em;color:var(--muted);margin-bottom:12px}.lobby-name input{font-size:1.1em}.lobby-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px}.lobby-tab{flex:1;padding:10px 16px;background:transparent;color:var(--muted);border:none;border-bottom:2px solid transparent;border-radius:0;margin-bottom:-2px;font-weight:600;font-size:.95em;cursor:pointer;transition:color .15s,border-color .15s}.lobby-tab:hover{color:var(--fg)}.lobby-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.lobby-form{display:flex;flex-direction:column;gap:14px}.lobby-form label{display:flex;flex-direction:column;gap:6px;font-size:.9em;color:var(--muted)}.lobby-form label.toggle-row{flex-direction:row;align-items:center;gap:8px;color:var(--fg)}.lobby-form input{font-size:1.1em}.lobby-submit{background:var(--accent);color:#0b1218;border:none;padding:12px;font-weight:600;font-size:1.05em;border-radius:6px}.create-code-row{display:flex;align-items:flex-end;gap:8px}.create-code-row label{flex:1}.regen-btn{width:40px;height:40px;font-size:1.3em;padding:0;background:var(--bg);border:1px solid var(--border);color:var(--fg);border-radius:6px;cursor:pointer}.regen-btn:hover{background:#2a3240}.create-option{display:flex;flex-direction:column;gap:6px}.option-label{font-size:.82em;color:var(--muted)}.pill-selector{display:flex;gap:4px}.pill{min-width:36px;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:6px;background:var(--bg);color:var(--muted);font-weight:700;font-size:.82em;cursor:pointer;transition:all .12s;white-space:nowrap}.pill:hover{border-color:var(--accent);color:var(--fg)}.pill.active{background:var(--accent);color:#0b1218;border-color:var(--accent)}.toggle-row{display:flex;align-items:center;gap:8px;font-size:.9em;color:var(--fg);cursor:pointer}.toggle-row{display:flex;align-items:center;gap:8px;font-size:.9em;color:var(--fg);cursor:pointer;flex-direction:row}.toggle-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.public-games-section{width:100%;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:14px 20px}.public-games-section h2{margin:0 0 10px;font-size:1em;color:var(--fg)}.no-games{color:var(--muted);font-size:.9em;margin:0;padding:12px 0;text-align:center}.lobby-footer{text-align:center;padding:16px 0;padding-bottom:max(16px,env(safe-area-inset-bottom));display:flex;justify-content:center;align-items:center;gap:8px;margin-top:auto}.footer-link{color:var(--muted);font-size:.82em;text-decoration:none;background:none;border:none;padding:0;font:inherit;cursor:pointer;transition:color .15s}.footer-link:hover{color:#9ecdff}.footer-dot{color:var(--border);font-size:.8em}.legal-content h3{margin-top:16px}.legal-content h4{color:var(--fg);margin:10px 0 4px;font-size:.95em}.legal-updated{color:var(--muted);font-size:.85em;font-style:italic;margin-bottom:12px}.game-list{display:flex;flex-direction:column;gap:8px}.game-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:8px}.game-info{flex:1;min-width:0}.game-code{font-weight:700;font-size:1.05em;color:var(--accent);letter-spacing:.05em}.game-meta{font-size:.82em;color:var(--muted);margin-top:2px}.game-join-btn{padding:6px 14px;font-size:.85em;font-weight:600;background:var(--accent);color:#0b1218;border:none;border-radius:6px;cursor:pointer;flex:0 0 auto}.game-join-btn:hover{background:#3ab86c}.table-root{max-width:1400px;margin:0 auto;padding:10px 16px;display:flex;flex-direction:row;align-items:stretch;gap:14px;height:100vh;height:100dvh;overflow:hidden}.main-col{flex:1 1 auto;min-width:0;min-height:0;display:flex;flex-direction:column;gap:8px;position:relative}.topbar{display:flex;justify-content:space-between;align-items:center;padding:6px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;font-size:.9em}.topbar-right{display:flex;align-items:center;gap:10px}.invite-btn{padding:4px 10px;font-size:.85em;font-weight:600;background:#2a3f55;color:#9ecdff;border:1px solid #3a5a7a;border-radius:5px;cursor:pointer;transition:background .15s}.invite-btn:hover{background:#3a5a7a;color:#fff}.leave-btn{padding:4px 10px;font-size:.85em;font-weight:600;background:#3a1f24;color:#f0a0a0;border:1px solid #5a2a30;border-radius:5px;cursor:pointer;transition:background .15s}.leave-btn:hover{background:#5a2a30;color:#fff}.help-btn{width:24px;height:24px;padding:0;font-size:.9em;font-weight:700;background:#2a3040;color:#9ecdff;border:1px solid #3a475a;border-radius:50%;cursor:pointer}.help-btn:hover{background:#3a475a;color:#fff}.sound-btn{width:28px;height:28px;padding:0;font-size:.95em;background:#2a3040;border:1px solid #3a475a;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.sound-btn:hover{background:#3a475a}.help-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.help-modal{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;max-width:720px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #000c}.help-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.help-header h2{margin:0;font-size:1.2em}.help-close{background:transparent;border:none;color:var(--muted);font-size:1.2em;cursor:pointer;padding:4px 10px;border-radius:6px}.help-close:hover{background:#2a3240;color:var(--fg)}.help-content{padding:16px 22px 22px;overflow-y:auto;font-size:.9em;line-height:1.5}.help-content section{margin-bottom:18px}.help-content h3{font-size:1em;margin:0 0 8px;color:var(--accent);border-bottom:1px solid var(--border);padding-bottom:4px}.help-content h4{font-size:.92em;margin:12px 0 4px;color:#c4a6ff}.help-content p{margin:4px 0 8px;color:#d0d8e8}.help-content ul,.help-content ol{margin:4px 0 8px;padding-left:22px}.help-content li{margin:3px 0;color:#d0d8e8}.help-content code{background:var(--bg);padding:1px 5px;border-radius:3px;font-size:.9em}.help-note{font-size:.85em;color:var(--muted);font-style:italic}.help-list{list-style:none;padding:0}.help-list li{padding:5px 0;border-bottom:1px solid #1f2733;display:flex;gap:8px;align-items:flex-start}.help-list li:last-child{border-bottom:none}.help-icon{font-size:1.15em;flex:0 0 auto}.help-rankings{list-style:decimal}.help-rankings li b{color:#fff}.help-ranking-table{width:100%;border-collapse:collapse;margin:6px 0 8px}.help-ranking-table th{text-align:left;font-size:.75em;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);padding:6px 8px;border-bottom:1px solid var(--border)}.help-ranking-table td{padding:8px;border-bottom:1px solid #1f2733;vertical-align:middle;color:#d0d8e8}.help-ranking-table tr:last-child td{border-bottom:none}.help-ranking-table .rank-num{width:24px;font-weight:700;color:var(--muted);text-align:center}.help-ranking-table .rank-name{font-weight:700;color:#fff;white-space:nowrap}.help-ranking-table .rank-cards-row{display:flex;gap:3px}.help-ranking-table .rank-notes{font-size:.82em;color:var(--muted)}.spectator-tag{position:relative;font-size:.8em;color:#c8a2ff;background:#5a3e8a4d;padding:3px 8px;border-radius:10px;border:1px solid rgba(167,139,250,.4);cursor:default}.spectator-popover{position:absolute;top:calc(100% + 6px);right:0;min-width:140px;padding:8px 12px;background:#1e1a35;border:1px solid #5a3e8a;border-radius:8px;box-shadow:0 6px 18px #0009;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-4px);transition:opacity .12s,transform .12s;z-index:50}.spectator-tag:hover .spectator-popover{opacity:1;visibility:visible;transform:translateY(0)}.spectator-row{font-size:.95em;color:#d9c5ff;padding:2px 0;white-space:nowrap}.spectator-row+.spectator-row{border-top:1px solid rgba(167,139,250,.15);margin-top:3px;padding-top:5px}.spectator-banner{background:#5a3e8a40;border:1px solid #5a3e8a;border-radius:8px;padding:8px 14px;color:#d9c5ff;font-size:.9em;text-align:center}.muted{color:var(--muted)}.modifier-corner{position:absolute;top:50px;left:0;max-width:240px;padding:8px 12px;background:linear-gradient(135deg,#2e1a4aeb,#1a2b4aeb);border:1px solid rgba(180,140,255,.55);border-radius:10px;box-shadow:0 4px 12px #00000080;z-index:4}.mod-label{font-size:.6em;color:#d7c0ff;letter-spacing:.18em;font-weight:700}.mod-name{font-weight:700;font-size:.92em;margin:2px 0 3px;color:#fff}.mod-desc{color:#d0d8e8;font-size:.72em;line-height:1.35}.felt-wrap{width:100%;display:flex;justify-content:center;align-items:center;padding:clamp(50px,10vh,120px) clamp(50px,8vw,110px) clamp(76px,10vh,100px);flex:1 1 auto;min-height:0;overflow:visible}.felt{position:relative;width:auto;height:100%;max-width:min(100%,820px);aspect-ratio:2.6 / 1;background:radial-gradient(ellipse at 50% 40%,#1e7a52,#156245 45%,#0a3a26);border:14px solid;border-color:#3a2412;border-radius:50%;box-shadow:0 20px 50px #000000b3,inset 0 0 60px #00000073;overflow:visible}.felt:before{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:50%;border:2px solid rgba(255,255,255,.08);pointer-events:none}.center-area{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:10px;width:80%}.champion-overlay{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:30;text-align:center;pointer-events:none;animation:champion-pop .5s cubic-bezier(.34,1.56,.64,1) both}.champion-trophy{font-size:3.6em;filter:drop-shadow(0 4px 12px rgba(245,215,122,.7));animation:champion-bounce 1.6s ease-in-out infinite}.champion-name{font-size:2.2em;font-weight:800;color:#ffe8a3;text-shadow:0 2px 8px rgba(0,0,0,.8),0 0 24px rgba(245,215,122,.5);letter-spacing:.02em}.champion-wins{font-size:1.4em;font-weight:800;color:#fff;letter-spacing:.25em;text-shadow:0 2px 6px rgba(0,0,0,.8);margin-bottom:8px}.champion-replay-btn{pointer-events:auto;padding:12px 28px;font-size:1.05em;font-weight:700;background:var(--accent);color:#0b1218;border:none;border-radius:8px;cursor:pointer;box-shadow:0 6px 18px #0009;transition:transform .1s,box-shadow .1s}.champion-replay-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px #000000b3,0 0 24px #4ade8066}.champion-waiting{padding:8px 16px;background:#00000080;color:#d0d8e8;font-size:.9em;border-radius:6px;border:1px solid rgba(255,255,255,.15)}@keyframes champion-pop{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes champion-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.community-cards{display:flex;gap:6px;justify-content:center;align-items:flex-end}.flying-chips{position:absolute;transform:translate(-50%,-50%);pointer-events:none;z-index:20;transition:left 1.2s cubic-bezier(.5,0,.4,1.2),top 1.2s cubic-bezier(.5,0,.4,1.2),opacity .4s ease-out 1s;will-change:left,top,opacity}.flying-chips.flying{opacity:0}.card-slot{width:62px;height:88px;border:1px dashed rgba(255,255,255,.15);border-radius:6px}.card-wrap{position:relative;display:inline-flex;flex-direction:column;align-items:center}@keyframes card-deal{0%{transform:translateY(-32px) rotate(-6deg) scale(.8);opacity:0}60%{opacity:1}to{transform:none;opacity:1}}.card-deal{animation:card-deal .32s cubic-bezier(.34,1.3,.64,1) both}@keyframes hole-deal{0%{transform:translateY(-20px) scale(.85);opacity:0}to{transform:none;opacity:1}}.seat-cards>div,.seat-cards>.card{animation:hole-deal .22s ease-out both}.seat-cards>*:nth-child(2){animation-delay:.08s}.seat-cards>*:nth-child(3){animation-delay:.16s}.card-wrap.bonus-card .card{outline:2px solid #f5d77a;outline-offset:2px;box-shadow:0 0 0 4px #f5d77a26,0 3px 8px #00000080}.card-wrap.peek-ghost{position:relative}.card-wrap.peek-ghost .card{opacity:.45;filter:saturate(.5);outline:2px dashed rgba(167,139,250,.8);outline-offset:2px;box-shadow:0 0 14px #a78bfa59}.peek-seen-btn{align-self:center;padding:4px 12px;background:#a78bfa40;color:#e0ccff;border:1px solid rgba(167,139,250,.6);border-radius:14px;font-size:.75em;font-weight:700;letter-spacing:.05em;cursor:pointer}.peek-seen-btn:hover{background:#a78bfa73}.peek-eye{position:absolute;top:-10px;left:50%;transform:translate(-50%);font-size:.85em;background:#1e1a35;color:#d9c5ff;padding:1px 5px;border-radius:10px;border:1px solid rgba(167,139,250,.6);box-shadow:0 2px 4px #00000080;pointer-events:none}.bonus-label{position:absolute;top:-12px;left:50%;transform:translate(-50%);font-size:.6em;font-weight:800;letter-spacing:.1em;color:#2b1810;background:#f5d77a;padding:1px 6px;border-radius:10px;white-space:nowrap;box-shadow:0 2px 4px #00000080}.pot{display:flex;align-items:center;justify-content:center;padding:6px 14px;background:#0000004d;border-radius:18px}.winners{position:absolute;top:100%;left:50%;transform:translate(-50%);color:#ffe8a3;font-weight:600;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.6);white-space:nowrap;margin-top:6px;pointer-events:none}.seat{position:absolute;width:0;height:0}.seat>*{position:absolute;left:0;top:0}.seat-cards{transform:translate(-50%,-50%);display:flex;gap:4px;z-index:2}.seat.folded .seat-cards{opacity:.35;filter:grayscale(.5)}.seat-plate{--plate-push: 72px;transform:translate(calc(-50% + var(--dx) * var(--plate-push)),calc(-50% + var(--dy) * var(--plate-push)));min-width:140px;padding:7px 10px;background:#080c12e0;border:1px solid var(--border);border-radius:10px;text-align:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 10px #00000080;z-index:1}.seat.me .seat-plate{min-width:170px;transform:translate(-50%,calc(-50% + var(--plate-push)))}.seat.me .seat-cards{transform:translate(-50%,calc(-50% - 10px))}.seat.turn .seat-plate{border-color:var(--accent);box-shadow:0 0 0 2px #4ade8066,0 0 22px #4ade8040}.seat.dc .seat-plate{border-style:dashed}.seat.folded .seat-plate{opacity:.55}.seat-top{display:flex;justify-content:space-between;align-items:center;font-size:.85em;gap:6px}.seat-top .name{font-weight:600;flex:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pu-count{color:#a78bfa;font-size:.85em;flex:0 0 auto}.dealer-btn{display:inline-block;filter:drop-shadow(0 1px 2px rgba(0,0,0,.6));flex:0 0 auto;margin:0 2px}.seat-chips{display:flex;justify-content:center;margin:4px 0 2px}.zero-chips{font-size:.85em;font-weight:700;color:#f87171;font-variant-numeric:tabular-nums}.seat-bot{font-size:.7em;color:var(--muted);margin-top:2px}.hand-desc{font-size:.72em;font-weight:700;color:#ffe8a3;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;margin:-2px -4px 4px;border-bottom:1px solid rgba(255,232,163,.2);text-shadow:0 1px 2px rgba(0,0,0,.6)}.seat-bet{--bet-push: 78px;transform:translate(calc(-50% - var(--dx) * var(--bet-push)),calc(-50% - var(--dy) * var(--bet-push)));display:flex;flex-direction:column;align-items:center;gap:2px;z-index:3}.timer{position:absolute;bottom:-8px;right:-8px;background:var(--accent);color:#0b1218;padding:2px 10px;border-radius:12px;font-size:.75em;font-weight:700;box-shadow:0 2px 6px #0009;z-index:5;white-space:nowrap}.card{width:62px;height:88px;background:var(--card-bg);border-radius:6px;position:relative;border:1px solid #cfcfcf;box-shadow:0 3px 6px #0006;overflow:hidden;font-family:SF Pro Display,-apple-system,system-ui,sans-serif}.card.red{color:var(--card-red)}.card.black{color:var(--card-black)}.card .corner{position:absolute;top:4px;left:5px;line-height:1;display:flex;flex-direction:column;align-items:center}.card .corner .r{font-size:18px;font-weight:800;letter-spacing:-.5px}.card .corner .s-small{font-size:12px;margin-top:1px}.card .s-big{position:absolute;right:5px;bottom:8px;font-size:38px;line-height:.85;font-weight:400}.card.back{background:#1e3a5f;border:1px solid #2a5080;background-image:repeating-linear-gradient(45deg,#1e3a5f,#1e3a5f 4px,#2a5080 4px,#2a5080 8px)}.card.small{width:44px;height:62px}.card.small .corner{top:3px;left:3px}.card.small .corner .r{font-size:12px}.card.small .corner .s-small{font-size:9px}.card.small .s-big{font-size:24px;right:3px;bottom:5px}.chips{display:inline-flex;align-items:flex-end;gap:8px}.chips-row{display:inline-flex;align-items:flex-end;gap:4px}.chip-group{display:inline-flex;align-items:flex-end;gap:3px}.chip-svg{filter:drop-shadow(0 2px 2px rgba(0,0,0,.5))}.chips-label{font-size:.72em;color:#ffe8a3;font-weight:800;font-variant-numeric:tabular-nums;align-self:center;text-shadow:0 1px 2px rgba(0,0,0,.8)}.chips-sm .chips-label{font-size:.6em}.chips-sm .chips-row{gap:2px}.chips-lg .chips-label{font-size:.9em}.controls{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;flex-direction:column;gap:8px;align-items:stretch;overflow:visible;min-width:0;flex:0 0 auto;position:relative}.start-row{display:flex;justify-content:flex-start}.start-btn{background:var(--accent);color:#0b1218;border:none;padding:8px 16px;font-weight:700;font-size:.9em;border-radius:6px}.start-btn:hover:not(:disabled){background:#3ab86c}.show-cards-btn{padding:6px 14px;font-size:.85em;font-weight:600;background:#2a3f55;color:#9ecdff;border:1px solid #3a5a7a;border-radius:6px;cursor:pointer}.show-cards-btn:hover{background:#3a5a7a;color:#fff}.peek{background:#1a2b3a;border:1px solid #2a4055;border-radius:6px;padding:8px 12px;display:flex;gap:8px;align-items:center}.peek-label{font-size:.85em;color:var(--muted)}.rev{display:flex;align-items:center;gap:4px}.action-row{display:flex;gap:14px;align-items:center;width:100%;min-width:0;min-height:84px;overflow:visible;flex-wrap:wrap}.action-row-spacer{flex:1 1 auto;min-width:20px}.action-bar{display:flex;gap:6px;align-items:stretch;flex:0 0 auto}.action-bar.disabled{pointer-events:none}.action-bar.disabled .act-btn{filter:grayscale(.6) brightness(.7)}.act-btn{flex:0 0 auto;min-width:78px;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:7px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);box-shadow:0 2px #0006,inset 0 1px #ffffff40;font-weight:700;transition:transform .08s,box-shadow .08s}.act-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px #0006,inset 0 1px #ffffff59}.act-btn:active:not(:disabled){transform:translateY(1px);box-shadow:0 1px #0006,inset 0 1px #ffffff40}.act-btn .act-main{font-size:.85em;letter-spacing:.02em}.act-btn .act-amt{font-size:.95em;font-weight:800;font-variant-numeric:tabular-nums}.act-fold{background:linear-gradient(180deg,#2a2f38,#1a1e25);border-color:#3a414d}.act-call{background:linear-gradient(180deg,#17a74a,#0f6b30);border-color:#145526}.act-raise{background:linear-gradient(180deg,#d9342a,#8e1a14);border-color:#651010}.bet-controls{display:flex;flex-direction:column;gap:4px;width:210px}.bet-presets{display:flex;gap:3px}.bet-presets button{flex:1;padding:3px 4px;background:#2a3240;border:1px solid #3a475a;border-radius:4px;color:#d0d8e8;font-size:.72em;font-weight:600}.bet-presets button:hover:not(:disabled){background:#3a4555}.bet-slider-row{display:flex;align-items:center;gap:4px}.bet-slider-row input[type=range]{flex:1;min-width:0;accent-color:#d9342a;cursor:pointer;height:4px}.bet-slider-row .bet-number{width:62px;text-align:right;font-variant-numeric:tabular-nums;font-weight:700;padding:4px 6px;font-size:.85em;-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.bet-slider-row .bet-number::-webkit-inner-spin-button,.bet-slider-row .bet-number::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.bet-slider-row .step{width:22px;height:22px;padding:0;display:inline-flex;align-items:center;justify-content:center;line-height:1;text-align:center;background:#2a3240;border:1px solid #3a475a;border-radius:4px;color:#d0d8e8;font-weight:700;font-size:.95em}.powerups-section{display:flex;flex-direction:column;gap:4px;flex:0 1 auto;min-width:0}.powerups-compact{display:flex;gap:6px;flex-wrap:wrap}.pu-max-msg{font-size:.72em;color:#ffd2a0;background:#a0501466;border:1px solid rgba(255,160,90,.6);border-radius:6px;padding:4px 8px;text-align:center;line-height:1.25}.pu-compact{width:64px;height:78px;background:linear-gradient(180deg,#2e1a4a,#1a0f28);border:1px solid #5a3e8a;border-radius:7px;padding:6px 4px;text-align:center;position:relative;cursor:default;box-shadow:0 2px 4px #0006;transition:transform .12s,box-shadow .12s}.pu-compact .pu-compact-body{opacity:.55}.pu-compact:hover{transform:translateY(-2px);box-shadow:0 5px 14px #7850c866;border-color:#a78bfa}.pu-compact.playable{cursor:pointer;border-color:#a78bfa;box-shadow:0 0 0 1px #a78bfa66,0 2px 4px #0006}.pu-compact.playable .pu-compact-body{opacity:1}.pu-compact.playable:hover{box-shadow:0 0 0 2px #a78bfa99,0 5px 14px #7850c880}.pu-compact.playable:active{transform:translateY(0)}.pu-discard{position:absolute;top:2px;right:2px;width:16px;height:16px;padding:0;border-radius:50%;background:#00000080;border:1px solid rgba(255,255,255,.2);color:#f87171;font-size:10px;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:2}.pu-compact:hover .pu-discard{opacity:1}.pu-discard:hover{background:#f87171;color:#fff}.pu-pop-hint{font-size:.72em;color:#a78bfa;font-weight:600;margin-top:6px;text-align:center}.pu-compact-body{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:2px}.pu-icon{font-size:1.5em;line-height:1}.pu-compact-name{font-size:.7em;font-weight:700;color:#d9c5ff;line-height:1.1}.pu-popover{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%) translateY(6px);width:200px;padding:10px 12px;background:#2a1f4a;border:1px solid #7a5fb8;border-radius:8px;box-shadow:0 8px 24px #000000d9;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .12s,transform .12s;z-index:300}.pu-compact:hover .pu-popover,.pu-compact.expanded .pu-popover{opacity:1;visibility:visible;transform:translate(-50%) translateY(0);pointer-events:auto}.pu-compact.expanded{transform:translateY(-2px);box-shadow:0 0 0 2px #a78bfa99,0 6px 18px #7850c880;border-color:#a78bfa}.pu-popover:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#5a3e8a}.pu-pop-name{font-weight:700;color:#e0c8ff;font-size:.92em;margin-bottom:4px}.pu-pop-desc{font-size:.8em;color:#f0f0f5;line-height:1.4}.target-picker{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding:10px;background:#1e1a35;border-radius:6px;border:1px solid #3a2e5a;position:absolute;bottom:100%;left:0;right:0;margin-bottom:6px;z-index:50;box-shadow:0 4px 14px #0009}.own-card-pickable{cursor:pointer;border-radius:8px;padding:2px;box-shadow:0 0 0 3px #a78bfa,0 0 18px #a78bfa99;animation:own-card-pulse 1.2s ease-in-out infinite;transition:transform .12s}.own-card-pickable:hover{transform:translateY(-4px)}@keyframes own-card-pulse{0%,to{box-shadow:0 0 0 3px #a78bfa,0 0 14px #a78bfa73}50%{box-shadow:0 0 0 4px #c4a6ff,0 0 22px #a78bfabf}}.log-side{flex:0 0 260px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.82em;color:var(--fg);font-family:SF Mono,Menlo,monospace;overflow:hidden;align-self:stretch;display:flex;flex-direction:column;gap:8px}.log-inner{flex:1;display:flex;flex-direction:column-reverse;overflow:hidden;gap:3px;mask-image:linear-gradient(to bottom,transparent 0,#000 40px,#000 100%);-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 40px,#000 100%)}.log-line{color:var(--muted);padding:1px 0;line-height:1.35;flex:0 0 auto;animation:log-slide-in .25s ease-out}.log-line:first-child{color:#ffe8a3}.log-line.log-chat{color:#9ecdff;font-family:-apple-system,BlinkMacSystemFont,system-ui,sans-serif}.log-line.log-chat:first-child{color:#c4e0ff}.log-line.log-powerup{color:#c4b0ff}.log-line.log-powerup:first-child{color:#d9caff}.chat-form{flex:0 0 auto;border-top:1px solid var(--border);padding-top:6px}.chat-input{width:100%;background:var(--bg);color:var(--fg);border:1px solid var(--border);border-radius:5px;padding:5px 8px;font-family:-apple-system,BlinkMacSystemFont,system-ui,sans-serif;font-size:.95em;box-sizing:border-box}.chat-input:focus{outline:none;border-color:#5a7a9a;background:#1a2028}.chat-input::placeholder{color:#4a5560}@keyframes log-slide-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px}.toast{background:var(--danger);color:#fff;padding:10px 16px;border-radius:6px}.emote-bar{display:flex;gap:4px;justify-content:flex-end;align-self:flex-end}.emote-btn{width:34px;height:30px;padding:0;font-size:1.1em;background:var(--bg);border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:transform .1s,background .1s;line-height:1}.emote-btn:hover{transform:scale(1.15);background:var(--bg-2)}.emote-btn:active{transform:scale(.95)}.floating-emote{position:absolute;left:0;top:0;transform:translate(-50%,-50%);font-size:2.4em;pointer-events:none;z-index:50;animation:emote-float 2.5s ease-out forwards;filter:drop-shadow(0 2px 6px rgba(0,0,0,.6))}@keyframes emote-float{0%{opacity:1;transform:translate(-50%,-50%) scale(.5)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}30%{transform:translate(-50%,-50%) scale(1)}80%{opacity:1;transform:translate(-50%,calc(-50% - 40px)) scale(1)}to{opacity:0;transform:translate(-50%,calc(-50% - 60px)) scale(.8)}}.tutorial-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;background:var(--bg)}.tutorial-overlay{position:fixed;bottom:12px;left:50%;transform:translate(-50%);z-index:260;width:100%;max-width:360px;padding:0 12px;pointer-events:none}@media (max-width: 679px){.tutorial-fullscreen{display:flex;flex-direction:column}.tutorial-overlay{position:relative;top:auto;bottom:auto;left:auto;transform:none;max-width:none;padding:4px 6px 0;flex:0 0 auto;pointer-events:auto}.tutorial-dialog{padding:6px 10px;gap:3px}.tutorial-title{font-size:.88em}.tutorial-text{font-size:.74em;line-height:1.3}.tutorial-progress{gap:3px;margin-bottom:1px}.progress-dot{width:5px;height:5px}.tutorial-skip{font-size:.68em;padding:1px 5px}.tutorial-btn{padding:4px 10px;font-size:.8em}.tutorial-hint{font-size:.76em}.tutorial-nav{gap:6px}.tutorial-wrong-action{font-size:.72em;padding:4px 8px}.tutorial-fullscreen .table-root{flex:1 1 auto;height:auto;max-height:none;min-height:0}}.tutorial-min-btn,.tutorial-min-label{display:none}.tutorial-dialog{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:10px 14px;box-shadow:0 -4px 30px #000000b3;pointer-events:auto;display:flex;flex-direction:column;gap:6px;position:relative}.tutorial-progress{display:flex;gap:6px;justify-content:center}.progress-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .2s}.progress-dot.active{background:var(--accent)}.progress-dot.done{background:#4ade8066}.tutorial-title{margin:0;font-size:.95em;color:var(--fg);text-align:center}.tutorial-text{margin:0;font-size:.8em;color:#c8d0dc;line-height:1.4;text-align:center;white-space:pre-line}.tutorial-nav{display:flex;align-items:center;gap:10px}.tutorial-spacer{flex:1}.tutorial-btn{padding:8px 20px;border-radius:8px;font-weight:600;font-size:.95em;cursor:pointer;border:none}.tutorial-btn.primary{background:var(--accent);color:#0b1218}.tutorial-btn.primary:hover{background:#3ab86c}.tutorial-btn.secondary{background:var(--bg);color:var(--fg);border:1px solid var(--border)}.tutorial-btn.secondary:hover{background:#2a3240}.tutorial-hint{font-size:.85em;color:var(--accent);font-weight:600;animation:tutorial-pulse-anim 1s ease-in-out infinite}@keyframes tutorial-pulse-anim{0%,to{opacity:.6}50%{opacity:1}}.tutorial-wrong-action{background:#f871711f;border:1px solid rgba(248,113,113,.4);border-radius:6px;padding:6px 10px;color:#fca5a5;font-size:.85em;text-align:center}.tutorial-skip{align-self:center;background:none;border:none;color:var(--muted);font-size:.78em;cursor:pointer;padding:4px}.tutorial-skip:hover{color:var(--fg)}.tutorial-prompt-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:400;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.tutorial-prompt{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:28px 32px;text-align:center;max-width:400px;box-shadow:0 10px 40px #000c}.tutorial-prompt-icon{font-size:3em;color:var(--accent);margin-bottom:8px;filter:drop-shadow(0 2px 8px rgba(74,222,128,.5))}.tutorial-prompt h2{margin:0 0 8px}.tutorial-prompt p{color:var(--muted);margin:0 0 18px;font-size:.95em}.tutorial-prompt-actions{display:flex;gap:10px;justify-content:center;margin-bottom:12px}.tutorial-dont-show{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.82em;color:var(--muted);cursor:pointer}.tutorial-dont-show input{accent-color:var(--accent);cursor:pointer}.reconnecting-banner{position:fixed;top:20px;left:50%;transform:translate(-50%);background:#a05014e6;color:#ffd2a0;border:1px solid rgba(255,160,90,.6);border-radius:20px;padding:8px 16px;font-size:.85em;font-weight:600;z-index:500;display:flex;align-items:center;gap:8px;box-shadow:0 6px 20px #00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.reconnect-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#ffb36b;animation:reconnect-pulse 1.2s ease-in-out infinite}@keyframes reconnect-pulse{0%,to{opacity:.3}50%{opacity:1}}@media (max-width: 1279px){.log-side{flex:0 0 220px}}@media (max-width: 1099px){.felt-wrap{padding:100px 70px 80px}.felt{max-width:720px}.log-side{flex:0 0 200px;padding:8px 10px;font-size:.78em}}@media (max-width: 959px){.table-root{flex-direction:column}.main-col{width:100%}.log-side{flex:0 0 auto;width:100%;height:100px;align-self:stretch}.log-inner{flex-direction:column-reverse}.felt-wrap{padding:90px 50px 70px}}@media (max-width: 819px){.felt-wrap{padding:80px 30px 60px}.felt{max-width:640px}.seat-plate{min-width:120px;padding:5px 8px}.seat.me .seat-plate{min-width:140px}.card{width:52px;height:74px}.card .corner .r{font-size:15px}.card .corner .s-small{font-size:10px}.card .s-big{font-size:32px;bottom:6px}.card.small{width:36px;height:52px}.card.small .s-big{font-size:20px}.card-slot{width:52px;height:74px}.action-row{gap:8px}.act-btn{min-width:68px;padding:5px 10px}.bet-controls{width:180px}.pu-compact{width:56px;height:70px}.pu-icon{font-size:1.3em}.pu-compact-name{font-size:.65em}}@media (max-width: 679px){.table-root{padding:4px;gap:4px;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;overflow:hidden}.main-col{gap:4px;flex:1 1 auto;min-height:0;overflow:hidden}.topbar{padding:5px 8px;font-size:.72em;flex-wrap:wrap;gap:4px}.topbar-right{gap:5px;flex-wrap:wrap}.topbar-right>.muted{display:none}.invite-btn,.leave-btn{padding:3px 7px;font-size:.78em}.sound-btn,.help-btn{width:22px;height:22px;font-size:.8em}.modifier-corner{position:static;max-width:100%;padding:5px 9px}.mod-label{font-size:.58em}.mod-name{font-size:.82em;margin:1px 0 2px}.mod-desc{font-size:.68em;line-height:1.25}.felt-wrap{padding:48px 14px 56px;flex:1 1 auto;min-height:0;overflow:visible}.felt{aspect-ratio:1.9 / 1;max-width:100%;height:100%}.card{width:38px;height:54px}.card .corner{top:2px;left:3px}.card .corner .r{font-size:12px}.card .corner .s-small{font-size:9px}.card .s-big{font-size:22px;right:3px;bottom:5px}.card.small{width:28px;height:40px}.card.small .corner{top:1px;left:2px}.card.small .corner .r{font-size:9px}.card.small .corner .s-small{font-size:7px}.card.small .s-big{font-size:16px;right:2px;bottom:3px}.card-slot{width:38px;height:54px}.seat-plate{--plate-push: 40px;min-width:80px;padding:3px 6px;font-size:.68em}.seat.me .seat-plate{min-width:100px;--plate-push: 42px}.seat-top{font-size:.92em}.seat-chips{margin:2px 0 0}.seat-bot{font-size:.68em}.dealer-btn{width:14px;height:14px}.pu-count{font-size:.78em}.seat-bet{--bet-push: 40px}.pot{padding:3px 6px;border-radius:10px;background:#00000040}.timer{padding:1px 6px;font-size:.65em}.emote-bar{gap:3px}.emote-btn{width:30px;height:28px;font-size:1em}.floating-emote{font-size:1.8em}.community-cards{gap:4px}.controls{padding:6px 8px;padding-bottom:max(6px,env(safe-area-inset-bottom));gap:6px;flex:0 0 auto}.action-row{gap:6px}.action-row-spacer{display:none}.action-bar{gap:4px;flex-wrap:wrap;width:100%}.act-btn{min-width:0;flex:1 1 30%;padding:6px 4px}.act-btn .act-main{font-size:.82em}.act-btn .act-amt{font-size:.9em}.bet-controls{width:100%}.bet-presets button{padding:3px 2px;font-size:.66em}.bet-slider-row{gap:3px}.bet-slider-row input[type=range]{min-width:0}.bet-slider-row .bet-number{width:52px;font-size:.78em;padding:3px 4px}.bet-slider-row .step{width:18px;font-size:.85em}.pu-compact{width:54px;height:68px;padding:4px 3px;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.pu-compact-body{gap:1px}.pu-icon{font-size:1.2em}.pu-compact-name{font-size:.62em}.pu-discard{width:14px;height:14px;font-size:9px}.pu-compact:hover .pu-popover{opacity:0;visibility:hidden;pointer-events:none}.pu-popover{position:fixed;bottom:auto;top:70px;left:12px;right:12px;width:auto;max-width:none;transform:none!important;padding:10px 14px}.pu-popover:after{display:none}.pu-compact.expanded .pu-popover{opacity:1;visibility:visible;pointer-events:auto}.powerups-compact{gap:4px}.pu-max-msg{font-size:.62em;padding:3px 6px}.log-side{flex:0 0 auto;height:70px;padding:4px 9px;font-size:.68em;gap:4px}.chat-form{padding-top:3px}.chat-input{padding:3px 6px;font-size:16px}.spectator-banner{padding:5px 10px;font-size:.78em}.champion-trophy{font-size:2.4em}.champion-name{font-size:1.4em}.champion-wins{font-size:1em}.champion-replay-btn{padding:9px 18px;font-size:.95em}.help-backdrop{padding:0}.help-modal{max-width:100%;max-height:100vh;height:100vh;border-radius:0;border:none}.help-header{padding:10px 14px;padding-top:max(10px,env(safe-area-inset-top))}.help-content{padding:12px 16px;font-size:.85em}.help-ranking-table th,.help-ranking-table td{padding:5px 4px;font-size:.9em}.toast-stack{bottom:auto;top:60px;right:10px}.toast{font-size:.82em;padding:7px 12px}.target-picker{flex-direction:column;align-items:stretch;padding:8px;font-size:.88em}.target-picker button{padding:8px 12px;font-size:1em}.lobby-page{padding:16px 12px 20px}.lobby-hero{text-align:left}.lobby-brand{justify-content:flex-start;gap:10px}.lobby-brand h1{font-size:1.5em}.lobby-logo{font-size:1.8em}.hero-tag{font-size:.85em}.lobby{padding:16px;max-width:100%}.lobby input{padding:12px 14px;font-size:16px}.lobby button[type=submit]{padding:14px;font-size:1em}.feature-cards{flex-direction:column;gap:8px}.feature-card{padding:10px}.how-it-works{flex-direction:column;gap:4px;padding:8px}.step-arrow{transform:rotate(90deg)}.game-settings-tags{display:none}.game-row{flex-wrap:wrap}input,textarea,select{font-size:16px}.chat-input{font-size:16px;padding:6px 8px}.bet-slider-row .bet-number{font-size:16px;width:60px}}
