@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/b2ea385cb5ae8625-s.0kjod.kaq1k69.woff2?dpl=dpl_D99Deade8Kqdp1ZgVJWKVCztyynJ)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Outfit;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1b99372b3eaef0c8-s.p.0gx2haw2tmll8.woff2?dpl=dpl_D99Deade8Kqdp1ZgVJWKVCztyynJ)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Outfit Fallback;src:local(Arial);ascent-override:100.18%;descent-override:26.05%;line-gap-override:0.0%;size-adjust:99.82%}.outfit_9edc4f9a-module__h4ISCa__className{font-family:Outfit,Outfit Fallback;font-style:normal}
:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:#faf8f3;--panel:#fff;--panel-2:#f7f3ec;--text:#1a1610;--muted:#5e5244;--accent:#8a6a1a;--accent-2:#1f8a80;--border:#1a16102e}*{box-sizing:border-box}html,body{min-height:100%;color:var(--text);background:radial-gradient(circle at top,#c49a381a,#0000 40%),linear-gradient(#faf8f3 0%,#f5f0e8 100%);margin:0;font-family:inherit}a{color:inherit;text-decoration:none}main{max-width:1120px;margin:0 auto;padding:32px 20px 56px}.shell{gap:20px;display:grid}.hero{border:1px solid var(--border);background:#fff;border-radius:8px;gap:12px;padding:28px;display:grid;box-shadow:0 4px 24px #1a161012}.eyebrow{letter-spacing:.18em;text-transform:uppercase;color:var(--accent-2);font-size:.75rem}.title{margin:0;font-size:clamp(2rem,5vw,4rem);line-height:.95}.lede{color:var(--muted);max-width:62ch;margin:0;line-height:1.55}.grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.card{border:1px solid var(--border);background:#fff;border-radius:8px;gap:10px;padding:18px;display:grid}.card h2,.card h3{margin:0}.card p{color:var(--muted);margin:0;line-height:1.5}.actions{flex-wrap:wrap;gap:12px;display:flex}.button{min-height:44px;color:var(--text);cursor:pointer;background:linear-gradient(#dfb85b47,#dfb85b29);border:1px solid #8a6a1a73;border-radius:8px;justify-content:center;align-items:center;padding:0 16px;font-weight:700;display:inline-flex}.button.secondary{background:#1a161014;border-color:#1a16102e}.button.danger{color:#fff;background:#c0392b}.button.danger:hover{background:#a93226}.reset-zone{border-top:1px solid #1a16101a;padding-top:10px}.reset-confirm-text{opacity:.7;margin-bottom:8px;font-size:.88rem}.reset-confirm-actions{gap:8px;display:flex}.button:disabled,.tile-button:disabled,select:disabled{cursor:not-allowed;opacity:.55}.stack{gap:10px;display:grid}.mono{color:var(--accent);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}form{gap:12px;display:grid}input{border:1px solid var(--border);width:100%;min-height:46px;color:var(--text);background:#1a16100a;border-radius:8px;padding:0 14px;font-size:16px}select{border:1px solid var(--border);width:100%;min-height:44px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px;font-size:16px}.note{color:var(--muted);font-size:.95rem;line-height:1.5}.phone-layout{grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr);align-items:start;gap:16px;display:grid}.hand-panel{align-content:start}.tile-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px;display:grid}.tile-button{border:1px solid var(--border);min-height:92px;color:var(--text);font:inherit;cursor:pointer;background:linear-gradient(#fffffff5,#f4ede0f2);border-radius:14px;align-items:stretch;padding:2px;font-weight:700;line-height:1.15;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;display:grid;box-shadow:0 8px 18px #1a161014,inset 0 1px #ffffffe6}.tile-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #1a16101f,inset 0 1px #ffffffe6}.tile-button.selected{background:linear-gradient(#c8f2eefc,#a8e8e2f7);border-color:#1f8a80;transform:translateY(-2px);box-shadow:0 12px 28px #1f8a8047,inset 0 0 0 1px #1f8a8066}.tile-button.is-newly-drawn{background:linear-gradient(#fff8dcfc,#faebb4f7);border-color:#8a6a1acc;animation:1.8s ease-in-out 3 newly-drawn-pulse;box-shadow:0 10px 22px #8a6a1a38,0 0 0 2px #c49a3880,inset 0 1px #ffffffe6}@keyframes newly-drawn-pulse{0%,to{box-shadow:0 10px 22px #8a6a1a38,0 0 0 2px #c49a3880,inset 0 1px #ffffffe6}50%{box-shadow:0 12px 28px #8a6a1a57,0 0 0 4px #c49a3861,inset 0 1px #ffffffe6}}.tile-button.is-newly-drawn.selected{background:linear-gradient(#c8f2eefc,#a8e8e2f7);border-color:#1f8a80;animation:none;box-shadow:0 12px 28px #1f8a8047,inset 0 0 0 1px #1f8a8066}@media (prefers-reduced-motion:reduce){.tile-button.is-newly-drawn{animation:none}}.tile-face{background:0 0;border-radius:10px;justify-content:center;align-items:center;width:100%;height:100%;display:flex;overflow:hidden}.tile-face-image{object-fit:contain;width:100%;height:100%}.tile-face--hand .tile-face-image{transform:scale(1.24)}.tile-face--fallback{padding:8px}.tile-face-fallback{text-align:center;justify-content:center;align-items:center;width:100%;height:100%;font-size:.82rem;font-weight:700;line-height:1.2;display:flex}.tile-face--chip{background:0 0;border-radius:999px;gap:8px;width:auto;min-width:0;height:auto;overflow:visible}.tile-face--chip .tile-face-image,.tile-face--chip .tile-face-fallback{background:linear-gradient(#fffffffa,#f4ede0fa);border-radius:6px;flex:none;width:28px;height:38px;box-shadow:0 3px 8px #1a16101f}.tile-face--chip.tile-face--fallback{padding:0}.tile-face-caption{color:var(--muted);white-space:nowrap;font-size:.8rem;font-weight:600}.action-list{grid-template-columns:1fr;gap:10px;display:grid}.compact{gap:6px}.seat-number,.badge{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.badge{color:var(--accent);border:1px solid #dfb85b73;border-radius:6px;justify-self:end;padding:4px 7px}.event-log{max-height:300px;overflow-y:auto}.score-card{background:linear-gradient(160deg,#dfb85b21,#dfb85b0a);border:1px solid #dfb85b8c;border-radius:12px;gap:14px;padding:28px;display:grid;box-shadow:0 4px 40px #dfb85b24}.score-card h2{margin:0}.score-card p{color:var(--muted);margin:0;line-height:1.5}.score-winner{color:var(--accent);margin:0;font-size:clamp(1.6rem,4vw,2.6rem);font-weight:800;line-height:1.1}.score-result{color:var(--muted);margin:0;font-size:1rem}.score-breakdown{border-top:1px solid var(--border);gap:5px;padding-top:10px;display:grid}.score-breakdown p{font-size:.9rem}.start-hint{color:var(--muted);margin:0;font-size:.875rem;line-height:1.4}.player-count{border:1px solid var(--border);color:var(--muted);border-radius:20px;align-items:center;gap:6px;padding:5px 10px;font-size:.875rem;display:inline-flex}.player-count strong{color:var(--accent)}.connect-dot{background:var(--muted);opacity:.5;border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.connect-dot.connected{opacity:1;background:#16a34a}.status-badge{border:1px solid;border-radius:20px;align-items:center;padding:2px 8px;font-size:.72rem;font-weight:600;display:inline-flex}.status-badge.bot{color:var(--accent-2);background:#1f8a8014;border-color:#1f8a8073}.status-badge.disconnected{color:#c0392b;background:#c0392b12;border-color:#c0392b73}.status-badge.empty{border-color:var(--border);color:var(--muted);background:0 0}.status-chips{flex-wrap:wrap;gap:8px;display:flex}.status-chip{border:1px solid var(--border);color:var(--muted);border-radius:20px;align-items:center;padding:4px 10px;font-size:.8rem;display:inline-flex}.status-tile-chip{gap:8px}.phone-main{max-width:440px;padding:24px 16px 48px}.phone-main.in-game{flex-direction:column;max-width:100%;min-height:100vh;padding:0;display:flex}.join-screen{flex-direction:column;gap:20px;padding-top:40px;display:flex}.join-screen-centered{justify-content:center;min-height:calc(100svh - 72px);padding-top:24px;padding-bottom:24px}.join-logo{color:var(--accent);margin:0;font-size:clamp(2rem,6vw,3rem);font-weight:800;line-height:1}.join-sub{color:var(--muted);margin:0;line-height:1.5}.join-form{gap:12px;display:grid}.join-error{color:#c0392b;background:#c0392b12;border:1px solid #c0392b66;border-radius:8px;margin:0;padding:10px 12px;font-size:.9rem}.join-status{align-items:center;gap:8px;display:flex}.join-status-text{color:var(--muted);font-size:.875rem}.muted-text{color:var(--muted);opacity:.7;font-size:.9rem}.waiting-room-screen{text-align:center;align-items:center}.waiting-room-screen .join-sub,.waiting-room-screen .join-status,.waiting-room-screen .join-error,.waiting-room-screen .seating-my-roll,.waiting-room-screen .seating-others{width:min(100%,320px)}.waiting-room-screen .join-status{justify-content:center}.game-bar{background:var(--panel);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.game-bar-left{flex-direction:column;gap:2px;display:flex}.game-bar-name{font-size:1rem;font-weight:700}.game-bar-room{color:var(--muted);font-size:.78rem}.turn-banner{text-align:center;color:var(--accent-2);letter-spacing:.06em;text-transform:uppercase;background:#1f8a8024;border-bottom:1px solid #1f8a8059;flex-shrink:0;padding:10px 16px;font-size:.85rem;font-weight:700}.actions-your-turn-label{letter-spacing:.06em;text-transform:uppercase;color:var(--accent-2);text-align:center;margin:0;font-size:.82rem;font-weight:700;display:none}.actions-section--your-turn{border-top-color:#1f8a8080}.wait-banner{text-align:center;color:var(--muted);border-bottom:1px solid var(--border);flex-shrink:0;padding:8px 16px;font-size:.85rem}.reconnect-banner{color:#c0392b;background:#c0392b17;border-bottom:1px solid #c0392b59;flex-shrink:0;justify-content:center;align-items:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:600;display:flex}.reconnect-banner-dot{background:currentColor;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite reconnect-pulse}@keyframes reconnect-pulse{0%,to{opacity:.35}50%{opacity:1}}.charleston-banner{background:linear-gradient(90deg,#c49a3821,#c49a380f);border-bottom:1px solid #c49a3847;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.charleston-banner--waiting{border-bottom-color:var(--border);background:#1a16100a}.charleston-banner-step{letter-spacing:.12em;text-transform:uppercase;color:var(--accent);white-space:nowrap;font-size:.72rem;font-weight:700}.charleston-banner--waiting .charleston-banner-step{color:var(--muted)}.charleston-banner-direction{color:var(--text);white-space:nowrap;font-size:.95rem;font-weight:700}.charleston-banner--waiting .charleston-banner-direction{color:var(--muted)}.charleston-banner-status{color:var(--muted);white-space:nowrap;margin-left:auto;font-size:.82rem}.phone-score-card{margin:12px 16px}.hand-section{flex:1;min-height:0;padding:16px;overflow-y:auto}.hand-layout{gap:16px;display:grid}.hand-sort-bar{flex-wrap:wrap;gap:8px;display:flex}.hand-sort-button{min-height:34px;color:var(--muted);font:inherit;cursor:pointer;background:#ffffffd1;border:1px solid #c49a3838;border-radius:999px;justify-content:center;align-items:center;padding:0 12px;font-size:.82rem;font-weight:700;transition:border-color .18s,background .18s,color .18s,box-shadow .18s;display:inline-flex}.hand-sort-button.is-active{color:var(--text);background:linear-gradient(#fff8ebfa,#f7ecd3f0);border-color:#c49a3861;box-shadow:0 8px 18px #c49a381f}.hand-groups{gap:14px;display:grid}.tile-grid--group{background:linear-gradient(#ffffffeb,#f9f2e9d6),#ffffffb3;border:1px solid #c49a3824;border-radius:18px;padding:10px 10px 12px}.hand-tile{min-width:0;position:relative}.hand-tile .tile-button{cursor:grab;touch-action:none;width:100%}.hand-groups.is-dragging .tile-button{cursor:grabbing}.hand-tile.is-dragging .tile-button{opacity:.52;transform:scale(.96);box-shadow:0 4px 12px #1a16101f,inset 0 1px #ffffffe6}.hand-tile.is-drop-before:before,.hand-tile.is-drop-after:after{content:"";z-index:2;pointer-events:none;background:#37887ae0;border-radius:999px;width:4px;position:absolute;top:5px;bottom:5px;box-shadow:0 0 0 3px #1f8a8047}.hand-tile.is-drop-before:before{left:-7px}.hand-tile.is-drop-after:after{right:-7px}.hand-empty{color:var(--muted);text-align:center;margin:0;padding:32px 0}.selected-tile-name{color:var(--accent-2);text-align:center;letter-spacing:.02em;background:#1f8a801a;border:1px solid #1f8a804d;border-radius:8px;margin:10px 0 0;padding:6px 12px;font-size:.88rem;font-weight:700}.selection-hint{color:var(--muted);text-align:right;margin:8px 0 0;font-size:.82rem}.exposed-section{border-top:1px solid var(--border);background:var(--panel-2);flex-shrink:0;gap:8px;padding:10px 16px 12px;display:grid}.exposed-section-label{letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2);margin:0;font-size:.72rem;font-weight:700}.exposed-meld-list{flex-wrap:wrap;align-content:flex-start;gap:8px;display:flex}.exposed-meld-set{background:#1f8a800f;border:1px solid #1f8a8038;border-radius:12px;flex-wrap:wrap;align-items:center;gap:5px;padding:6px 8px;display:inline-flex}.exposed-mini-tile{align-items:center;display:inline-flex}.exposed-mini-tile .tile-face--chip .tile-face-image,.exposed-mini-tile .tile-face--chip .tile-face-fallback{width:28px;height:38px}@media (max-width:480px){.exposed-section{padding:8px 14px 10px}.exposed-mini-tile .tile-face--chip .tile-face-image,.exposed-mini-tile .tile-face--chip .tile-face-fallback{width:24px;height:33px}}.actions-section{border-top:1px solid var(--border);background:var(--panel);flex-shrink:0;gap:8px;max-height:55vh;padding:12px 16px;display:grid;overflow-y:auto}.action-button{width:100%}.claim-row{grid-template-columns:1fr auto;align-items:center;gap:8px;display:grid}.claim-select{min-height:44px}.card-hand-picker{border:1px solid var(--border);background:#1a161008;border-radius:8px;gap:7px;padding:10px 12px;display:grid}.card-hand-label{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;font-weight:700}.card-hand-select{min-height:42px}.card-hand-detail{color:var(--muted);margin:0;font-size:.82rem;line-height:1.35}.suggestion-row{border:1px solid var(--border);background:#1a161008;border-radius:8px;gap:8px;padding:10px 12px;display:grid}.suggestion-row--highlighted{background:linear-gradient(#dfb85b24,#dfb85b12);border-color:#8a6a1a99;animation:2s ease-in-out infinite suggestion-highlight-pulse;box-shadow:0 0 0 3px #8a6a1a24}@keyframes suggestion-highlight-pulse{0%,to{box-shadow:0 0 0 3px #8a6a1a24}50%{box-shadow:0 0 0 5px #8a6a1a42}}@media (prefers-reduced-motion:reduce){.suggestion-row--highlighted{animation:none}}.suggestion-hint-label{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:0 0 2px;font-size:.72rem;font-weight:700}.suggest-button--highlighted{background:linear-gradient(#dfb85b38,#dfb85b1f);border-color:#8a6a1a99;animation:2s ease-in-out infinite suggestion-highlight-pulse;box-shadow:0 0 0 3px #8a6a1a24}.suggestion-label{color:var(--ink);margin:0;font-size:.88rem;font-weight:700}.suggestion-reason,.suggestion-meta{color:var(--muted);margin:4px 0 0;font-size:.82rem;line-height:1.35}.suggestion-meta{font-size:.78rem}.suggest-button{font-size:.875rem}.pending-label{color:var(--muted);text-align:center;margin:0;font-size:.85rem}.wait-message{color:var(--muted);text-align:center;margin:0;padding:12px 0;font-size:.95rem}.game-status-bar{border-top:1px solid var(--border);background:var(--panel-2);flex-shrink:0;padding:8px 16px}.game-error{color:#c0392b;background:#c0392b12;border:1px solid #c0392b66;border-radius:8px;margin:10px 16px;padding:10px 12px;font-size:.9rem}.game-bar-right{align-items:center;gap:10px;display:flex}.score-card-toggle-button{min-height:32px;color:var(--accent);font:inherit;letter-spacing:.04em;cursor:pointer;background:#8a6a1a17;border:1px solid #8a6a1a73;border-radius:999px;justify-content:center;align-items:center;padding:0 12px;font-size:.78rem;font-weight:700;transition:background .16s,border-color .16s;display:inline-flex}.score-card-toggle-button:hover{background:#8a6a1a29;border-color:#8a6a1a99}.score-card-dialog{background:linear-gradient(#fffbf7fc,#f7efe8fc);border:1px solid #c49a384d;border-radius:20px;width:min(540px,94vw);max-height:82vh;margin:auto;padding:0;overflow:hidden;box-shadow:0 28px 72px #1c120e52}.score-card-dialog::backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#140e0c8a}.score-card-dialog-body{flex-direction:column;max-height:82vh;display:flex;overflow:hidden}.score-card-dialog-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 20px 14px;display:flex}.score-card-dialog-kicker{letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);margin:0 0 2px;font-size:.72rem;font-weight:700}.score-card-dialog-title{color:var(--text);margin:0;font-size:1.1rem}.score-card-dialog-note{max-width:36ch;color:var(--muted);margin:5px 0 0;font-size:.76rem;line-height:1.4}.score-card-close-button{border:1px solid var(--border);width:34px;height:34px;color:var(--muted);font:inherit;cursor:pointer;background:#1a16100d;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:.88rem;transition:background .14s;display:inline-flex}.score-card-close-button:hover{background:#1a16101a}.score-card-dialog-content{flex-direction:column;flex:1;gap:20px;min-height:0;padding:18px 20px 24px;display:flex;overflow-y:auto}.score-card-section{flex-direction:column;gap:8px;display:flex}.score-card-section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--accent-2);border-bottom:1px solid var(--border);margin:0;padding-bottom:6px;font-size:.82rem;font-weight:700}.score-card-hand-list{flex-direction:column;gap:6px;display:flex}.score-card-hand-row{border:1px solid var(--border);background:#ffffffb3;border-radius:10px;gap:3px;padding:9px 12px;display:grid}.score-card-hand-row--primary{background:linear-gradient(#fffaecf5,#fff4d6f5);border-color:#8a6a1acc;box-shadow:0 10px 22px #8a6a1a1f}.score-card-hand-row--secondary{background:linear-gradient(#fffcf5f0,#faf1e2f0);border-color:#8a6a1a7a}.score-card-hand-main{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.score-card-hand-line{color:var(--muted);letter-spacing:.04em;flex-shrink:0;font-size:.72rem;font-weight:700}.score-card-hand-pattern{color:var(--text);letter-spacing:.03em;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.88rem;font-weight:700}.score-card-hand-alt{color:var(--muted);font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.82rem}.score-card-hand-suits{color:var(--muted);margin:0;font-size:.78rem;line-height:1.35}.score-card-hand-meta{flex-wrap:wrap;align-items:center;gap:8px;margin-top:2px;display:flex}.score-card-hand-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.score-card-hand-badge--primary{color:var(--accent);background:#8a6a1a1f;border:1px solid #8a6a1a6b}.score-card-hand-badge--secondary{color:var(--muted);background:#8a6a1a14;border:1px solid #8a6a1a47}.score-card-hand-points{color:var(--accent);background:#8a6a1a14;border:1px solid #8a6a1a66;border-radius:999px;align-items:center;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.score-card-hand-points.is-concealed{color:var(--accent-2);background:#1f8a8017;border-color:#1f8a8066}.host-main{max-width:1440px}.host-shell{gap:24px}.host-main--broadcast{max-width:none;padding:12px 18px}.host-shell--broadcast{flex-direction:column;gap:12px;min-height:calc(100vh - 24px);display:flex}.host-error-toast{color:#fff5f2;text-align:center;background:#781e1eeb;border:1px solid #c4503c80;border-radius:12px;margin:0;padding:10px 14px;font-size:.92rem}.host-hero{background:radial-gradient(circle at 100% 0,#c49a381f,#0000 32%),linear-gradient(#fffffffa,#fbf7f2fa)}.host-hero-pre-header,.host-hero-active-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.host-hero-conn{color:var(--muted);letter-spacing:.04em;background:#1a16100d;border-radius:999px;align-items:center;gap:8px;padding:4px 10px 4px 8px;font-size:.78rem;font-weight:600;display:inline-flex}.host-hero-conn-dot{background:#d39b00;border-radius:999px;width:8px;height:8px;animation:1.2s ease-in-out infinite host-hero-conn-pulse;box-shadow:0 0 0 3px #d39b002e}.host-hero-conn.is-ready .host-hero-conn-dot{background:#1f9d6e;animation:none;box-shadow:0 0 0 3px #1f9d6e2e}@keyframes host-hero-conn-pulse{0%,to{opacity:1}50%{opacity:.45}}.host-hero-error{color:#8a2a1d;background:#c0392b0f;border:1px solid #c0392b59;border-radius:10px;align-items:flex-start;gap:10px;padding:12px 14px;font-size:.92rem;line-height:1.4;display:flex}.host-hero-error-icon{color:#fff;background:#c0392b;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:.78rem;font-weight:800;line-height:1;display:inline-flex}.host-hero--pre{gap:18px}.host-hero-pre-actions{margin-top:4px}.host-hero-cta{letter-spacing:.02em;color:#fff;background:linear-gradient(#7a5e10,#5e4809);border-color:#4a3806;min-height:52px;padding:0 28px;font-size:1rem;transition:transform .15s,box-shadow .15s;box-shadow:0 10px 24px #5a440a4d,inset 0 1px #ffffff2e}.host-hero-cta:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 14px 28px #5a440a61,inset 0 1px #ffffff2e}.host-hero-steps{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:6px 0 0;padding:0;list-style:none;display:grid}.host-hero-steps>li{border:1px solid var(--border);background:#ffffffa6;border-radius:10px;align-items:flex-start;gap:12px;padding:14px;display:flex}.host-hero-step-num{width:28px;height:28px;color:var(--accent-2);background:#1f8a8024;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:.92rem;font-weight:800;display:inline-flex}.host-hero-step-title{margin-bottom:2px;font-size:.96rem;font-weight:700}.host-hero-step-text{color:var(--muted);font-size:.88rem;line-height:1.45}.host-hero-reconnect{background:#1f8a800f;border:1px dashed #1f8a808c;border-radius:10px;gap:8px;padding:14px 16px;display:grid}.host-hero-reconnect-title{color:var(--text);font-size:.92rem;font-weight:700}.host-hero--active{gap:20px}.host-hero-active-body{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:24px;display:grid}.host-hero-roomcode{gap:8px;min-width:0;display:grid}.host-hero-roomcode-label{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:.75rem;font-weight:600}.host-hero-roomcode-value{letter-spacing:.05em;color:var(--text);text-shadow:0 1px #fff9;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:clamp(3.5rem,9vw,6.5rem);font-weight:800;line-height:.95}.host-hero-phase{flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;display:inline-flex}.host-hero-phase-pill{color:var(--accent-2);letter-spacing:.04em;text-transform:uppercase;background:#1f8a8024;border-radius:999px;align-items:center;padding:4px 12px;font-size:.82rem;font-weight:700;display:inline-flex}.host-hero-phase-turn{color:var(--muted);font-size:.92rem}.host-hero-qr{justify-items:center;gap:8px;display:grid}.host-hero-qr-frame{border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px;line-height:0;box-shadow:0 6px 20px #1a161014}.host-hero-qr-frame--placeholder{background:#1a16100a;width:228px;height:228px}.host-hero-qr-caption{color:var(--muted);text-align:center;max-width:228px;font-size:.78rem}.host-hero-seats{gap:10px;display:grid}.host-hero-seats-header{justify-content:space-between;align-items:baseline;gap:12px;display:flex}.host-hero-seats-title{letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-size:.75rem;font-weight:600}.host-hero-seats-count{color:var(--text);font-size:.9rem;font-weight:600}.host-hero-seats-row{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.host-hero-seat{border:1px solid var(--border);background:#fff;border-radius:10px;gap:4px;min-width:0;padding:10px 12px;display:grid}.host-hero-seat.is-empty{color:var(--muted);background:repeating-linear-gradient(135deg,#1a161006,#1a161006 6px,#0000 6px 12px);border-style:dashed}.host-hero-seat.is-active{background:linear-gradient(#fff7e0,#fcf0cdd9);border-color:#c49a38bf;box-shadow:0 0 0 3px #c49a382e,0 6px 16px #c49a3826}.host-hero-seat--disconnected{opacity:.7}.host-hero-seat-name{white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:6px;font-size:.96rem;font-weight:700;display:flex;overflow:hidden}.host-hero-seat-badge{background:var(--accent-2);color:#fff;letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;padding:1px 6px;font-size:.62rem;font-weight:800;display:inline-flex}.host-hero-seat-status{color:var(--muted);font-size:.78rem}.host-hero-seat--bot .host-hero-seat-status{color:#7a5c12}@media (max-width:720px){.host-hero-active-body{text-align:center;grid-template-columns:1fr;justify-items:center}.host-hero-roomcode{justify-items:center}.host-hero-phase{justify-content:center}}.host-broadcast{grid-template-columns:minmax(0,1.35fr) minmax(300px,.65fr);align-items:stretch;gap:20px;display:grid}.host-broadcast--tv{flex:1;grid-template-columns:1fr;gap:0;min-height:0}.host-broadcast--tv .tv-stage-card{flex-direction:column;flex:1;justify-content:flex-start;align-items:stretch;gap:12px;width:100%;min-height:0;margin:0 auto;padding:12px 12px 14px;display:flex}.host-broadcast--tv .tv-stage{aspect-ratio:auto;flex:1;width:100%;max-width:calc(170vh - 187px);height:100%;min-height:0;margin:0 auto;position:relative}.host-broadcast--tv .tv-table{border-width:10px;padding:18px}.host-broadcast--tv .tv-table:before{inset:16px}.host-broadcast--tv .tv-table-layout{grid-template-rows:minmax(0,auto) minmax(0,1fr) minmax(0,auto);grid-template-columns:minmax(110px,.85fr) minmax(0,1.6fr) minmax(110px,.85fr);gap:12px}.tv-hud{color:#f4f6f4;background:#111512d1;border:1px solid #ffffff14;border-radius:18px;flex-wrap:wrap;align-items:center;gap:12px;padding:12px 16px;display:flex;box-shadow:inset 0 1px #ffffff0a}.tv-hud--broadcast{background:#0b100dad;border-radius:20px;width:min(100%,170vh - 187px);margin:0 auto}.tv-hud-cluster{flex-wrap:wrap;flex:0 auto;align-items:center;gap:8px;display:flex}.tv-hud-chip{color:#f4f6f4e0;white-space:nowrap;background:#ffffff09;border-radius:999px;align-items:baseline;gap:6px;padding:3px 10px;display:inline-flex}.tv-hud-chip-label{text-transform:uppercase;letter-spacing:.12em;color:#e4e8e475;font-size:.58rem}.tv-hud-chip-value{font-size:.84rem;font-weight:600}.tv-hud-chip--winner{background:#e8bc5c1f;border:1px solid #e8bc5c47}.tv-hud-chip--winner .tv-hud-chip-value{color:#f7e4a8}.tv-hud-summary{color:#e4e8e4ad;flex:220px;margin:0;font-size:.84rem;line-height:1.35}.tv-hud-item{flex-direction:column;gap:2px;min-width:0;display:flex}.tv-hud-label{text-transform:uppercase;letter-spacing:.14em;color:#e4e8e499;font-size:.68rem}.tv-hud-value{color:#f4f6f4;white-space:nowrap;font-size:1.15rem;font-weight:600}.tv-hud-value strong{color:#fff;margin-right:2px;font-size:1.35rem}.tv-hud-utility{color:#f4f6f4d6;cursor:pointer;background:#ffffff08;border:1px solid #ffffff1f;border-radius:16px;align-items:center;gap:10px;min-height:44px;margin-left:auto;padding:8px 12px;transition:background .15s,border-color .15s;display:flex}.tv-hud-utility:hover{background:#ffffff12;border-color:#ffffff2e}.tv-hud-utility-icon{background:#ffffff0d;border-radius:999px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.95rem;display:inline-flex}.tv-hud-utility-copy{flex-direction:column;align-items:flex-start;gap:1px;display:flex}.tv-hud-utility-label{letter-spacing:.08em;text-transform:uppercase;font-size:.74rem;font-weight:700}.tv-hud-utility-meta{color:#e4e8e494;font-size:.72rem}.tv-event-log{color:#e8ece8;background:#161a18;border:1px solid #ffffff14;border-radius:14px;font-size:.95rem;line-height:1.4}.tv-event-log-summary{cursor:pointer;-webkit-user-select:none;user-select:none;letter-spacing:.04em;text-transform:uppercase;color:#e8ece8c7;justify-content:space-between;align-items:center;gap:12px;padding:10px 18px;font-size:.8rem;font-weight:600;list-style:none;display:flex}.tv-event-log-summary::-webkit-details-marker{display:none}.tv-event-log-summary:after{content:"▾";color:#e8ece899;font-size:.8rem;transition:transform .16s}.tv-event-log[open] .tv-event-log-summary:after{transform:rotate(180deg)}.tv-event-log-count{color:#e8ece8d9;background:#ffffff14;border-radius:999px;margin-left:auto;padding:2px 8px;font-size:.74rem}.tv-event-log-list{flex-direction:column;gap:6px;max-height:240px;margin:0;padding:4px 18px 14px;list-style:none;display:flex;overflow-y:auto}.tv-event-log-item{background:#ffffff0a;border-radius:8px;align-items:flex-start;gap:8px;padding:6px 10px;display:flex}.tv-event-log-item:before{content:"•";color:#e8ece880;margin-top:2px;font-size:.9rem;line-height:1}.tv-event-log-empty{color:#e8ece880;margin:0;padding:0 18px 14px;font-style:italic}.tv-controls-dialog{background:#fff;border:1px solid #0000001f;border-radius:22px;width:min(560px,92vw);max-height:86vh;margin:auto;padding:0;box-shadow:0 32px 80px #00000052}.tv-controls-dialog::backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0e0ca8}.tv-controls-body{flex-direction:column;gap:18px;max-height:86vh;padding:22px 24px 24px;display:flex;overflow-y:auto}.tv-controls-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.tv-controls-head h2{margin:0}.tv-controls-section{flex-direction:column;gap:10px;display:flex}.tv-controls-section h3{color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin:0;font-size:.95rem}.tv-controls-list{gap:8px;display:grid}.tv-controls-row{border:1px solid var(--border);background:#1a161008;border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex}.tv-stage-card{background:#0f1311;border:1px solid #0000001f;border-radius:28px;padding:18px;box-shadow:0 24px 60px #00000059}.tv-stage{aspect-ratio:1;min-height:760px;position:relative}.tv-table{background:#1f3a2b;border:12px solid #6b4a2b;border-radius:34px;width:100%;height:100%;padding:28px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 0 2px #00000059,inset 0 -10px 24px #00000047}.tv-table:before{content:"";pointer-events:none;border:1px solid #ffffff14;border-radius:26px;position:absolute;inset:24px}.tv-table-layout{z-index:1;grid-template:".top."minmax(152px,auto)"left center right"minmax(0,1fr)".bottom."minmax(188px,auto)/minmax(140px,.88fr) minmax(0,1.48fr) minmax(140px,.88fr);gap:18px;width:100%;height:100%;display:grid;position:relative}.tv-wall-slot{justify-content:center;align-items:center;display:flex}.tv-wall-slot--top{grid-area:top;align-self:end;margin-bottom:-8px}.tv-wall-slot--right{grid-area:right;justify-content:flex-start;margin-left:-8px}.tv-wall-slot--bottom{grid-area:bottom;align-self:start;margin-top:-8px}.tv-wall-slot--left{grid-area:left;justify-content:flex-end;margin-right:-8px}.tv-wall{background:#00000047;border-radius:999px;align-items:center;gap:7px;padding:8px 10px;display:flex}.tv-wall--right,.tv-wall--left{flex-direction:column}.tv-wall-break{background:#fff3;border-radius:999px;width:18px;height:10px}.tv-wall--right .tv-wall-break,.tv-wall--left .tv-wall-break{width:10px;height:18px}.tv-wall-count{color:#f4f6f4;background:#0000006b;border-radius:999px;justify-content:center;align-items:center;min-width:26px;min-height:26px;padding:0 6px;font-size:.76rem;font-weight:700;display:inline-flex}.tv-wall-brick{background:linear-gradient(#f5ecd9,#d8c8a8);border-radius:4px;width:24px;height:12px;box-shadow:0 2px 4px #00000047,inset 0 1px #fff9}.tv-wall--right .tv-wall-brick,.tv-wall--left .tv-wall-brick{width:12px;height:24px}.tv-seat{background:#080e0b9e;border:1px solid #ffffff1a;border-radius:20px;align-content:start;gap:10px;min-width:0;min-height:0;padding:14px 16px;display:grid;box-shadow:0 6px 18px #00000040}.tv-seat--top{grid-area:top;align-self:end}.tv-seat--bottom{grid-area:bottom;align-self:start}.tv-seat--right{grid-area:right;place-self:stretch stretch}.tv-seat--left{grid-area:left;place-self:stretch stretch}.tv-seat.is-active{background:#28200eb3;border-color:#e8bc5ce6;animation:2.4s ease-in-out infinite tv-seat-pulse;box-shadow:0 0 0 3px #e8bc5c8c,0 0 24px 4px #e8bc5c47,0 6px 18px #00000052}@keyframes tv-seat-pulse{0%,to{box-shadow:0 0 0 3px #e8bc5c8c,0 0 24px 4px #e8bc5c47,0 6px 18px #00000052}50%{box-shadow:0 0 0 4px #e8bc5cbf,0 0 32px 8px #e8bc5c66,0 6px 18px #00000052}}@media (prefers-reduced-motion:reduce){.tv-seat.is-active{animation:none}}.tv-seat.is-dealer{background:#142016b8}.tv-seat.is-away{opacity:.62}.tv-seat-header,.tv-seat-heading,.tv-seat-flags,.tv-seat-status{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.tv-seat-heading h3{color:#f4f6f4;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:1.15rem;overflow:hidden}.tv-seat-label,.tv-zone-label,.tv-panel-kicker{text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}.tv-seat-label,.tv-zone-label{color:#e8ece89e}.tv-seat-status{color:#e8ece8d6;justify-content:flex-start;font-size:.84rem}.tv-pill{color:#f4f6f4eb;background:#ffffff0f;border:1px solid #ffffff24;border-radius:999px;align-items:center;min-height:24px;padding:0 8px;font-size:.74rem;font-weight:700;display:inline-flex}.tv-pill--turn{color:#f7e4a8;background:#e8bc5c2e;border-color:#e8bc5cb3}.tv-pill--dealer{color:#f0d68e;background:#e8bc5c1a;border-color:#e8bc5c80}.tv-pill--alert{color:#f6b8b5;background:#dc4c462e;border-color:#dc4c46b3}.tv-meld-zone{background:linear-gradient(#e8bc5c14,#080e0b4d);border:1px solid #e8bc5c24;border-radius:16px;gap:8px;min-width:0;padding:10px 12px 12px;display:grid}.tv-rack-zone{background:#ffffff08;border-top:1px dashed #ffffff14;border-radius:16px;gap:8px;min-width:0;padding:10px 12px 12px;display:grid}.tv-zone-head{justify-content:space-between;align-items:center;gap:8px;min-width:0;display:flex}.tv-zone-count{color:#e8ece8d1;white-space:nowrap;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:999px;align-items:center;min-height:22px;padding:0 8px;font-size:.72rem;font-weight:700;display:inline-flex}.tv-zone-count.is-open{color:#f3dda0;background:#e8bc5c24;border-color:#e8bc5c73}.tv-rack-lane{align-items:center;gap:8px;min-width:0;display:flex}.tv-rack{flex-wrap:wrap;flex:1;align-content:flex-start;gap:4px;min-width:0;min-height:0;display:flex}.tv-rack-tile{background:linear-gradient(#f5ecd9,#d8c8a8);border-radius:3px;width:12px;height:22px;box-shadow:0 2px 4px #0000003d,inset 0 1px #fff9}.tv-rack-count{color:#e8ece8b3;font-variant-numeric:tabular-nums;text-align:right;min-width:1.5em;font-size:.78rem;font-weight:700}.tv-meld-list{align-content:flex-start;gap:8px;display:grid}.tv-meld-set{background:#e8bc5c1a;border:1px solid #e8bc5c52;border-radius:12px;gap:6px;min-height:52px;padding:8px 10px;display:grid;box-shadow:0 2px 6px #0003}.tv-meld-set-label{color:#f4f6f4b3;letter-spacing:.12em;text-transform:uppercase;font-size:.68rem;font-weight:700}.tv-meld-tiles{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.tv-meld-empty{background:#ffffff08;border:1px dashed #ffffff1f;border-radius:12px;place-items:center;min-height:64px;display:grid}.tv-mini-tile{align-items:center;display:inline-flex}.tv-mini-tile .tile-face--chip .tile-face-image,.tv-mini-tile .tile-face--chip .tile-face-fallback{width:30px;height:41px}.tv-mini-tile--discard.is-claimed{opacity:.58}.tv-empty-copy{color:#e8ece899;margin:0;font-size:.82rem}.tv-center{grid-area:center;grid-template-rows:auto minmax(0,1fr);gap:14px;min-width:0;min-height:0;display:grid}.tv-center-badge{text-align:left;background:#080e0b99;border:1px solid #ffffff1a;border-radius:18px;align-content:start;gap:8px;padding:16px;display:grid;box-shadow:0 6px 18px #00000040}.tv-center-summary{gap:4px;display:grid}.tv-center-kicker{color:#e8ece89e;letter-spacing:.12em;text-transform:uppercase;font-size:.74rem}.tv-center-room{color:#f4f6f4;font-size:1.1rem}.tv-center-winner{color:#f0d68e;font-size:.98rem;font-weight:700}.tv-center-result,.tv-center-points{color:#e8ece8d6;font-size:.84rem}.tv-center-board{grid-template:".top.""left discard right"minmax(0,1fr)".bottom."/auto minmax(0,1fr) auto;gap:10px;min-height:0;display:grid}.tv-board-focus{grid-area:discard;grid-template-rows:auto minmax(0,1fr);gap:14px;min-height:0;display:grid}.tv-last-discard-card{background:radial-gradient(circle,#e8bc5c2e,#080e0ba6 70%),#080e0bb3;border:1px solid #e8bc5c73;border-radius:20px;align-content:center;justify-items:center;gap:12px;padding:18px 18px 20px;display:grid;box-shadow:0 0 0 2px #e8bc5c40,0 12px 28px #0006}.tv-last-discard-head{justify-content:space-between;align-items:center;gap:10px;width:100%;display:flex}.tv-last-discard-kicker{text-transform:uppercase;letter-spacing:.18em;color:#f0d68e;font-size:.78rem;font-weight:700}.tv-discard-state{color:#9ee1d9;background:#1f8a8029;border:1px solid #1f8a8070;border-radius:999px;align-items:center;min-height:24px;padding:0 9px;font-size:.72rem;font-weight:700;display:inline-flex}.tv-discard-state.is-claimed{color:#f4e0a7;background:#e8bc5c29;border-color:#e8bc5c8a}.tv-last-discard-tile{background:#0000002e;border-radius:14px;padding:6px;display:inline-flex}.tv-last-discard-tile .tile-face--chip .tile-face-image,.tv-last-discard-tile .tile-face--chip .tile-face-fallback{width:92px;height:124px}.tv-last-discard-copy{justify-items:center;gap:4px;display:grid}.tv-last-discard-meta{color:#f4f6f4f5;font-size:1.18rem;font-weight:700}.tv-last-discard-seat{color:#e8ece8b8;font-size:.86rem;font-weight:600}.tv-last-discard-empty{color:#e8ece8a6;padding:12px 4px;font-size:.95rem;font-style:italic}.tv-discard-history{background:#080e0b80;border:1px solid #ffffff14;border-radius:16px;grid-template-rows:auto minmax(0,1fr);gap:8px;min-height:0;padding:12px 14px;display:grid;box-shadow:0 6px 18px #00000038}.tv-discard-history-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.tv-discard-history-title{color:#e8ece8c7;text-transform:uppercase;letter-spacing:.12em;gap:2px;font-size:.74rem;font-weight:700;display:grid}.tv-discard-history-note{color:#e8ece87a;letter-spacing:.08em;font-size:.62rem}.tv-discard-history-count{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:999px;justify-content:center;align-items:center;min-width:32px;min-height:32px;display:inline-flex}.tv-discard-history-grid{grid-template-columns:repeat(auto-fill,minmax(58px,1fr));align-content:start;gap:6px;min-height:0;display:grid;overflow-y:auto}.tv-discard-tile{background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;justify-items:center;gap:6px;padding:8px 6px 7px;display:grid}.tv-discard-tile-face{display:inline-flex}.tv-discard-tile .tile-face--chip .tile-face-image,.tv-discard-tile .tile-face--chip .tile-face-fallback{width:28px;height:38px}.tv-discard-tile-meta{color:#e8ece8b8;letter-spacing:.06em;text-transform:uppercase;justify-items:center;gap:2px;font-size:.6rem;font-weight:700;display:grid}.tv-discard-tile.is-claimed{background:#e8bc5c14;border-style:dashed;border-color:#e8bc5c61}.tv-discard-tile.is-claimed .tv-discard-tile-meta span:last-child{color:#f0d68e}.tv-discard-history-empty{background:#ffffff05;border:1px dashed #ffffff1f;border-radius:10px;place-items:center;min-height:64px;display:grid}.tv-sidebar{flex-direction:column;gap:16px;height:100%;display:flex}.tv-info-card,.tv-roster-card{gap:12px}.tv-info-head{justify-content:space-between;align-items:start;gap:12px;display:flex}.tv-info-head h2{margin-top:2px}.tv-panel-kicker{color:var(--accent-2);margin:0 0 4px}.tv-status-chips .status-chip{background:#1a161008}.tv-roster{gap:10px;display:grid}.tv-roster-row{border:1px solid var(--border);background:#1a161008;border-radius:14px;gap:8px;padding:12px;display:grid}.tv-roster-row strong{margin-top:4px;display:block}.tv-roster-row.is-active{background:#dfb85b14;border-color:#dfb85b8c}.tv-roster-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px;font-size:.82rem;display:flex}.tv-event-card{flex:1;grid-template-rows:auto minmax(0,1fr);min-height:260px}.tv-event-card .event-log{min-height:0;max-height:none}.host-phase-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;display:flex}.host-phase-header h2{margin:0}.host-seats{gap:8px;display:grid}.host-seat-row{border:1px solid var(--border);background:#1a16100a;border-radius:8px;align-items:center;gap:10px;padding:12px;transition:border-color .22s,opacity .22s;display:flex}.host-seat-row.empty{opacity:.5}.host-seat-row.disconnected{opacity:.65}.host-seat-row.active-seat{background:#dfb85b12;border-color:#dfb85bb3}.host-seat-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:600;overflow:hidden}.host-seat-row.empty .host-seat-name{color:var(--muted);font-weight:400}.host-seat-badges{align-items:center;gap:6px;display:flex}.seat-tile-count{color:var(--muted);white-space:nowrap;font-size:.82rem}.small-button{min-height:34px;padding:0 10px;font-size:.82rem}.seat-method-row{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.seat-method-label{color:var(--muted);white-space:nowrap;font-size:.88rem}.seat-method-options{gap:20px;display:flex}.seat-method-option{cursor:pointer;align-items:center;gap:6px;font-size:.9rem;display:flex}.card-set-select{min-width:160px}.seating-roll-list{flex-direction:column;gap:8px;display:flex}.seating-roll-header{color:var(--muted);margin-bottom:4px;font-size:.88rem}.seating-roll-row{border:1px solid var(--border);background:var(--surface);border-radius:8px;align-items:center;gap:12px;padding:10px 14px;display:flex}.seating-roll-row.rolled{background:#64b4640d;border-color:#64b46466}.seating-roll-result{color:var(--fg);margin-left:auto;font-size:.9rem}.seating-roll-pending{color:var(--muted);margin-left:auto;font-size:.85rem}.seating-my-roll{text-align:center;margin:12px 0;font-size:1.1rem}.seating-others{margin-top:8px}.muted-text{color:var(--muted)}.dice-tray{perspective:600px;justify-content:center;gap:18px;margin:18px 0 6px;display:flex}.die{background:var(--panel);border:1px solid var(--border);border-radius:12px;justify-content:center;align-items:center;width:64px;height:64px;display:flex;box-shadow:0 4px 10px #1a161014}.die-face{grid-template-rows:repeat(3,1fr);grid-template-columns:repeat(3,1fr);gap:4px;width:48px;height:48px;display:grid}.die-pip{background:0 0;border-radius:50%;place-self:center;width:8px;height:8px}.die-pip.on{background:var(--text)}.die-rolling{animation:.5s linear infinite die-tumble}.dice-tray.rolling .die:nth-child(2){animation-duration:.45s;animation-direction:reverse}@keyframes die-tumble{0%{transform:rotate(0)translateY(0)}25%{transform:rotate(180deg)translateY(-10px)}50%{transform:rotate(360deg)translateY(0)}75%{transform:rotate(540deg)translateY(-10px)}to{transform:rotate(720deg)translateY(0)}}.dice-tray.settled .die{animation:.45s cubic-bezier(.34,1.56,.64,1) die-settle}@keyframes die-settle{0%{transform:scale(.85)rotate(-10deg)}60%{transform:scale(1.08)rotate(4deg)}to{transform:scale(1)rotate(0)}}@media (prefers-reduced-motion:reduce){.die-rolling,.dice-tray.settled .die{animation:none}}@media (max-width:760px){main{padding:18px 12px 36px}.hero{padding:18px}.tile-grid{grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}.tile-button{border-radius:12px;min-height:84px}.host-broadcast{grid-template-columns:1fr}.tv-stage-card{border-radius:22px;padding:12px}.tv-stage{aspect-ratio:auto;min-height:860px}.tv-table{border-width:8px;border-radius:24px;padding:18px}.tv-table:before{border-radius:18px;inset:16px}.tv-table-layout{grid-template-rows:minmax(138px,auto) minmax(0,1fr) minmax(176px,auto);grid-template-columns:minmax(94px,.75fr) minmax(0,1.6fr) minmax(94px,.75fr);gap:12px}.tv-seat{border-radius:20px;padding:12px}.tv-seat-heading h3{font-size:.92rem}.tv-seat-status{font-size:.72rem}.tv-rack{gap:4px}.tv-rack-tile{width:15px;height:28px}.tv-wall-slot--top{margin-bottom:-4px}.tv-wall-slot--bottom{margin-top:-4px}.tv-discard-history-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr));gap:4px}.tv-last-discard-tile .tile-face--chip .tile-face-image,.tv-last-discard-tile .tile-face--chip .tile-face-fallback{width:76px;height:104px}.tv-mini-tile .tile-face--chip .tile-face-image,.tv-mini-tile .tile-face--chip .tile-face-fallback{width:24px;height:33px}.tile-grid--group{grid-template-columns:repeat(auto-fill,minmax(64px,1fr));padding:8px}}@media (max-width:480px){.turn-banner{letter-spacing:.1em;background:#1f8a8033;border-bottom:2px solid #1f8a808c;padding:14px 16px;font-size:1rem;animation:2s ease-in-out infinite mobile-turn-pulse}@keyframes mobile-turn-pulse{0%,to{background:#1f8a8033}50%{background:#1f8a8057}}@media (prefers-reduced-motion:reduce){.turn-banner{animation:none}}.actions-section{z-index:10;border-top:2px solid var(--border);max-height:60vh;position:sticky;bottom:0;box-shadow:0 -6px 20px #1a16101a}.actions-section--your-turn{background:linear-gradient(#e0f6f4fa,#fffffffa);border-top:2px solid #1f8a80bf;box-shadow:0 -6px 24px #1f8a8033}.actions-your-turn-label{padding:4px 0 2px;font-size:.78rem;display:block}.action-button{border-radius:12px;min-height:52px;font-size:1rem}.actions-section{gap:10px;padding:14px 14px 20px}.claim-row .button{min-height:52px;font-size:1rem}}.host-advanced-controls{border-top:1px solid #1a161014;margin-top:4px;padding-top:10px}.host-advanced-controls-summary{cursor:pointer;color:var(--muted);letter-spacing:.02em;text-transform:uppercase;font-size:.84rem;font-weight:600;list-style:none}.host-advanced-controls-summary::-webkit-details-marker{display:none}.host-advanced-controls-summary:after{content:"▾";margin-left:8px;font-size:.8rem;transition:transform .18s;display:inline-block}.host-advanced-controls[open] .host-advanced-controls-summary:after{transform:rotate(180deg)}.host-advanced-controls-body{gap:12px;margin-top:12px;padding-left:2px;display:grid}.custom-runs-collapsed{align-items:center;display:flex}.custom-runs-editor{border:1px solid var(--border);background:var(--surface);border-radius:10px;flex-direction:column;gap:12px;padding:14px;display:flex}.custom-runs-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.custom-runs-title{color:var(--fg);font-size:.9rem;font-weight:600}.custom-runs-hint{color:var(--muted);font-size:.82rem;line-height:1.4}.custom-runs-empty{color:var(--muted);font-size:.85rem}.custom-runs-list{flex-direction:column;gap:10px;display:flex}.custom-run-row{border:1px solid var(--border);background:var(--bg);border-radius:8px;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.custom-run-fields{flex-wrap:wrap;flex:1;align-items:flex-end;gap:8px 14px;display:flex}.custom-run-field{flex-direction:column;flex:1;gap:3px;min-width:120px;display:flex}.custom-run-field--narrow{flex:0 0 80px;min-width:70px;max-width:90px}.custom-run-field--checkbox{flex-direction:row;align-items:center;gap:6px;min-width:auto;padding-bottom:2px}.custom-run-field-label{color:var(--muted);white-space:nowrap;font-size:.78rem}.custom-run-input{background:var(--surface);border:1px solid var(--border);height:32px;color:var(--fg);box-sizing:border-box;border-radius:6px;width:100%;padding:0 8px;font-size:.85rem}.custom-run-input.mono{font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace}.custom-run-input:focus{border-color:var(--accent,#4a90d9);outline:none}.custom-run-remove{flex-shrink:0;margin-top:18px}.custom-runs-actions{align-items:center;gap:8px;display:flex}
