@import "https://fonts.googleapis.com/css2?family=Fraunces:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&family=Oswald:wght@400;600;700&family=Playfair+Display:ital,wght@0,700;1,700;1,800&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--card-w:90px;--card-h:130px;--card-r:10px;--gold:#fbbf24;--gold-dim:#fbbf241a;--gold-border:#fbbf2447;--red:#c0392b;--black:#1a1a1a;--card-bg:#fefefe;--card-shadow:0 4px 14px #0000008c;--bg-base:#070503;--bg-surface:#0d0904;--bg-panel:#0e0a05e6;--table-surface:#2a1a0d;--table-dark:#0e0906;--border-subtle:#c4a97d17;--border-medium:#c4a97d2e;--border-strong:#c4a97d4d;--text-primary:#f0e8d8;--text-secondary:#c4a97d;--text-muted:#7a6a58;--team-0:#6ee7b7;--team-1:#fca5a5;--anim-dur:var(--anim-dur)}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif}#root{width:100%;min-height:100vh}.app{flex-direction:column;gap:8px;min-height:100vh;padding:10px;display:flex}.scoreboard{z-index:10;background:var(--bg-panel);border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(16px);border-radius:12px;align-items:stretch;display:flex;position:sticky;top:0;overflow:hidden;box-shadow:inset 0 1px #ffffff08,0 4px 20px #0006}.team-score{flex:1;justify-content:center;align-items:center;gap:10px;padding:10px 28px;display:flex;position:relative}.team-score+.team-score:before{content:"";background:var(--border-subtle);width:1px;height:60%;position:absolute;top:20%;left:0}.bid-info{color:var(--text-secondary);align-items:center;gap:10px;padding:10px 22px;font-size:13px;display:flex;position:relative}.bid-info:before{content:"";background:var(--border-subtle);width:1px;height:60%;position:absolute;top:20%;left:0}.team-name{color:var(--text-muted);letter-spacing:1.2px;text-transform:uppercase;font-size:10px;font-weight:700}.team-points{color:var(--text-primary);font-family:Oswald,sans-serif;font-size:30px;font-weight:700;line-height:1}.team-0 .team-points{color:var(--team-0)}.team-1 .team-points{color:var(--team-1)}.hand-pts{color:var(--team-0);background:#6ee7b714;border:1px solid #6ee7b72e;border-radius:99px;padding:2px 8px;font-size:12px;font-weight:600}.trump-badge{background:var(--gold-dim);border:1px solid var(--gold-border);border-radius:6px;padding:2px 10px;font-size:15px;font-weight:700}.trump-badge.red{color:#f87171}.trump-badge.black{color:#c7d2fe}.game-area{flex-direction:row;flex:1;align-items:stretch;gap:8px;display:flex}.game-column{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.table{border:1px solid var(--border-subtle);background:radial-gradient(at 50% 40%,#271508 0%,#110800 100%);border-radius:16px;flex-direction:column;flex:1;align-items:center;gap:8px;padding:14px;display:flex;box-shadow:inset 0 1px #ffffff08,inset 0 0 80px #00000080,0 0 0 1px #0009}.middle-row{justify-content:center;align-items:center;gap:8px;width:100%;display:flex}.hand{flex-direction:column;align-items:center;gap:4px;display:flex}.hand-cards{flex-wrap:wrap;justify-content:center;gap:4px;display:flex}.hand-west .hand-cards,.hand-east .hand-cards{flex-direction:column;max-height:260px;overflow:hidden}.hand-west .hand-cards.hand-cards-debug,.hand-east .hand-cards.hand-cards-debug{flex-flow:wrap;max-height:none;overflow:visible}.hand-label{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:600}.hand-count{color:#7a6a5899;font-size:10px}.hand-count-badge{display:none}.avatar{width:var(--avatar-size);height:var(--avatar-size);background:var(--avatar-bg);border:2px solid #0000;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:border-color .3s,box-shadow .3s;display:flex}.avatar-initials{font-size:calc(var(--avatar-size) * .36);color:#ffffffeb;letter-spacing:.3px;font-family:Inter,sans-serif;font-weight:700}.avatar-active{border-color:var(--gold);animation:2s ease-in-out infinite avatar-pulse;box-shadow:0 0 0 3px #fbbf2433,0 0 16px #fbbf2433}@keyframes avatar-pulse{0%,to{box-shadow:0 0 0 3px #fbbf242e,0 0 16px #fbbf241f}50%{box-shadow:0 0 0 5px #fbbf2452,0 0 24px #fbbf2438}}.avatar-passed{opacity:.28;filter:grayscale()}.passed-badge{color:var(--text-muted);border:1px solid var(--border-subtle);background:#00000040;border-radius:99px;margin-left:4px;padding:1px 7px;font-size:10px;font-style:italic}.hand-passed .hand-label{color:#7a6a5866}.hand-passed .hand-cards{opacity:.3}.card{width:var(--card-w);height:var(--card-h);border-radius:var(--card-r);background:var(--card-bg);box-shadow:var(--card-shadow);-webkit-user-select:none;user-select:none;transition:transform var(--anim-dur), box-shadow var(--anim-dur);flex-direction:column;flex-shrink:0;justify-content:space-between;padding:4px 5px;display:flex;position:relative}.card.small{width:72px;height:104px;padding:4px 5px;font-size:15px}.card.red{color:var(--red)}.card.black{color:var(--black)}.card.face-down{background:repeating-linear-gradient(135deg,#192e45,#192e45 5px,#142538 5px 10px);border:1px solid #0d1e30}.card.playable{cursor:pointer;outline:2px solid var(--gold);outline-offset:2px}.card.playable:hover{transform:translateY(-8px);box-shadow:0 14px 28px #0000008c,0 0 0 3px #fbbf2433}.rank-top,.rank-bottom{flex-direction:column;align-items:flex-start;font-size:18px;font-weight:700;line-height:1;display:flex}.rank-bottom{align-items:flex-end;transform:rotate(180deg)}.suit-small{font-size:12px;line-height:1}.suit-center{font-size:38px;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.card.small .suit-center{font-size:28px}.trick-area{flex-direction:column;flex:1;align-items:center;gap:6px;min-width:220px;display:flex}.trump-indicator{border:1px solid var(--border-medium);letter-spacing:.6px;background:#00000080;border-radius:99px;padding:3px 14px;font-size:12px;font-weight:600}.trump-indicator.red{color:#f87171}.trump-indicator.black{color:#c7d2fe}.trick-grid{flex-direction:column;align-items:center;gap:4px;display:flex}.trick-row-middle{align-items:center;gap:8px;display:flex}.trick-slot{border:1px dashed #c4a97d1f;border-radius:8px;justify-content:center;align-items:center;width:76px;height:108px;display:flex}.trick-center{text-align:center;width:70px}.tricks-won{color:var(--text-muted);letter-spacing:.3px;font-size:11px}.status-bar{text-align:center;color:var(--gold);letter-spacing:.6px;text-shadow:0 0 24px #fbbf2447;text-transform:uppercase;min-height:22px;font-size:13px;font-weight:600}.bid-panel,.trump-select-panel{background:var(--bg-panel);border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(16px);border-radius:14px;flex-direction:column;align-items:center;gap:10px;padding:14px 20px;display:flex;box-shadow:0 4px 24px #00000080}.bid-label{color:var(--text-muted);letter-spacing:1.2px;text-transform:uppercase;font-size:10px;font-weight:700}.bid-buttons,.trump-buttons{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.bid-btn{color:#93c5fd;cursor:pointer;transition:background var(--anim-dur), border-color var(--anim-dur), color var(--anim-dur), transform .1s;letter-spacing:.5px;background:#1d4ed82e;border:1px solid #3b82f647;border-radius:8px;padding:8px 16px;font-family:Oswald,sans-serif;font-size:14px;font-weight:700}.bid-btn:hover:not(:disabled){color:#bfdbfe;background:#1d4ed866;border-color:#3b82f699;transform:translateY(-1px)}.bid-btn:disabled{opacity:.4;cursor:not-allowed}.bid-btn.pass-btn{color:var(--text-muted);background:#6b72801f;border-color:#6b728038}.bid-btn.pass-btn:hover{color:var(--text-secondary);background:#6b728040;border-color:#6b728066}.trump-btn{cursor:pointer;background:#ffffffe6;border:1px solid #ffffff1f;border-radius:10px;padding:10px 22px;font-size:22px;font-weight:700;transition:transform .12s,box-shadow .12s,background .12s;box-shadow:0 3px 10px #00000059}.trump-btn:hover{background:#fff;transform:translateY(-2px)scale(1.06);box-shadow:0 8px 20px #00000073}.trump-btn.red{color:var(--red)}.trump-btn.black{color:#111}.game-log{background:var(--bg-panel);border:1px solid var(--border-subtle);scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;-webkit-backdrop-filter:blur(12px);border-radius:12px;max-height:130px;padding:10px 14px;overflow-y:auto}.log-header{justify-content:space-between;align-items:center;margin-bottom:7px;display:flex}.log-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);font-size:10px;font-weight:700}.log-actions{align-items:center;gap:6px;display:flex}.debug-btn{color:#93c5fd;cursor:pointer;transition:background var(--anim-dur);background:#1e3a5f73;border:1px solid #3b82f638;border-radius:6px;padding:2px 9px;font-family:Inter,sans-serif;font-size:11px}.debug-btn:hover{background:#1d4ed859}.debug-btn.debug-btn-active{color:#fff;background:#1d4ed873}.reset-btn{color:#fca5a5;cursor:pointer;transition:background var(--anim-dur);background:#7f1d1d59;border:1px solid #991b1b59;border-radius:6px;padding:2px 9px;font-family:Inter,sans-serif;font-size:11px}.reset-btn:hover{background:#991b1b80}.log-list{flex-direction:column;gap:2px;list-style:none;display:flex}.log-list li{color:#7a6a58b3;font-size:12px;line-height:1.5}.log-list li.log-latest{color:var(--text-secondary);font-weight:500}.landing{z-index:1;z-index:200;background:radial-gradient(at 50% 30%,#160e05 0%,#060402 100%);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.landing:before{content:"";opacity:.4;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}.landing-logo{object-fit:contain;width:140px;height:140px}.landing-title{color:var(--text-primary);letter-spacing:2px;text-shadow:0 6px 40px #000000e6;font-family:Oswald,sans-serif;font-size:110px;font-weight:700;line-height:1;position:relative}.landing-subtitle{color:var(--text-muted);letter-spacing:5px;text-transform:uppercase;margin-top:-14px;font-size:11px;font-weight:500;position:relative}.landing-stats{border:1px solid var(--border-subtle);background:#ffffff08;border-radius:99px;align-items:center;gap:8px;padding:5px 14px;display:flex;position:relative}.landing-stat{color:var(--text-muted);letter-spacing:.3px;align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.landing-stat-dot{background:#4ade80;border-radius:50%;width:6px;height:6px;animation:2.5s ease-in-out infinite dot-pulse;box-shadow:0 0 6px #4ade8099}@keyframes dot-pulse{0%,to{opacity:1;box-shadow:0 0 6px #4ade8099}50%{opacity:.7;box-shadow:0 0 10px #4ade8066}}.landing-stat-sep{color:var(--border-strong);font-size:12px}.landing-rejoin{border:1px solid var(--gold-border);background:#fbbf240f;border-radius:12px;flex-direction:column;align-items:center;gap:8px;width:300px;padding:12px 20px;display:flex;position:relative}.landing-rejoin-text{color:var(--text-secondary);text-align:center;font-size:13px;line-height:1.5}.landing-rejoin-btn{background:var(--gold-dim);border:1px solid var(--gold-border);color:var(--gold);cursor:pointer;transition:background var(--anim-dur), border-color var(--anim-dur);border-radius:8px;width:100%;padding:7px 20px;font-family:Inter,sans-serif;font-size:13px;font-weight:700}.landing-rejoin-btn:hover{background:#fbbf2429;border-color:#fbbf2480}.landing-toast{border:1px solid var(--border-medium);color:var(--text-secondary);z-index:999;pointer-events:none;white-space:nowrap;background:#000000bf;border-radius:8px;padding:8px 18px;font-size:13px;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.name-prompt-overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.name-prompt-card{background:#faf6ee;border-radius:16px;flex-direction:column;gap:16px;width:340px;max-width:calc(100vw - 40px);padding:36px 32px 28px;animation:.18s card-up;display:flex;box-shadow:0 20px 60px #00000040}@keyframes card-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.name-prompt-title{color:#1a1209;font-family:Fraunces,serif;font-size:22px}.name-prompt-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.landing-join-code{flex-direction:column;align-items:center;gap:4px;display:flex;position:relative}.landing-join-code-label{color:var(--text-muted);letter-spacing:1.2px;text-transform:uppercase;font-size:10px;font-weight:600}.landing-input{border:1px solid var(--border-medium);color:var(--text-primary);text-align:center;background:#ffffff0a;border-radius:12px;outline:none;width:300px;margin-top:8px;padding:13px 22px;font-family:Inter,sans-serif;font-size:17px;transition:border-color .2s,background .2s,box-shadow .2s;position:relative}.landing-input::placeholder{color:var(--text-muted)}.landing-welcome{color:var(--text-primary);text-align:center;justify-content:center;align-items:center;height:44px;margin-top:8px;font-size:1.1rem;font-weight:600;display:flex}.landing-input:focus{border-color:var(--gold-border);background:#ffffff0f;box-shadow:0 0 0 3px #fbbf2412}.difficulty-row{justify-content:center;gap:6px;margin-top:-2px;display:flex}.difficulty-btn{border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;transition:background var(--anim-dur), border-color var(--anim-dur), color var(--anim-dur);background:#ffffff0a;border-radius:7px;flex:1;padding:5px 0;font-family:Inter,sans-serif;font-size:.75rem;font-weight:600}.difficulty-btn:hover{color:var(--text-primary);background:#ffffff14}.difficulty-btn--active{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.lobby-modes{flex-direction:column;gap:8px;width:320px;margin-top:4px;display:flex;position:relative}.lobby-mode-card{border:1px solid var(--border-subtle);cursor:pointer;text-align:left;color:var(--text-primary);transition:background .2s, border-color .2s, transform var(--anim-dur), box-shadow .2s;background:#ffffff08;border-radius:14px;align-items:center;gap:16px;width:100%;padding:15px 20px;display:flex}.lobby-mode-card:not(.lobby-mode-disabled):not(:disabled):hover{background:#fbbf240f;border-color:#fbbf2447;transform:translateY(-1px);box-shadow:0 6px 20px #0006}.lobby-mode-card:disabled{opacity:.35;cursor:not-allowed}.lobby-mode-disabled{opacity:.28;cursor:default}.lobby-mode-icon{flex-shrink:0;font-size:22px}.lobby-mode-text{flex-direction:column;flex:1;gap:2px;display:flex}.lobby-mode-title{color:var(--text-primary);font-size:15px;font-weight:700}.lobby-mode-desc{color:var(--text-muted);font-size:12px}.coming-soon-badge{letter-spacing:.8px;text-transform:uppercase;color:var(--text-muted);border:1px solid var(--border-subtle);background:#7a6a581a;border-radius:99px;flex-shrink:0;padding:2px 9px;font-size:10px;font-weight:700}.private-entry{flex-direction:column;align-items:center;gap:12px;width:300px;display:flex;position:relative}.private-entry-btn{background:var(--gold-dim);border:1px solid var(--gold-border);width:100%;color:var(--gold);cursor:pointer;transition:background var(--anim-dur), border-color var(--anim-dur), box-shadow var(--anim-dur);letter-spacing:.2px;border-radius:12px;padding:13px;font-family:Inter,sans-serif;font-size:15px;font-weight:700}.private-entry-btn:hover:not(:disabled){background:#fbbf2429;border-color:#fbbf2480;box-shadow:0 0 0 3px #fbbf240f}.private-entry-btn:disabled{opacity:.35;cursor:not-allowed}.private-entry-divider{color:var(--text-muted);letter-spacing:1px;text-transform:uppercase;font-size:10px;font-weight:600}.private-entry-join{gap:8px;width:100%;display:flex}.private-entry-join .private-entry-btn{flex-shrink:0;width:auto;padding:13px 18px}.join-code-input{border:1px solid var(--border-medium);color:var(--text-primary);letter-spacing:4px;text-transform:uppercase;text-align:center;background:#ffffff0a;border-radius:12px;outline:none;flex:1;padding:10px 14px;font-family:Oswald,sans-serif;font-size:18px;font-weight:700;transition:border-color .2s,box-shadow .2s}.join-code-input:focus{border-color:var(--gold-border);box-shadow:0 0 0 3px #fbbf240f}.join-code-input::placeholder{color:var(--text-muted);letter-spacing:2px;font-weight:400}.private-entry-error{color:#f87171;text-align:center;font-size:13px}.back-btn{color:var(--text-muted);cursor:pointer;transition:color var(--anim-dur);background:0 0;border:none;margin-top:2px;padding:6px 10px;font-family:Inter,sans-serif;font-size:13px}.back-btn:hover{color:var(--text-secondary)}.lobby-join-layout{background:#f0e8d5;justify-content:center;padding:48px 56px 64px;display:flex}.lobby-join-card{background:#f5edd8;border:1.5px solid #1a0f06;border-radius:18px;flex-direction:column;gap:16px;width:100%;max-width:400px;padding:36px;display:flex;box-shadow:3px 3px #1a0f06}.lobby-join-code-badge{letter-spacing:8px;color:#1a0f06;text-align:center;background:#faf6ee;border:1.5px solid #1a0f0626;border-radius:10px;padding:14px;font-family:JetBrains Mono,monospace;font-size:28px;font-weight:700}.lobby-join-hint{color:#8a7a6a;margin:0;font-family:Inter,sans-serif;font-size:13px;line-height:1.5}.lobby-name-input{color:#1a0f06;background:#fff;border:1.5px solid #1a0f062e;border-radius:10px;outline:none;padding:14px 16px;font-family:Inter,sans-serif;font-size:16px}.lobby-name-input:focus{border-color:#9b1c1c;box-shadow:0 0 0 3px #9b1c1c14}.lobby-name-input::placeholder{color:#8a7a6a}.lobby-share-bar{background:#f5edd8;border-bottom:1px solid #1a0f061a;flex-wrap:wrap;align-items:center;gap:10px;padding:16px 56px;display:flex}.lobby-share-code{letter-spacing:6px;color:#1a0f06;font-family:JetBrains Mono,monospace;font-size:22px;font-weight:700}.lobby-copy-btn{color:#1a0f06;cursor:pointer;letter-spacing:.03em;background:0 0;border:1.5px solid #1a0f06;border-radius:999px;padding:5px 12px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;transition:background .1s,color .1s}.lobby-copy-btn:hover{background:#1a0f060f}.lobby-copy-btn--active{color:#f5edd8;background:#1a0f06}.lobby-share-hint{color:#8a7a6a;letter-spacing:.05em;font-family:JetBrains Mono,monospace;font-size:10px}.lobby-body{background:#f0e8d5;flex-direction:column;align-items:center;gap:32px;padding:40px 56px 56px;display:flex}.lobby-seat-grid{flex-direction:column;align-items:center;gap:10px;display:flex}.lobby-seat-middle{align-items:center;gap:10px;display:flex}.lobby-table-center{background:#1a0f06;border:2px solid #1a0f06;border-radius:50%;justify-content:center;align-items:center;width:88px;height:88px;display:flex}.lobby-table-label{color:#f5edd8;font-family:Fraunces,Georgia,serif;font-size:22px;font-style:italic;font-weight:700}.lobby-seat{border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:120px;height:100px;transition:background .15s,transform .1s;display:flex;position:relative}.lobby-seat-empty{background:#f5edd880;border:1.5px dashed #1a0f0633}.lobby-seat-available{cursor:pointer;border-color:#1a0f0659}.lobby-seat-available:hover{background:#1a0f060d;transform:scale(1.03)}.lobby-seat-filled{background:#faf6ee;border:1.5px solid #1a0f06;box-shadow:2px 2px #1a0f06}.lobby-seat-mine{border-color:#9b1c1c;box-shadow:2px 2px #9b1c1c}.lobby-seat-plus{color:#1a0f0638;font-size:24px;line-height:1}.lobby-seat-avatar{color:#f5edd8;background:#1e3a6e;border:1.5px solid #1a0f06;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-family:Fraunces,Georgia,serif;font-size:14px;font-weight:700;display:flex}.lobby-seat-name{color:#1a0f06;text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-family:Inter,sans-serif;font-size:12px;font-weight:600;overflow:hidden}.lobby-seat-label{color:#8a7a6a;text-transform:uppercase;letter-spacing:.8px;font-family:JetBrains Mono,monospace;font-size:10px}.lobby-seat-leave{color:#8a7a6a;cursor:pointer;background:0 0;border:none;padding:2px;font-family:JetBrains Mono,monospace;font-size:10px;transition:color .1s;position:absolute;top:5px;right:7px}.lobby-seat-leave:hover{color:#9b1c1c}.lobby-actions{flex-direction:column;align-items:center;gap:10px;display:flex}.lobby-start-btn{color:#f5edd8;letter-spacing:.08em;cursor:pointer;background:#1e3a6e;border:1.5px solid #1a0f06;border-radius:12px;padding:14px 56px;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;transition:transform .1s,box-shadow .1s;box-shadow:3px 3px #1a0f06}.lobby-start-btn:hover:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px #1a0f06}.lobby-start-btn:disabled{opacity:.35;cursor:not-allowed}.lobby-waiting-msg{color:#8a7a6a;letter-spacing:.04em;font-family:JetBrains Mono,monospace;font-size:12px}.lobby-error{color:#9b1c1c;font-family:Inter,sans-serif;font-size:13px}.exit-fab{z-index:250;width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:background var(--anim-dur), color var(--anim-dur), border-color var(--anim-dur);-webkit-backdrop-filter:blur(10px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;font-size:16px;display:flex;position:fixed;top:1rem;left:1rem}.exit-fab:hover{color:#f87171;background:#f871711a;border-color:#f8717159}.player-notifications{z-index:300;pointer-events:none;flex-direction:column;align-items:center;gap:.5rem;display:flex;position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%)}.player-notification{border:1px solid var(--border-medium);color:var(--text-secondary);white-space:nowrap;-webkit-backdrop-filter:blur(10px);background:#0e0a05f5;border-radius:999px;padding:.6rem 1.3rem;font-size:.85rem;animation:.25s notif-in;box-shadow:0 6px 20px #00000080}.player-notification strong{color:var(--text-primary)}@keyframes notif-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.auth-fab{z-index:250;height:36px;color:var(--text-muted);cursor:pointer;transition:background var(--anim-dur), color var(--anim-dur), border-color var(--anim-dur);-webkit-backdrop-filter:blur(10px);white-space:nowrap;background:#ffffff0a;border:1px solid #ffffff14;border-radius:18px;align-items:center;padding:0 12px;font-size:13px;font-weight:600;text-decoration:none;display:flex;position:fixed;top:1rem;right:3.5rem}.auth-fab:hover{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.rules-fab{z-index:250;width:36px;height:36px;color:var(--text-muted);cursor:pointer;transition:background var(--anim-dur), color var(--anim-dur), border-color var(--anim-dur);-webkit-backdrop-filter:blur(10px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;font-size:16px;font-weight:700;display:flex;position:fixed;top:1rem;right:1rem}.rules-fab:hover{background:var(--gold-dim);border-color:var(--gold-border);color:var(--gold)}.rules-overlay{z-index:300;-webkit-backdrop-filter:blur(6px);background:#000000d1;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.rules-modal{border:1px solid var(--border-medium);scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;background:#0c0805;border-radius:18px;width:100%;max-width:480px;max-height:82vh;padding:2rem 2rem 1.5rem;position:relative;overflow-y:auto;box-shadow:0 28px 70px #000000d9}.rules-close{color:var(--text-muted);cursor:pointer;transition:color var(--anim-dur), background var(--anim-dur);background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:18px;line-height:1;position:absolute;top:1rem;right:1rem}.rules-close:hover{color:var(--text-primary);background:#ffffff0f}.rules-title{color:var(--text-primary);letter-spacing:-.3px;margin:0 0 1.25rem;font-size:20px;font-weight:800}.rules-section{margin-bottom:1rem}.rules-section h3{text-transform:uppercase;letter-spacing:1.2px;color:var(--gold);margin:0 0 .4rem;font-size:10px;font-weight:700}.rules-section p{color:#a09080;margin:0 0 .35rem;font-size:14px;line-height:1.65}.rules-section ul{margin:.25rem 0 .35rem 1.1rem;padding:0}.rules-section li{color:#a09080;font-size:14px;line-height:1.65}.rules-section strong{color:var(--text-primary)}.rules-section em{color:var(--gold);font-style:normal}.github-link{color:#ffffff29;z-index:100;transition:color .2s;display:flex;position:fixed;bottom:1.25rem;left:1.25rem}.github-link:hover{color:#ffffff8c}.github-link svg{fill:currentColor;width:22px;height:22px}.loading{height:100vh;color:var(--text-muted);letter-spacing:.05em;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.overlay{z-index:100;-webkit-backdrop-filter:blur(6px);background:#000000d1;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.overlay-card{border:1px solid var(--border-medium);background:#0c0805;border-radius:20px;flex-direction:column;align-items:center;gap:22px;padding:48px 64px;display:flex;box-shadow:0 28px 70px #000000d9}.overlay-result{letter-spacing:-.5px;font-size:36px;font-weight:800}.overlay-result.win{color:#34d399}.overlay-result.loss{color:#f87171}.overlay-scores{text-align:center;color:var(--text-secondary);letter-spacing:.5px;flex-direction:column;gap:6px;font-family:Oswald,sans-serif;font-size:17px;display:flex}.ready-banner{z-index:11;background:var(--bg-panel);border:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(14px);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:14px 22px;display:flex;position:sticky;top:0;box-shadow:0 4px 20px #0006}.ready-banner-label{color:var(--text-secondary);letter-spacing:.3px;font-size:12px;font-weight:500}.ready-waiting-msg{color:var(--text-muted);font-size:12px}.new-game-btn{color:var(--team-0);cursor:pointer;transition:background var(--anim-dur), border-color var(--anim-dur), box-shadow var(--anim-dur);background:#0596692e;border:1px solid #05966961;border-radius:12px;padding:13px 40px;font-family:Inter,sans-serif;font-size:17px;font-weight:700}.new-game-btn:hover{background:#05966952;border-color:#10b98199;box-shadow:0 0 20px #0596692e}.shell{flex-direction:row;min-height:100vh;display:flex}.shell-content{flex:1;min-width:0;margin-left:72px}@keyframes settings-in{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.settings-page{flex-direction:column;gap:28px;width:100%;max-width:360px;animation:.2s settings-in;display:flex;position:relative}.settings-section{flex-direction:column;gap:14px;display:flex}.settings-section-title{letter-spacing:1.5px;text-transform:uppercase;color:#bba898;border-bottom:1px solid #00000012;padding-bottom:6px;font-size:9px;font-weight:700}.settings-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.settings-label{color:#5a4a3a;font-family:Inter,sans-serif;font-size:13.5px;font-weight:500}.toggle-switch{cursor:pointer;background:#00000026;border:none;border-radius:11px;flex-shrink:0;align-items:center;width:38px;height:22px;padding:2px;transition:background .15s;display:flex}.toggle-switch--on{background:#9b1c1c}.toggle-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .15s;box-shadow:0 1px 4px #00000040}.toggle-switch--on .toggle-thumb{transform:translate(16px)}.volume-slider{accent-color:#9b1c1c;cursor:pointer;flex:1;max-width:160px;height:4px}.volume-slider:disabled{opacity:.3;cursor:not-allowed}.speed-group{gap:6px;display:flex}.speed-btn{color:#8a7a6a;cursor:pointer;background:0 0;border:2px solid #0000001f;border-radius:8px;padding:6px 14px;font-family:Inter,sans-serif;font-size:12px;font-weight:600;transition:none}.speed-btn:hover:not(.speed-btn--active){color:#3a2a1a;border-color:#00000040}.speed-btn--active{color:#fff;background:#9b1c1c;border-color:#7a1515;box-shadow:2px 2px #7a1515}.sidebar-tab{border:1px solid var(--border-strong);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);transition:color var(--anim-dur), background var(--anim-dur);background:#1e1509;border-left:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;padding:0;display:none;position:absolute;top:20px;right:-36px}.sidebar-tab:hover{color:var(--gold);background:#2a1e0a}.sidebar-backdrop{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;position:fixed;inset:0}.sidebar{z-index:200;border-right:1px solid var(--border-medium);background:#100b06;flex-direction:column;align-items:center;gap:4px;width:72px;padding:20px 0;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:visible}.nav-item{cursor:pointer;width:56px;color:var(--text-muted);transition:color var(--anim-dur), background var(--anim-dur);background:0 0;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:5px;padding:10px 8px;display:flex}.nav-item:not(.nav-item--disabled):hover{color:var(--text-secondary);background:#c4a97d14}.nav-item--active{color:var(--gold)!important;background:var(--gold-dim)!important}.nav-item--disabled{cursor:not-allowed;opacity:.35}.nav-label{text-transform:uppercase;letter-spacing:.05em;font-family:Inter,sans-serif;font-size:9px;font-weight:600}@media (width<=768px){:root{--card-w:68px;--card-h:100px}.suit-center{font-size:28px}.card.small{width:54px;height:78px}.overlay-card{padding:32px 28px}.landing-logo{width:100px;height:100px}.sidebar-tab{display:flex}.sidebar-backdrop{display:block}.sidebar{transform:translate(-72px)}.sidebar.sidebar--open{transform:translate(0)}.hand-north .hand-cards{display:none}.hand-north .hand-count-badge{color:var(--text-secondary);border:1px solid var(--border-medium);background:#ffffff0a;border-radius:8px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;display:flex}.hand-count-pip{background:repeating-linear-gradient(135deg,#192e45,#192e45 3px,#142538 3px 6px);border:1px solid #0d1e30;border-radius:3px;flex-shrink:0;width:14px;height:20px}.hand-west .hand-cards,.hand-east .hand-cards{display:none}.hand-west .hand-count-badge,.hand-east .hand-count-badge{color:var(--text-secondary);border:1px solid var(--border-medium);background:#ffffff0a;border-radius:8px;align-items:center;gap:6px;padding:5px 12px;font-size:13px;font-weight:600;display:flex}.middle-row{gap:4px}.trick-slot{width:58px;height:82px}.table{gap:6px;padding:8px}.app{gap:6px;padding:6px}}.ad-slot{background:#ffffff08;border:1px dashed #ffffff1a;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ad-slot--300x250{width:300px;height:250px}.ad-slot--728x90{width:100%;max-width:728px;height:90px}.ad-slot--160x600{align-self:center;width:160px;height:600px}@media (width<=768px){.ad-slot--728x90,.ad-slot--160x600{display:none}}.home-layout{color:#1a0f06;background:#f0e8d5;min-height:100vh;font-family:Inter,sans-serif;display:flex}.home-sidebar{background:#faf6ee;border-right:1px solid #00000014;flex-direction:column;flex-shrink:0;width:220px;height:100vh;display:flex;position:sticky;top:0}.home-brand{cursor:pointer;border-bottom:1px solid #00000012;align-items:center;gap:12px;padding:20px;display:flex}.home-brand-mark{color:#fff;background:#9b1c1c;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-family:Fraunces,Georgia,serif;font-size:18px;font-weight:700;display:flex}.home-brand-info{flex-direction:column;gap:2px;display:flex}.home-brand-name{color:#1a0f06;font-family:Fraunces,Georgia,serif;font-size:20px;font-weight:700;line-height:1}.home-brand-sub{letter-spacing:1.2px;text-transform:uppercase;color:#8a7a6a;font-size:9px;font-weight:700}.home-sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:8px 10px;display:flex}.home-nav-section-label{letter-spacing:1.5px;text-transform:uppercase;color:#bba898;padding:10px 8px 4px;font-size:9px;font-weight:700}.home-nav-item{cursor:pointer;color:#5a4a3a;text-align:left;background:0 0;border:2px solid #0000;border-radius:8px;align-items:center;gap:10px;width:100%;padding:8px 10px;font-family:Inter,sans-serif;font-size:13.5px;font-weight:500;transition:background .15s,color .15s;display:flex}.home-nav-item:hover:not(.home-nav-item--disabled){color:#1a0f06;background:#0000000d}.home-nav-item--active{font-weight:600;box-shadow:2px 2px #7a1515;color:#fff!important;background:#9b1c1c!important;border:2px solid #7a1515!important}.home-nav-item--disabled{color:#bba898;cursor:default;opacity:.7}.home-nav-spacer{flex:1}.home-nav-ico{text-align:center;opacity:.7;flex-shrink:0;width:16px;font-size:13px}.home-sidebar-footer{border-top:1px solid #0000000f;flex-direction:column;gap:6px;padding:12px 10px;display:flex}.home-auth-btn{cursor:pointer;color:#3a2a1a;text-align:center;background:0 0;border:1px solid #0000001f;border-radius:8px;padding:8px 14px;font-family:Inter,sans-serif;font-size:13px;font-weight:500;transition:background .15s}.home-auth-btn:hover{background:#0000000a}.home-auth-btn--primary{color:#fff;background:#9b1c1c;border-color:#9b1c1c}.home-auth-btn--primary:hover{background:#7a1515}.home-bottom-nav{display:none}.home-lang-toggle{gap:4px;margin-top:2px;display:flex}.home-lang-toggle button{cursor:pointer;color:#8a7a6a;letter-spacing:.5px;background:0 0;border:1px solid #0000001f;border-radius:6px;flex:1;padding:5px;font-family:Inter,sans-serif;font-size:11px;font-weight:700;transition:background .15s,color .15s}.home-lang-toggle button.active{color:#f5edd8;background:#2d1f0e;border-color:#2d1f0e}.home-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.home-hero{background:#f5edd8;border-bottom:1px solid #00000012;flex-direction:column;gap:28px;padding:48px 56px 40px;display:flex}.home-hero-top{justify-content:space-between;align-items:center;gap:32px;display:flex}.home-hero-content{flex:1;max-width:520px}.home-hero-eyebrow{letter-spacing:2px;text-transform:uppercase;color:#8a7a6a;margin-bottom:12px;font-size:11px;font-weight:700;display:block}.home-hero-heading{color:#1a0f06;margin-bottom:16px;font-family:Fraunces,Georgia,serif;font-size:58px;font-weight:700;line-height:1.1}.home-hero-heading em{color:#9b1c1c;font-style:italic}.home-hero-desc{color:#5a4a3a;max-width:420px;margin-bottom:24px;font-size:14.5px;line-height:1.65}.home-play-tiles{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.home-play-tile{cursor:pointer;border:1.5px solid #1a0f06;border-radius:14px;flex-direction:column;gap:7px;min-height:155px;padding:16px;transition:transform .1s,box-shadow .1s;display:flex;box-shadow:3px 3px #1a0f06}.home-play-tile:not(.home-play-tile--disabled):hover{transform:translate(2px,2px);box-shadow:1px 1px #1a0f06}.home-play-tile--red{color:#faf6ee;background:#9b1c1c}.home-play-tile--navy{color:#faf6ee;background:#1e3a6e}.home-play-tile--mustard{color:#1a0f06;background:#f0b429}.home-play-tile--disabled{cursor:default;opacity:.72}.home-play-tile-glyph{color:#1a0f06;background:#faf6ee;border:1.5px solid #1a0f06;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;display:flex;box-shadow:1.5px 1.5px #1a0f06}.home-play-tile-glyph--dark{color:#f0b429;background:#2d1f0e;border-color:#2d1f0e;box-shadow:1.5px 1.5px #2d1f0e}.home-play-tile-body{flex-direction:column;flex:1;gap:2px;display:flex}.home-play-tile-name{font-family:Fraunces,Georgia,serif;font-size:17px;font-style:italic;font-weight:600;line-height:1.1}.home-play-tile-sub{letter-spacing:.8px;text-transform:uppercase;opacity:.6;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700}.home-play-tile-diff{gap:4px;display:flex}.home-play-diff-btn{cursor:pointer;color:#faf6ee;background:#ffffff1a;border:1.5px solid #ffffff4d;border-radius:4px;padding:2px 7px;font-family:Inter,sans-serif;font-size:10px;font-weight:700;transition:background .1s}.home-play-diff-btn:hover{background:#fff3}.home-play-diff-btn--active{background:#ffffff47;border-color:#ffffffa6}.home-play-tile-cta{letter-spacing:.08em;opacity:.75;margin-top:auto;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700}@media (width<=560px){.home-play-tiles{grid-template-columns:1fr}.home-play-tile{min-height:auto}}.home-name-input{color:#1a0f06;background:#fff;border:1px solid #00000026;border-radius:8px;outline:none;width:100%;max-width:320px;margin-bottom:16px;padding:10px 16px;font-family:Inter,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s;display:block}.home-name-input::placeholder{color:#a09080}.home-name-input:focus{border-color:#9b1c1c;box-shadow:0 0 0 3px #9b1c1c14}.home-welcome{color:#3a2a1a;margin-bottom:16px;font-size:14px;font-weight:600}.home-hero-actions{flex-direction:column;gap:8px;margin-bottom:14px;display:flex}.home-hero-actions-row{flex-wrap:wrap;gap:8px;display:flex}.home-btn{cursor:pointer;white-space:nowrap;color:#1a0f06;background:#faf6ee;border:2px solid #1a1a1a;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:700;transition:transform 50ms,box-shadow 50ms,opacity .15s;display:inline-flex;box-shadow:3px 3px #1a1a1a}.home-btn:hover:not(:disabled){transform:translate(1px,1px);box-shadow:2px 2px #1a1a1a}.home-btn:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px #1a1a1a}.home-btn:disabled{opacity:.45;cursor:default}.home-btn--lg{padding:13px 28px;font-size:16px}.home-btn--primary{color:#fff;background:#9b1c1c;border-color:#7a1515;box-shadow:3px 3px #7a1515}.home-btn--primary:hover:not(:disabled){box-shadow:2px 2px #7a1515}.home-btn--secondary{color:#fff;background:#2d5fa8;border-color:#1e4080;box-shadow:3px 3px #1e4080}.home-btn--secondary:hover:not(:disabled){box-shadow:2px 2px #1e4080}.home-btn--tertiary{color:#1a1a1a;background:#f0b429;border-color:#c8941a;box-shadow:3px 3px #c8941a}.home-btn--tertiary:hover:not(:disabled){box-shadow:2px 2px #c8941a}.home-btn--ghost{color:#7a6a5a;box-shadow:none;background:0 0;border:2px dashed #0003}.home-btn--ghost:hover:not(:disabled){box-shadow:none;background:#00000008;transform:none}.home-btn-ico{font-family:JetBrains Mono,monospace;font-size:13px}.home-difficulty-row{align-items:center;gap:6px;margin-top:8px;margin-bottom:20px;display:flex}.home-difficulty-label{color:#8a7a6a;margin-right:2px;font-size:12px}.home-diff-btn{cursor:pointer;color:#5a4a3a;background:0 0;border:1px solid #0000001f;border-radius:6px;padding:4px 10px;font-family:Inter,sans-serif;font-size:12px;font-weight:500;transition:background .15s,color .15s}.home-diff-btn:hover{background:#0000000d}.home-diff-btn--active{color:#f5edd8;background:#2d1f0e;border-color:#2d1f0e}.home-find-game{letter-spacing:1.5px;color:#9b1c1c;cursor:pointer;text-transform:uppercase;font-size:11px;font-weight:700;text-decoration:none}.home-find-game:hover{text-decoration:underline}.hcard-fan{flex-shrink:0;width:240px;height:210px;position:relative}.hcard{color:#1a1a1a;transform-origin:bottom;background:#fff;border:1.5px solid #00000026;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;width:90px;height:128px;font-family:Georgia,serif;animation:.5s cubic-bezier(.34,1.56,.64,1) forwards hcard-deal;display:flex;position:absolute;bottom:0;left:50%;transform:translate(-50%)rotate(0);box-shadow:0 4px 16px #0000002e}@keyframes hcard-deal{0%{transform:translate(-50%)rotate(0)}to{transform:var(--final-transform)}}.hcard-red{color:#9b1c1c}.hcard-corner{text-align:center;font-size:13px;font-weight:700;line-height:1.2;position:absolute;top:8px;left:9px}.hcard-center-suit{font-size:32px}.home-stats-row{background:#faf6ee;border-bottom:1px solid #0000000f;flex-wrap:wrap;gap:16px;padding:24px 56px;display:flex}.home-stat-card{background:#f5edd8;border:1px solid #00000014;border-radius:12px;flex-direction:column;flex:1;gap:5px;min-width:160px;padding:18px 22px;display:flex}.home-stat-display{color:#1a0f06;font-family:Fraunces,Georgia,serif;font-size:32px;font-weight:700;line-height:1}.home-stat-eyebrow{letter-spacing:1.5px;text-transform:uppercase;color:#8a7a6a;font-size:10px;font-weight:700}.home-section-head{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:32px 56px 16px;display:flex}.home-section-head h2{color:#1a0f06;align-items:center;gap:10px;margin:0;font-family:Fraunces,Georgia,serif;font-size:22px;font-weight:700;display:flex}.home-section-num{color:#bba898;letter-spacing:.5px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.home-see-all-link{color:#9b1c1c;font-size:12px;font-weight:600;text-decoration:none}.home-see-all-link:hover{text-decoration:underline}.home-two-col{grid-template-columns:1fr 1fr;display:grid}.home-panel{border-bottom:1px solid #0000000f;border-right:1px solid #0000000f;padding:32px 56px}.home-panel:last-child{border-right:none}.home-panel-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.home-panel-title{color:#1a0f06;margin-bottom:16px;font-family:Fraunces,Georgia,serif;font-size:18px;font-weight:700}.home-panel-header .home-panel-title{margin-bottom:0}.home-chip{color:#5a4a3a;background:#0000000a;border:1.5px solid #0000001a;border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;display:inline-flex}.home-chip--red{color:#fff;background:#9b1c1c;border-color:#9b1c1c}.home-step{align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.home-step-num{color:#8a7a6a;flex-shrink:0;width:28px;padding-top:2px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.home-step-text{flex-direction:column;gap:3px;display:flex}.home-step-text strong{color:#1a0f06;font-size:14px;font-weight:600}.home-step-text span{color:#6a5a4a;font-size:13px;line-height:1.5}.home-create-table-btn{letter-spacing:1px;color:#9b1c1c;text-transform:uppercase;cursor:pointer;background:0 0;border:none;padding:0;font-family:Inter,sans-serif;font-size:11px;font-weight:700}.home-create-table-btn:hover{text-decoration:underline}.home-tables-empty{color:#8a7a6a;padding:8px 0;font-size:13px}.home-table-row{border-bottom:1px solid #0000000f;justify-content:space-between;align-items:center;padding:12px 0;display:flex}.home-table-info{flex-direction:column;gap:5px;display:flex}.home-table-name{color:#1a0f06;font-size:13.5px;font-weight:600}.home-table-dots{gap:4px;display:flex}.home-table-dot{background:#0000001f;border-radius:50%;width:8px;height:8px}.home-table-dot--filled{background:#9b1c1c}.home-join-btn{cursor:pointer;color:#2d1f0e;background:#fff;border:1.5px solid #00000026;border-radius:999px;padding:6px 16px;font-family:Inter,sans-serif;font-size:12px;font-weight:700;transition:background .15s;box-shadow:2px 2px #0000001a}.home-join-btn:hover{background:#f5edd8}.home-see-all{color:#9b1c1c;margin-top:12px;font-size:12px;text-decoration:none;display:block}.home-see-all:hover{text-decoration:underline}.home-lb-row{border-bottom:1px solid #0000000d;align-items:center;gap:10px;padding:10px 0;display:flex}.home-lb-rank{color:#8a7a6a;flex-shrink:0;width:28px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.home-lb-info{flex-direction:column;gap:1px;width:120px;min-width:0;display:flex}.home-lb-name{color:#1a0f06;text-overflow:ellipsis;white-space:nowrap;font-family:Fraunces,Georgia,serif;font-size:14px;font-weight:600;overflow:hidden}.home-lb-region{color:#8a7a6a;font-size:11px}.home-lb-bar-wrap{background:#00000014;border-radius:99px;flex:1;height:4px;overflow:hidden}.home-lb-bar{height:100%;width:var(--w,0%);background:#9b1c1c;border-radius:99px}.home-lb-wins{color:#3a2a1a;text-align:right;flex-shrink:0;min-width:36px;font-family:JetBrains Mono,monospace;font-size:13px;font-weight:700}.home-tourney-row{border-bottom:1px solid #0000000d;align-items:center;gap:14px;padding:12px 0;display:flex}.home-tourney-date{background:#f0e8d5;border:1px solid #00000014;border-radius:8px;flex-direction:column;flex-shrink:0;align-items:center;min-width:48px;padding:6px 10px;display:flex}.home-tourney-mo{text-transform:uppercase;letter-spacing:1px;color:#8a7a6a;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:700;line-height:1}.home-tourney-day{color:#1a0f06;font-family:Fraunces,Georgia,serif;font-size:22px;font-weight:700;line-height:1.1}.home-tourney-info{flex:1;min-width:0}.home-tourney-name{color:#1a0f06;font-size:14px;font-weight:600}.home-tourney-sub{color:#8a7a6a;margin-top:2px;font-size:11px}.home-footer{color:#8a7a6a;background:#faf6ee;border-top:1px solid #00000012;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:auto;padding:20px 56px;font-size:12px;display:flex}.home-footer-links{align-items:center;gap:10px;display:flex}.home-footer-links a{color:#5a4a3a;font-weight:500;text-decoration:none}.home-footer-links a:hover{text-decoration:underline}.home-private-view{max-width:500px;padding:56px}.home-private-title{color:#1a0f06;margin-bottom:24px;font-family:Fraunces,Georgia,serif;font-size:32px;font-weight:700}.home-back-btn{color:#8a7a6a;cursor:pointer;background:0 0;border:none;margin-bottom:20px;padding:0;font-family:Inter,sans-serif;font-size:13px;display:block}.home-back-btn:hover{color:#1a0f06}.home-private-actions{flex-direction:column;gap:12px;margin-top:4px;display:flex}.home-private-divider{color:#8a7a6a;text-align:center;padding:4px 0;font-size:12px}.home-private-join{gap:8px;display:flex}.home-join-code-input{letter-spacing:6px;text-transform:uppercase;color:#1a0f06;text-align:center;background:#fff;border:1.5px solid #0003;border-radius:10px;outline:none;flex:1;padding:14px 20px;font-family:JetBrains Mono,monospace;font-size:22px}.home-join-code-input:focus{border-color:#9b1c1c;box-shadow:0 0 0 3px #9b1c1c14}.home-error{color:#9b1c1c;padding:4px 0;font-size:13px}.home-settings-panel{z-index:99;background:#faf6ee;border-right:1px solid #00000014;width:300px;padding:0 20px 24px;animation:.18s settings-panel-in;position:fixed;top:0;bottom:0;left:220px;overflow-y:auto;box-shadow:4px 0 24px #0000001f}@keyframes settings-panel-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.home-settings-header{z-index:1;background:#faf6ee;border-bottom:1px solid #00000012;justify-content:space-between;align-items:center;margin-bottom:4px;padding:20px 0 14px;display:flex;position:sticky;top:0}.home-settings-title{color:#1a0f06;font-family:Fraunces,Georgia,serif;font-size:18px;font-weight:700}.home-settings-close{cursor:pointer;color:#8a7a6a;background:0 0;border:none;border-radius:4px;padding:4px 6px;font-family:Inter,sans-serif;font-size:20px;line-height:1;transition:color .15s,background .15s}.home-settings-close:hover{color:#1a0f06;background:#0000000d}.home-settings-panel .settings-page{max-width:100%}.home-settings-panel .settings-row{flex-wrap:wrap;gap:8px}.home-settings-panel .volume-slider{max-width:120px}@media (width<=1100px){.home-stats-row,.home-section-head{padding-left:32px;padding-right:32px}.home-panel{padding:24px 32px}.home-hero{padding:36px 32px}.home-footer{padding:16px 32px}}@media (width<=900px){.home-sidebar{width:180px}.home-hero-heading{font-size:44px}.hcard-fan{display:none}.home-two-col{grid-template-columns:1fr}.home-panel{border-right:none}}@media (width<=640px){.home-sidebar{display:none}.home-hero{padding:28px 20px}.home-stats-row{padding:16px 20px}.home-section-head{padding:20px 20px 10px}.home-panel{padding:20px}.home-footer{padding:16px 20px}.home-main{padding-bottom:68px}.home-bottom-nav{z-index:100;height:60px;padding-bottom:env(safe-area-inset-bottom);background:#f0e8d5;border-top:1px solid #1a0f061a;justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}.home-bottom-nav-item{cursor:pointer;letter-spacing:.5px;text-transform:uppercase;color:#8a7a6a;background:0 0;border:2px solid #0000;border-radius:8px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;margin:6px 4px;padding:6px 8px;font-family:Inter,sans-serif;font-size:10px;font-weight:600;transition:none;display:flex}.home-bottom-nav-ico{font-size:18px;line-height:1}.home-bottom-nav-item--active{color:#fff;background:#9b1c1c;border-color:#7a1515;box-shadow:2px 2px #7a1515}.home-bottom-nav-item:active:not(.home-bottom-nav-item--active){background:#1a0f060d}.home-settings-panel{border-top:1px solid #1a0f061a;border-right:none;width:auto;bottom:60px;left:0;right:0;box-shadow:0 -4px 24px #0000001f}}.play-page-head{background:#f5edd8;border-bottom:1px solid #00000012;padding:48px 56px 32px}.play-page-eyebrow{letter-spacing:2px;text-transform:uppercase;color:#8a7a6a;margin-bottom:10px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;display:block}.play-page-title{color:#1a0f06;margin:0;font-family:Fraunces,Georgia,serif;font-size:48px;font-style:italic;font-weight:700;line-height:1.05}.play-tile-section{background:#f0e8d5;border-bottom:1px solid #00000012;padding:40px 56px}.play-tile-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.play-tile{cursor:pointer;color:inherit;border:1.5px solid #1a0f06;border-radius:18px;flex-direction:column;gap:10px;min-height:280px;padding:28px;text-decoration:none;transition:transform .1s,box-shadow .1s;display:flex;position:relative;box-shadow:4px 4px #1a0f06}.play-tile:not(.play-tile--disabled):hover{transform:translate(2px,2px);box-shadow:2px 2px #1a0f06}.play-tile--red{color:#faf6ee;background:#9b1c1c}.play-tile--navy{color:#faf6ee;background:#1e3a6e}.play-tile--mustard{color:#1a0f06;background:#f0b429}.play-tile--disabled{cursor:default;opacity:.75}.play-tile-glyph{color:#1a0f06;background:#faf6ee;border:2px solid #1a0f06;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;font-family:Fraunces,Georgia,serif;font-size:22px;font-weight:700;display:flex;box-shadow:2px 2px #1a0f06}.play-tile-glyph--dark{color:#f0b429;background:#2d1f0e;border-color:#2d1f0e;box-shadow:2px 2px #2d1f0e}.play-tile-name{letter-spacing:-.01em;margin:0;font-family:Fraunces,Georgia,serif;font-size:26px;font-style:italic;font-weight:600;line-height:1.1}.play-tile-sub{letter-spacing:1.2px;text-transform:uppercase;opacity:.65;margin-top:-4px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.play-tile-desc{opacity:.85;flex:1;font-size:13.5px;line-height:1.55}.play-tile-difficulty{flex-wrap:wrap;align-items:center;gap:5px;margin-top:4px;display:flex}.play-tile-diff-label{opacity:.7;margin-right:2px;font-size:11px}.play-diff-btn{cursor:pointer;color:#faf6ee;background:#ffffff1f;border:1.5px solid #ffffff59;border-radius:5px;padding:3px 9px;font-family:Inter,sans-serif;font-size:11px;font-weight:600;transition:background .12s}.play-diff-btn:hover{background:#ffffff38}.play-diff-btn--active{background:#ffffff47;border-color:#ffffffb3}.play-tile-arrow{letter-spacing:.1em;opacity:.8;margin-top:4px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.play-tile-coming-soon{letter-spacing:1.5px;background:#0000001f;border-radius:4px;align-self:flex-start;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;display:inline-block}.play-private-layout{background:#f0e8d5;padding:40px 56px 56px}.play-private-grid{grid-template-columns:1fr 1fr;gap:16px;max-width:760px;display:grid}.play-private-card{border:1.5px solid #1a0f06;border-radius:18px;flex-direction:column;gap:14px;min-height:280px;padding:28px;display:flex;box-shadow:3px 3px #1a0f06}.play-private-card--navy{color:#f5edd8;background:#1e3a6e}.play-private-card--paper{color:#1a0f06;background:#f5edd8}.play-private-btn{color:#1a0f06;letter-spacing:.05em;cursor:pointer;background:#f5edd8;border:1.5px solid #1a0f06;border-radius:10px;width:100%;margin-top:auto;padding:14px 24px;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;transition:transform .1s,box-shadow .1s;box-shadow:3px 3px #1a0f06}.play-private-btn:hover:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px #1a0f06}.play-private-btn:disabled{opacity:.38;cursor:default}.play-private-btn--dark{color:#f5edd8;background:#1a0f06;border-color:#1a0f06;box-shadow:3px 3px #0006}.play-private-btn--dark:hover:not(:disabled){box-shadow:1px 1px #0006}.play-private-code-row{flex-direction:column;gap:10px;display:flex}@media (width<=1100px){.play-tile-section{padding:32px}.play-page-head{padding:36px 32px 24px}}@media (width<=860px){.play-tile-grid{grid-template-columns:1fr}.play-tile{min-height:auto}}@media (width<=640px){.play-page-head{padding:24px 20px 20px}.play-page-title{font-size:36px}.play-tile-section{padding:20px}.play-private-layout{padding:24px 20px 40px}.play-private-grid{grid-template-columns:1fr}}.tbl-live-chip{color:#fff;letter-spacing:.04em;vertical-align:middle;background:#9b1c1c;border-radius:999px;align-items:center;margin-left:8px;padding:1px 8px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.tbl-filters{background:#f0e8d5;border-bottom:1px solid #1a0f061a;flex-wrap:wrap;align-items:center;gap:8px;padding:16px 56px;display:flex}.tbl-filter-chip{color:#1a0f06;cursor:pointer;letter-spacing:.04em;background:0 0;border:1.5px solid #1a0f06;border-radius:999px;align-items:center;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:500;transition:background .1s,color .1s;display:inline-flex}.tbl-filter-chip--active{color:#f5edd8;background:#1a0f06}.tbl-filter-chip:not(.tbl-filter-chip--active):hover{background:#1a0f060f}.tbl-new-btn{color:#fff;cursor:pointer;letter-spacing:.04em;background:#9b1c1c;border:1.5px solid #6b1212;border-radius:8px;align-items:center;padding:5px 14px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;transition:transform .1s,box-shadow .1s;display:inline-flex;box-shadow:2px 2px #6b1212}.tbl-new-btn:hover{transform:translate(1px,1px);box-shadow:1px 1px #6b1212}.tbl-grid{background:#f0e8d5;grid-template-columns:repeat(2,1fr);gap:14px;padding:32px 56px 56px;display:grid}.tbl-empty{text-align:center;color:#8a7a6a;letter-spacing:.05em;grid-column:1/-1;padding:48px 0;font-family:JetBrains Mono,monospace;font-size:12px}.tbl-card{background:#f5edd8;border:1.5px solid #1a0f06;border-radius:12px;flex-direction:column;gap:10px;padding:18px;display:flex;box-shadow:2px 2px #1a0f06}.tbl-card-top{justify-content:space-between;align-items:center;display:flex}.tbl-card-name{color:#1a0f06;margin:0;font-family:Fraunces,Georgia,serif;font-size:22px;font-style:italic;font-weight:600;line-height:1.1}.tbl-card-eyebrow{text-transform:uppercase;letter-spacing:.1em;color:#8a7a6a;font-family:JetBrains Mono,monospace;font-size:10px}.tbl-card-footer{justify-content:space-between;align-items:center;display:flex}.tbl-card-seats{gap:5px;display:flex}.tbl-seat{background:#d4c9b0;border:1.5px solid #1a0f06;border-radius:50%;width:18px;height:18px}.tbl-seat--taken{background:#9b1c1c}.tbl-card-count{color:#8a7a6a;letter-spacing:.06em;font-family:JetBrains Mono,monospace;font-size:11px}.tbl-card-btn{color:#fff;cursor:pointer;letter-spacing:.04em;background:#9b1c1c;border:1.5px solid #6b1212;border-radius:8px;align-self:flex-start;padding:7px 14px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:700;transition:transform .1s,box-shadow .1s;box-shadow:2px 2px #6b1212}.tbl-card-btn:hover{transform:translate(1px,1px);box-shadow:1px 1px #6b1212}.tbl-card-btn--full{color:#8a7a6a;box-shadow:none;cursor:default;background:0 0;border-color:#1a0f0640}.tbl-card-btn--full:hover{box-shadow:none;transform:none}@media (width<=860px){.tbl-grid{grid-template-columns:1fr;padding:24px 32px 40px}.tbl-filters{padding:14px 32px}}@media (width<=640px){.tbl-grid{gap:12px;padding:20px}.tbl-filters{padding:12px 20px}.tbl-card-name{font-size:18px}}.game-shell{--gs-paper:#f6efdc;--gs-paper-2:#efe5cc;--gs-paper-3:#e6d8b3;--gs-ink:#1a1410;--gs-ink-soft:#4a3f33;--gs-ink-faint:#8a7c69;--gs-red:#b8323c;--gs-red-deep:#8a2530;--gs-navy:#1f3a6b;--gs-mustard:#e6a93c;--gs-cream:#fdf6e3;--paper:var(--gs-paper);--paper-2:var(--gs-paper-2);--paper-3:var(--gs-paper-3);--ink:var(--gs-ink);--ink-soft:var(--gs-ink-soft);--ink-faint:var(--gs-ink-faint);--red:var(--gs-red);--red-deep:var(--gs-red-deep);--navy:var(--gs-navy);--mustard:var(--gs-mustard);--cream:var(--gs-cream);background:var(--gs-paper);width:100vw;height:100vh;color:var(--gs-ink);grid-template-rows:56px 1fr;grid-template-columns:1fr 280px;font-family:Fraunces,Georgia,serif;display:grid;overflow:hidden}.game-top{border-bottom:1.5px solid var(--ink);background:var(--paper-2);grid-column:1/-1;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex}.game-top-left,.game-top-right{align-items:center;gap:14px;display:flex}.game-shell .brand-mark{background:var(--red);width:36px;height:36px;color:var(--cream);border:2px solid var(--ink);box-shadow:2px 2px 0 var(--ink);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;font-family:Fraunces,serif;font-size:16px;font-style:italic;font-weight:700;display:flex}.game-shell .chip{border:1.5px solid var(--ink);background:var(--cream);letter-spacing:.04em;color:var(--ink);border-radius:999px;align-items:center;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:11px;display:inline-flex}.game-shell .chip.mustard{background:var(--mustard)}.game-shell .eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:11px}.game-shell .btn{border:2px solid var(--ink);background:var(--cream);color:var(--ink);cursor:pointer;box-shadow:2px 2px 0 var(--ink);border-radius:999px;justify-content:center;align-items:center;gap:6px;padding:6px 14px;font-family:Fraunces,serif;font-size:13px;font-weight:600;transition:transform 80ms,box-shadow 80ms;display:inline-flex}.game-shell .btn:hover:not(:disabled){box-shadow:1px 1px 0 var(--ink);transform:translate(1px,1px)}.game-shell .btn:active:not(:disabled){box-shadow:none;transform:translate(2px,2px)}.game-shell .btn:disabled{opacity:.4;cursor:default}.game-shell .btn.ghost{box-shadow:none;border-color:var(--ink-faint);background:0 0}.game-shell .btn.primary{background:var(--red);color:var(--cream);border-color:var(--red-deep);box-shadow:2px 2px 0 var(--red-deep)}.game-shell .btn.primary:hover:not(:disabled){box-shadow:1px 1px 0 var(--red-deep)}.game-shell .felt{background:radial-gradient(#1f4a36 0%,#143027 60%,#0e2419 100%);position:relative;overflow:hidden}.game-shell .felt:before{content:"";pointer-events:none;z-index:0;border:2px dashed #e6d9b82e;border-radius:50%/40%;position:absolute;inset:24px}.game-shell .felt:after{content:"★";color:#e6a93c0d;pointer-events:none;z-index:0;font-size:260px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.game-shell .player{color:var(--cream);z-index:2;align-items:center;gap:8px;font-family:Fraunces,serif;display:flex;position:absolute}.game-shell .player.top{flex-direction:column;top:16px;left:50%;transform:translate(-50%)}.game-shell .player.left{flex-direction:column;top:44%;left:14px;transform:translateY(-50%)}.game-shell .player.right{flex-direction:column;top:44%;right:14px;transform:translateY(-50%)}.game-shell .player .name{text-shadow:0 1px 2px #00000080;text-align:center;font-size:15px;font-style:italic;font-weight:600}.game-shell .player .meta{letter-spacing:.1em;opacity:.65;text-align:center;font-family:JetBrains Mono,monospace;font-size:9px}.game-shell .player.player-passed{opacity:.5}.game-shell .avatar{border:2.5px solid var(--cream);background:var(--mustard);color:var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:Fraunces,serif;font-style:italic;font-weight:700;display:flex;position:relative;box-shadow:0 0 0 3px #0003}.game-shell .avatar.partner{background:var(--mustard)}.game-shell .avatar.opp{background:var(--paper-2);color:var(--ink)}.game-shell .avatar.you{background:var(--red);color:var(--cream);border-color:var(--mustard)}.game-shell .avatar.avatar-active{animation:1.8s ease-in-out infinite gs-avatar-pulse}.game-shell .avatar.avatar-passed{opacity:.3;filter:grayscale()}@keyframes gs-avatar-pulse{0%,to{box-shadow:0 0 0 3px #0003,0 0 0 6px #e6a93c4d}50%{box-shadow:0 0 0 3px #0003,0 0 0 9px #e6a93c80}}.game-shell .team-badge{border:2px solid var(--ink);border-radius:50%;justify-content:center;align-items:center;width:17px;height:17px;font-family:JetBrains Mono,monospace;font-size:8px;font-style:normal;font-weight:700;line-height:1;display:flex;position:absolute;top:-5px;right:-5px}.game-shell .team-badge.team-a{background:var(--red);color:var(--cream)}.game-shell .team-badge.team-b{background:var(--navy);color:var(--cream)}.game-shell .stack{gap:2px;margin-top:6px;display:flex}.game-shell .mini-back{border:1px solid var(--ink);background:repeating-linear-gradient(45deg, var(--red) 0 3px, var(--red-deep) 3px 6px);border-radius:3px;width:18px;height:26px;display:inline-block}.game-shell .stack.h .mini-back{width:26px;height:18px}.game-shell .center-info{z-index:5;pointer-events:none;flex-direction:column;align-items:center;gap:12px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.game-shell .center-info>*{pointer-events:auto}.game-shell .deal-status{color:var(--cream);letter-spacing:.18em;background:#00000080;border:1.5px dashed #e6d9b84d;border-radius:999px;padding:5px 14px;font-family:JetBrains Mono,monospace;font-size:10px}.game-shell .trump-pill{background:var(--cream);border:2px solid var(--ink);color:var(--ink);border-radius:999px;align-items:center;gap:8px;padding:5px 14px 5px 7px;font-family:Fraunces,serif;font-size:15px;font-style:italic;font-weight:600;display:flex;box-shadow:3px 3px #0006}.game-shell .trump-pill .badge{width:26px;height:26px;color:var(--cream);border:1.5px solid var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-style:normal;font-weight:700;display:flex}.game-shell .trump-pill .tp-label{letter-spacing:.18em;color:var(--ink-faint);font-family:JetBrains Mono,monospace;font-size:9px;font-style:normal;font-weight:500}.game-shell .trick-grid{flex-direction:column;align-items:center;gap:3px;display:flex}.game-shell .trick-row-mid{align-items:center;gap:6px;display:flex}.game-shell .trick-slot{border:1.5px dashed #e6d9b833;border-radius:8px;justify-content:center;align-items:center;width:72px;height:104px;display:flex}.game-shell .tricks-count{text-align:center;color:#e6d9b899;width:36px;font-family:JetBrains Mono,monospace;font-size:13px}.game-shell .trump-select-panel{background:var(--cream);border:2px solid var(--ink);box-shadow:3px 3px 0 var(--ink);border-radius:14px;flex-direction:column;gap:10px;min-width:200px;padding:14px;display:flex}.game-shell .trump-buttons{gap:6px;display:flex}.game-shell .trump-btn{border:2px solid var(--ink);cursor:pointer;background:var(--cream);box-shadow:2px 2px 0 var(--ink);border-radius:10px;flex:1;padding:10px 4px;font-family:Fraunces,serif;font-size:24px;transition:transform 80ms,box-shadow 80ms}.game-shell .trump-btn:hover{box-shadow:1px 1px 0 var(--ink);transform:translate(1px,1px)}.game-shell .trump-btn.red{color:var(--red)}.game-shell .trump-btn.black{color:var(--ink)}.game-shell .you-label{color:var(--cream);text-shadow:0 1px 2px #00000080;z-index:2;white-space:nowrap;align-items:center;gap:10px;font-family:Fraunces,serif;font-size:15px;font-style:italic;font-weight:600;display:flex;position:absolute;bottom:162px;left:50%;transform:translate(-50%)}.game-shell .you-label .meta{letter-spacing:.1em;opacity:.7;font-family:JetBrains Mono,monospace;font-size:9px;font-style:normal;font-weight:400}.game-shell .your-hand{z-index:3;align-items:flex-end;padding-bottom:0;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.game-shell .your-hand .card-art{cursor:default;margin:0 -14px;transition:transform .18s cubic-bezier(.2,.9,.3,1.2),margin .18s}.game-shell .your-hand .card-art:hover{margin:0 6px;z-index:99!important;transform:translateY(-28px)scale(1.07)!important;box-shadow:5px 10px #0006!important}.game-shell .card-art{border:2px solid var(--ink);background:var(--cream);-webkit-user-select:none;user-select:none;border-radius:10px;flex-direction:column;flex-shrink:0;justify-content:space-between;width:92px;height:132px;padding:7px 9px;font-family:Fraunces,serif;font-weight:700;display:flex;position:relative;box-shadow:2px 3px #1a141047}.game-shell .card-art .corner{flex-direction:column;align-self:flex-start;align-items:flex-start;gap:1px;font-size:17px;font-style:normal;font-weight:700;line-height:1;display:flex}.game-shell .card-art .suit-corner{font-size:11px;line-height:1}.game-shell .card-art .corner.br{align-self:flex-end;transform:rotate(180deg)}.game-shell .card-art.red{color:var(--red)}.game-shell .card-art.black{color:var(--ink)}.game-shell .card-art.back{background:repeating-linear-gradient(45deg, var(--red) 0 6px, var(--red-deep) 6px 12px);border-color:var(--ink)}.game-shell .card-art.back:after{content:"★";color:var(--mustard);text-shadow:0 0 8px #0006;justify-content:center;align-items:center;font-size:30px;display:flex;position:absolute;inset:0}.game-shell .card-art.playable{cursor:pointer;outline:2.5px solid var(--mustard);outline-offset:2px}.game-shell .card-art.card-sm{width:66px;height:96px;padding:5px 7px}.game-shell .card-art.card-sm .corner{font-size:13px}.game-shell .card-art.card-sm .suit-corner{font-size:9px}.game-shell .card-art.card-sm .card-face{font-size:14px;inset:20px 7px}.game-shell .card-art.card-sm .card-face .ace-pip{font-size:2em}.game-shell .card-art.card-sm .card-royal{inset:20px 6px}.game-shell .card-art.card-sm .card-royal .royal-letter{font-size:1.9em}.game-shell .card-art.card-sm .card-royal .suit-mini{font-size:.9em}.game-shell .card-face{font-size:18px;line-height:1;position:absolute;inset:26px 8px}.game-shell .card-face .pip{line-height:1;display:inline-block;position:absolute;transform:translate(-50%,-50%)}.game-shell .card-face .pip.flip{transform:translate(-50%,-50%)rotate(180deg)}.game-shell .card-face .ace-pip{font-size:2.4em;line-height:1;position:absolute;transform:translate(-50%,-50%)}.game-shell .card-royal{background:repeating-linear-gradient(45deg,#0000 0 6px,#00000008 6px 7px);border:1.5px solid;border-radius:5px;justify-content:center;align-items:center;display:flex;position:absolute;inset:26px 7px}.game-shell .card-royal .royal-letter{font-family:Fraunces,serif;font-size:2.4em;font-style:italic;font-weight:700;line-height:1}.game-shell .card-royal .suit-mini{font-size:1.1em;font-style:normal;font-weight:400;line-height:1;position:absolute}.game-shell .card-royal .suit-mini.tl{top:5px;left:6px}.game-shell .card-royal .suit-mini.br{bottom:5px;right:6px;transform:rotate(180deg)}.game-shell .right-rail{background:var(--paper-2);border-left:1.5px solid var(--ink);grid-template-rows:auto 1fr;min-height:0;display:grid;overflow:hidden}.game-shell .right-rail-stats{flex-direction:column;gap:14px;padding:16px 16px 0;display:flex;overflow-y:auto}.game-shell .panel-title{letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:9px}.game-shell .scoreboard{background:var(--cream);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);-webkit-backdrop-filter:none;border-radius:12px;padding:14px;display:block;position:static;overflow:visible}.game-shell .score-row{grid-template-columns:22px 1fr auto;align-items:center;gap:10px;padding:8px 0;display:grid}.game-shell .score-row+.score-row{border-top:1px dashed var(--ink-faint)}.game-shell .team-dot{border:1.5px solid var(--ink);border-radius:50%;flex-shrink:0;width:14px;height:14px}.game-shell .team-dot.a{background:var(--red)}.game-shell .team-dot.b{background:var(--navy)}.game-shell .team-name-col{flex-direction:column;gap:2px;min-width:0;display:flex;overflow:hidden}.game-shell .score-team-name{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-family:Fraunces,serif;font-size:15px;font-style:italic;font-weight:600;line-height:1.1;overflow:hidden}.game-shell .score-team-sub{letter-spacing:.08em;color:var(--ink-faint);white-space:nowrap;text-overflow:ellipsis;font-family:JetBrains Mono,monospace;font-size:9px;overflow:hidden}.game-shell .pts{flex-shrink:0;font-family:Fraunces,serif;font-size:28px;font-style:italic;font-weight:700;line-height:1}.game-shell .pts.team-a{color:var(--red)}.game-shell .pts.team-b{color:var(--navy)}.game-shell .progress{background:var(--paper-3);border:1px solid var(--ink);border-radius:999px;height:7px;margin-top:10px;display:flex;overflow:hidden}.game-shell .seg-a{background:var(--red)}.game-shell .seg-b{background:var(--navy)}.game-shell .deal-banner{background:var(--red);color:var(--cream);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);border-radius:10px;padding:10px 14px}.game-shell .banner-label{letter-spacing:.18em;opacity:.85;text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:8px}.game-shell .banner-val{margin-top:2px;font-family:Fraunces,serif;font-size:19px;font-style:italic;font-weight:600;line-height:1.15}.game-shell .ready-panel{background:var(--cream);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);border-radius:12px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.game-shell .bid-tracker{background:var(--cream);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);border-radius:12px;padding:12px 14px}.game-shell .bid-log{flex-direction:column;gap:3px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.game-shell .bid-log-row{border-radius:6px;justify-content:space-between;align-items:center;padding:4px 6px;display:flex}.game-shell .bid-log-row.pass{color:var(--ink-faint)}.game-shell .bid-log-row.win{background:var(--mustard);border:1.5px solid var(--ink);font-weight:700}.game-shell .bid-log-row.stale{opacity:.45}.game-shell .bid-log-name{letter-spacing:.04em;font-weight:700}.game-shell .bid-log-amount{font-variant-numeric:tabular-nums}.game-shell .bid-log-empty{align-items:center;gap:8px;padding:4px 6px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.game-shell .bid-log-dealer{font-weight:700}.game-shell .bid-log-label{color:var(--ink-faint);font-style:italic}.game-shell .bid-panel{background:var(--cream);border:1.5px solid var(--ink);box-shadow:2px 2px 0 var(--ink);border-radius:12px;flex-direction:column;gap:10px;padding:12px 14px;display:flex}.game-shell .bid-stepper{align-items:center;gap:8px;display:flex}.game-shell .bid-step-btn{border:2px solid var(--ink);background:var(--cream);cursor:pointer;width:36px;height:36px;box-shadow:2px 2px 0 var(--ink);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-family:Fraunces,serif;font-size:20px;font-weight:700;line-height:1;transition:transform 80ms,box-shadow 80ms;display:flex}.game-shell .bid-step-btn:hover:not(:disabled){box-shadow:1px 1px 0 var(--ink);transform:translate(1px,1px)}.game-shell .bid-step-btn:disabled{opacity:.28;cursor:default;box-shadow:none}.game-shell .bid-value-box{text-align:center;background:var(--paper-3);border:1.5px solid var(--ink);border-radius:8px;flex:1;padding:7px 8px}.game-shell .bid-value-display{color:var(--ink);font-family:Fraunces,serif;font-size:30px;font-style:italic;font-weight:700;line-height:1}.game-shell .bid-range-label{letter-spacing:.14em;color:var(--ink-faint);margin-top:2px;font-family:JetBrains Mono,monospace;font-size:8px}.game-shell .bid-slider{width:100%;accent-color:var(--red);cursor:pointer}.game-shell .bid-actions{gap:6px;display:flex}.game-shell .bid-actions .btn{flex:1;justify-content:center}.game-shell .bid-actions .btn.primary{flex:2}.game-shell .game-log{background:var(--cream);border:1.5px dashed var(--ink-faint);-webkit-backdrop-filter:none;border-radius:12px;flex-direction:column;min-height:0;margin:14px 16px 16px;padding:12px 14px;display:flex;overflow:hidden}.game-shell .log-header{flex-shrink:0;margin-bottom:8px}.game-shell .log-title{letter-spacing:.16em;color:var(--ink-faint);text-transform:uppercase;font-family:JetBrains Mono,monospace;font-size:9px}.game-shell .log-list{scrollbar-width:thin;scrollbar-color:var(--ink-faint) transparent;flex:1;overflow-y:auto}.game-shell .log-list li{color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:10px;line-height:1.6}.game-shell .log-list li.log-latest{color:var(--ink);font-weight:600}.game-shell .debug-btn{background:var(--paper-3);color:var(--ink-soft);border:1px solid var(--ink-faint);cursor:pointer;border-radius:6px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:10px}.game-shell .debug-btn:hover{background:var(--mustard);color:var(--ink)}.game-shell .debug-btn.debug-btn-active{background:var(--navy);color:var(--cream);border-color:var(--ink)}.game-shell .reset-btn{background:var(--paper-3);color:var(--red);border:1px solid var(--red);cursor:pointer;border-radius:6px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:10px}.game-shell .reset-btn:hover{background:var(--red);color:var(--cream)}.game-shell .mobile-game{display:none}.game-shell .game-top-m{background:var(--paper-2);border-bottom:1.5px solid var(--ink);flex:none;justify-content:space-between;align-items:center;padding:8px 14px;display:flex}.game-shell .felt-m{background:radial-gradient(at top,#1f4a36 0%,#143027 60%,#0e2419 100%);flex-direction:column;flex:1;min-height:0;display:flex;position:relative;overflow:clip hidden}.game-shell .felt-m:before{content:"";pointer-events:none;z-index:0;border:2px dashed #e6d9b82e;border-radius:50%/35%;position:absolute;inset:14px 14px 200px}.game-shell .opp-row{z-index:1;flex:none;justify-content:space-between;gap:8px;padding:10px 12px 0;display:flex;position:relative}.game-shell .opp-chip{color:var(--cream);background:#0000006b;border:1.5px solid #fdf6e3d9;border-radius:999px;align-items:center;gap:6px;padding:4px 8px 4px 4px;display:flex}.game-shell .opp-chip.right{flex-direction:row-reverse;padding:4px 4px 4px 8px}.game-shell .opp-chip .av{background:var(--paper-2);width:26px;height:26px;color:var(--ink);border:1.5px solid var(--ink);border-radius:50%;flex:none;justify-content:center;align-items:center;font-family:Fraunces,serif;font-size:12px;font-style:italic;font-weight:700;display:flex}.game-shell .opp-chip .nm{font-family:Fraunces,serif;font-size:12px;font-style:italic;font-weight:600;line-height:1}.game-shell .opp-chip .cnt{letter-spacing:.08em;opacity:.75;margin-top:2px;font-family:JetBrains Mono,monospace;font-size:9px;line-height:1}.game-shell .opp-chip.right .nm,.game-shell .opp-chip.right .cnt{text-align:right}.game-shell .partner-row{z-index:1;flex-direction:column;flex:none;align-items:center;gap:4px;padding:10px 0 4px;display:flex;position:relative}.game-shell .partner-row .av{background:var(--mustard);width:36px;height:36px;color:var(--ink);border:2px solid var(--cream);box-shadow:0 0 0 2px var(--ink);border-radius:50%;justify-content:center;align-items:center;font-family:Fraunces,serif;font-size:14px;font-style:italic;font-weight:700;display:flex}.game-shell .partner-row .lbl{color:var(--cream);font-family:Fraunces,serif;font-size:11px;font-style:italic;font-weight:600}.game-shell .partner-row .stk{flex-wrap:wrap;justify-content:center;gap:2px;max-width:160px;display:flex}.game-shell .partner-row .mb{background:repeating-linear-gradient(45deg, var(--red) 0 3px, var(--red-deep) 3px 6px);border:1px solid #00000080;border-radius:2px;width:10px;height:16px}.game-shell .center-row-m{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;min-height:0;padding:4px 16px;display:flex;position:relative}.game-shell .center-row-m .deal-status{color:var(--cream)!important;letter-spacing:.18em!important;background:#0000008c!important;border:1.5px dashed #e6d9b852!important;border-radius:999px!important;padding:4px 12px!important;font-size:9px!important}.game-shell .center-row-m .trump-pill{border-radius:999px;padding:4px 12px 4px 4px;font-size:13px;box-shadow:2px 2px #0006}.game-shell .center-row-m .trump-pill .badge{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:inline-flex}.game-shell .center-row-m .trick-grid{transform:scale(.85)}.game-shell .score-strip-m{z-index:1;flex:none;gap:6px;padding:6px 10px 0;display:flex;position:relative}.game-shell .score-strip-m .sc{background:var(--cream);border:1.5px solid var(--ink);border-radius:8px;flex:1;align-items:center;gap:8px;padding:5px 10px;display:flex;box-shadow:1.5px 1.5px #0006}.game-shell .score-strip-m .dot{border:1.5px solid var(--ink);border-radius:50%;flex:none;width:10px;height:10px}.game-shell .score-strip-m .nm{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-family:Fraunces,serif;font-size:11px;font-style:italic;font-weight:600;line-height:1;overflow:hidden}.game-shell .score-strip-m .pt{flex-shrink:0;font-family:Fraunces,serif;font-size:18px;font-style:italic;font-weight:700;line-height:1}.game-shell .you-strip-m{z-index:1;flex:none;justify-content:center;align-items:center;gap:6px;padding:4px 0 0;display:flex;position:relative}.game-shell .you-strip-m .av{background:var(--red);width:20px;height:20px;color:var(--cream);border:1.5px solid var(--mustard);border-radius:50%;justify-content:center;align-items:center;font-family:Fraunces,serif;font-size:8px;font-style:italic;font-weight:700;display:flex}.game-shell .you-strip-m .lbl{letter-spacing:.16em;color:var(--cream);text-shadow:0 1px 2px #0000008c;font-family:JetBrains Mono,monospace;font-size:9px}.game-shell .bid-info-m{z-index:1;flex:none;justify-content:center;align-items:center;gap:8px;padding:4px 12px 0;display:flex;position:relative}.game-shell .bid-info-m .bi-winner{background:var(--mustard);border:1.5px solid var(--ink);letter-spacing:.08em;color:var(--ink);border-radius:999px;padding:3px 10px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;box-shadow:1.5px 1.5px #00000059}.game-shell .bid-info-m .bi-label{letter-spacing:.14em;color:#fdf6e399;font-family:JetBrains Mono,monospace;font-size:8px}.game-shell .hand-grid-m{z-index:2;flex:none;justify-content:center;align-items:center;padding:6px 8px 2px;display:flex;position:relative}.game-shell .hand-grid-m .your-hand{flex-wrap:wrap;justify-content:center;align-items:flex-start;gap:4px;max-width:360px;display:flex;position:relative;bottom:auto;left:auto;transform:none}.game-shell .hand-grid-m .your-hand .card-art{flex-shrink:0;width:62px;height:90px;margin:0;transform:none!important}.game-shell .hand-grid-m .your-hand .card-art .corner{font-size:13px}.game-shell .hand-grid-m .your-hand .card-art .card-face{font-size:13px;inset:18px 6px}.game-shell .hand-grid-m .your-hand .card-art .card-face .ace-pip{font-size:2em}.game-shell .hand-grid-m .your-hand .card-art .card-royal{inset:18px 5px}.game-shell .hand-grid-m .your-hand .card-art .card-royal .royal-letter{font-size:1.8em}.game-shell .hand-grid-m .your-hand .card-art .card-royal .suit-mini{font-size:.85em}.game-shell .hand-grid-m .your-hand .card-art:hover{z-index:10!important;transform:translateY(-10px)scale(1.08)!important;box-shadow:3px 6px #00000059!important}.game-shell .actions-m{background:var(--paper-2);border-top:1.5px solid var(--ink);padding:10px 12px;padding-bottom:max(10px, env(safe-area-inset-bottom));z-index:1;flex:none;grid-template-columns:1fr auto 1fr;gap:8px;display:grid;position:relative}.game-shell .actions-m.single{grid-template-columns:1fr}.game-shell .actions-m .pass,.game-shell .actions-m .bid{width:100%;font-size:13px}.game-shell .actions-m .stepper{background:var(--cream);border:1.5px solid var(--ink);border-radius:999px;align-items:center;gap:6px;padding:3px 4px;display:flex}.game-shell .actions-m .stepper button{border:1.5px solid var(--ink);background:var(--paper);cursor:pointer;border-radius:50%;width:28px;height:28px;padding:0;font-family:JetBrains Mono,monospace;font-size:15px;line-height:1}.game-shell .actions-m .stepper button:disabled{opacity:.4;cursor:not-allowed}.game-shell .actions-m .stepper .v{text-align:center;min-width:26px;font-family:JetBrains Mono,monospace;font-size:13px}@media (width<=760px){.game-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.game-shell .game-top,.game-shell .felt,.game-shell .right-rail{display:none}.game-shell .mobile-game{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}}
