:root{--ink: #17211b;--muted: #5f7168;--paper: #fbfaf6;--linen: #efebe1;--felt: #0f6f86;--felt-dark: #0a4658;--rail: #17352d;--gold: #d8a731;--red: #b72f35;--green: #14553f;--shadow: rgba(17, 27, 24, .22);color:var(--ink);background:var(--linen);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{min-height:40px;padding:0 14px;border:0;border-radius:6px;color:#fff;background:var(--green);font-weight:800;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease,opacity .12s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 18px #14553f38}button:disabled{cursor:not-allowed;opacity:.5}button.secondary{color:var(--ink);background:#e4ded1}button.danger{background:#9f2f35}.app-shell{min-height:100vh;padding:18px;background:linear-gradient(135deg,rgba(15,111,134,.15),transparent 40%),linear-gradient(315deg,rgba(216,167,49,.16),transparent 42%),var(--linen)}.table-surface{width:min(1500px,100%);min-height:calc(100vh - 36px);margin:0 auto;padding:14px;border:1px solid rgba(23,33,27,.14);border-radius:8px;background:#fbfaf6d1;box-shadow:0 24px 80px #17211b21}.top-bar,.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.top-bar{margin-bottom:10px;padding:0 4px}.eyebrow{margin:0 0 6px;color:var(--muted);font-size:.78rem;font-weight:800;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(1.45rem,2.8vw,2.4rem);line-height:1;letter-spacing:0}h2{font-size:.95rem;letter-spacing:0}.status-pill{flex:0 0 auto;padding:8px 12px;border:1px solid rgba(23,33,27,.16);border-radius:999px;color:var(--muted);background:#fff;font-size:.88rem;font-weight:800}.status-ok{color:var(--green);border-color:#14553f47;background:#e8f4ee}.grid{display:grid;gap:14px}.grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel{padding:16px;border:1px solid rgba(23,33,27,.14);border-radius:8px;background:#fff}.saved-seat-card{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.saved-seat-card h2,.saved-seat-card p{margin:0}.saved-seat-card p{color:var(--muted);font-size:.9rem;font-weight:800}.saved-seat-actions,.seat-row-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.seat-kick-button{min-height:30px;padding:0 8px;font-size:.72rem}.side-panel{align-self:start}.table-info-panel{display:grid;gap:12px}.table-panel{min-width:0;display:grid;gap:10px}.room-form{display:grid;gap:14px}.room-form label{display:grid;gap:6px;color:var(--muted);font-size:.92rem;font-weight:800}.room-form input,.room-form select{width:100%;min-height:42px;padding:9px 10px;border:1px solid rgba(23,33,27,.22);border-radius:6px;background:#fff}.ruleset-selector{display:grid;gap:8px;min-width:0;margin:0;padding:0;border:0}.ruleset-selector legend{width:100%;padding:0;color:var(--muted);font-size:.92rem;font-weight:800}.ruleset-label-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.ruleset-help-button,.ruleset-close-button{display:grid;place-items:center;flex:0 0 auto;min-height:32px;width:32px;padding:0;border:1px solid rgba(23,33,27,.16);border-radius:999px;color:var(--ink);background:#fff}.ruleset-segmented{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;min-width:0}.ruleset-choice{display:grid;align-content:start;gap:4px;min-height:74px;padding:10px;border:1px solid rgba(23,33,27,.16);border-radius:8px;color:var(--ink);background:#fff;text-align:left}.ruleset-choice.is-selected{border-color:#d8a731d6;color:#211805;background:var(--gold)}.ruleset-choice strong,.ruleset-choice small{min-width:0;overflow-wrap:anywhere}.ruleset-choice small{color:inherit;font-size:.74rem;font-weight:800;line-height:1.24;opacity:.78}.ruleset-modal-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:18px;background:#081411b3}.ruleset-modal{display:grid;gap:16px;width:min(900px,100%);max-height:calc(100vh - 36px);overflow:auto;padding:18px;border:1px solid rgba(23,33,27,.14);border-radius:8px;color:var(--ink);background:var(--paper);box-shadow:0 24px 80px #00000057}.ruleset-modal>header,.ruleset-detail-card>header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.ruleset-modal h2,.ruleset-detail-card h3,.ruleset-detail-card p{margin:0}.ruleset-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.ruleset-detail-card{display:grid;gap:12px;min-width:0;padding:14px;border:1px solid rgba(23,33,27,.12);border-radius:8px;background:#fff}.ruleset-detail-card p{color:var(--muted);font-size:.86rem;font-weight:700;line-height:1.35}.ruleset-rule-list{display:grid;gap:7px;margin:0}.ruleset-rule-row{display:grid;grid-template-columns:minmax(120px,.75fr) minmax(0,1.25fr);gap:8px;min-width:0;padding:8px;border-radius:6px;background:var(--linen)}.ruleset-rule-row dt,.ruleset-rule-row dd{min-width:0;margin:0;overflow-wrap:anywhere}.ruleset-rule-row dt{color:var(--muted);font-size:.75rem;font-weight:900;text-transform:uppercase}.ruleset-rule-row dd{font-size:.86rem;font-weight:750;line-height:1.3}.checkbox-row{display:flex!important;grid-template-columns:unset!important;align-items:center;gap:8px!important}.checkbox-row input{width:auto;min-height:auto}.invite-text{margin-bottom:0;overflow-wrap:anywhere}.seat-list{display:grid;gap:7px}.seat-row,.score-row,.state-strip{display:grid;gap:8px;align-items:center}.table-room-overlay,.table-state-overlay{position:absolute;z-index:8;width:min(320px,calc(100% - 32px));border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#fff;background:#07242ec7;box-shadow:0 16px 36px #00000038}.table-room-overlay{top:16px;left:16px}.table-state-overlay{top:190px;right:16px}.table-room-overlay summary,.table-state-overlay summary{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;font-weight:900;cursor:pointer}.table-room-overlay summary span,.table-state-overlay summary span{color:#ffffffbd;font-size:.78rem}.table-room-overlay p,.ready-count{margin:0;padding:0 12px 10px;color:#ffffffc7;overflow-wrap:anywhere}.table-room-overlay .seat-list{padding:0 10px 10px}.table-room-overlay .seat-row{color:var(--ink)}.overlay-actions{display:flex;flex-wrap:wrap;gap:8px;padding:0 12px 12px}.table-scoreboard{position:absolute;z-index:7;top:16px;right:16px;display:grid;gap:9px;width:min(300px,calc(100% - 360px));min-width:230px;padding:11px 12px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#fff;background:#07242ed1;box-shadow:0 12px 26px #0000002e}.table-scoreboard header,.scoreboard-team,.scoreboard-meta{display:flex;align-items:center}.table-scoreboard header{justify-content:space-between;gap:10px}.table-scoreboard header span,.scoreboard-meta span{color:#ffffffb8;font-size:.74rem;font-weight:900;text-transform:uppercase}.scoreboard-teams{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.scoreboard-team{justify-content:space-between;gap:8px;min-width:0;padding:7px 8px;border-radius:8px;background:#ffffff14}.scoreboard-team span{min-width:0;overflow:hidden;font-size:.84rem;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.scoreboard-team b{display:grid;flex:0 0 54px;place-items:center;min-width:54px;min-height:26px;padding:0 5px;border-radius:999px;background:var(--gold);color:#251d08;font-variant-numeric:tabular-nums;line-height:1;white-space:nowrap}.scoreboard-meta{flex-wrap:wrap;gap:5px}.scoreboard-meta span{padding:3px 7px;border-radius:999px;background:#0000002e}.scoreboard-hand-math{display:grid;gap:6px;padding:8px;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#ffffff14}.scoreboard-meld-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px}.scoreboard-meld-row span,.scoreboard-contract-line{min-width:0;border-radius:7px;background:#0000002e;font-size:.72rem;font-weight:900;text-transform:uppercase}.scoreboard-meld-row span{display:flex;align-items:center;justify-content:space-between;gap:5px;padding:4px 6px;color:#ffffffc7}.scoreboard-meld-row b,.scoreboard-contract-line strong{color:var(--gold)}.scoreboard-contract-line{display:grid;grid-template-columns:auto auto minmax(0,1fr);align-items:center;gap:6px;padding:6px 8px}.scoreboard-contract-line span{color:#fffc}.scoreboard-contract-line strong{display:grid;place-items:center;min-width:28px;min-height:24px;border-radius:999px;background:#d8a73129}.scoreboard-contract-line small{min-width:0;overflow:hidden;color:#ffffffb8;text-overflow:ellipsis;white-space:nowrap}.seat-row{grid-template-columns:72px 1fr auto;padding:9px;border-radius:6px;background:var(--linen)}.seat-row span{display:grid;gap:2px;font-weight:800}.seat-row small,.muted{color:var(--muted);overflow-wrap:anywhere}.viewer-seat-row{outline:2px solid rgba(216,167,49,.55)}.score-row{grid-template-columns:1fr auto 1fr auto;padding:12px;border-radius:6px;background:var(--rail);color:#fff}.prompt{margin-bottom:0;padding:12px;border-left:4px solid var(--gold);background:#f6edd4;font-weight:800}.table-stage{min-height:calc(100vh - 142px);padding:10px;border-radius:8px;background:linear-gradient(90deg,rgba(255,255,255,.08),transparent 20%,transparent 80%,rgba(0,0,0,.08)),#21423a;box-shadow:inset 0 0 0 1px #ffffff14}.felt-table{position:relative;width:100%;min-height:calc(100vh - 164px);height:100%;border:14px solid var(--rail);border-radius:64px;overflow:hidden;background:radial-gradient(ellipse at center,rgba(255,255,255,.14),transparent 52%),repeating-linear-gradient(35deg,rgba(255,255,255,.025),rgba(255,255,255,.025) 2px,transparent 2px,transparent 7px),linear-gradient(160deg,var(--felt),var(--felt-dark));box-shadow:inset 0 0 0 2px #ffffff2e,inset 0 0 34px #0000004d,0 18px 40px #111b182e}.felt-table:after{content:"";position:absolute;inset:16%;border:1px solid rgba(255,255,255,.22);border-radius:50%;pointer-events:none}.seat-station{position:absolute;z-index:4;display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:8px;width:min(240px,32%);min-height:58px;padding:8px;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;background:#09262fb8;box-shadow:0 12px 30px #00000038}.seat-slot-top{top:60px;left:50%;transform:translate(-50%)}.seat-slot-left{top:50%;left:16px;transform:translateY(-50%)}.seat-slot-right{top:50%;right:16px;transform:translateY(-50%)}.seat-slot-bottom{left:50%;bottom:286px;transform:translate(-50%)}.active-seat{border-color:#d8a731e6;box-shadow:0 0 0 3px #d8a73138,0 12px 30px #0000003d}.viewer-seat{background:#104438e6}.seat-station.has-speech{z-index:14}.seat-avatar,.score-chip{display:grid;place-items:center;border-radius:999px;background:var(--gold);color:#251d08;font-weight:900}.seat-avatar{width:34px;height:34px}.seat-copy{min-width:0;display:grid;gap:2px}.seat-copy strong,.seat-copy small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.seat-copy small{color:#ffffffc2}.mini-hand{position:relative;width:48px;height:32px}.mini-hand .card-back{position:absolute;top:1px}.mini-hand .card-back:nth-child(1){left:0}.mini-hand .card-back:nth-child(2){left:8px}.mini-hand .card-back:nth-child(3){left:16px}.mini-hand .card-back:nth-child(4){left:24px}.mini-hand span{position:absolute;right:-6px;bottom:-3px;min-width:20px;padding:1px 4px;border-radius:999px;background:#fff;color:var(--ink);font-size:.72rem;font-weight:900;text-align:center}.seat-station.has-speech:after{content:attr(data-speech);position:absolute;z-index:15;min-width:72px;max-width:190px;padding:9px 13px;border:2px solid rgba(216,167,49,.95);border-radius:16px;color:#251d08;background:#fff7d9;box-shadow:0 0 0 3px #07242e33,0 14px 26px #00000047;font-size:.9rem;font-weight:900;line-height:1.05;text-align:center;white-space:nowrap;opacity:1;pointer-events:none}.seat-station.has-speech:before{content:"";position:absolute;z-index:16;width:12px;height:12px;border-right:2px solid rgba(216,167,49,.78);border-bottom:2px solid rgba(216,167,49,.78);background:#fffae8f5;transform:rotate(45deg)}.seat-slot-top.has-speech:after{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.seat-slot-top.has-speech:before{top:-8px;left:50%;transform:translate(-50%) rotate(225deg)}.seat-slot-left.has-speech:after{top:-6px;left:calc(100% + 10px)}.seat-slot-left.has-speech:before{top:16px;left:-8px;transform:rotate(135deg)}.seat-slot-right.has-speech:after{top:-6px;right:calc(100% + 10px)}.seat-slot-right.has-speech:before{top:16px;right:-8px;transform:rotate(-45deg)}.seat-slot-bottom.has-speech:after{bottom:calc(100% + 10px);left:50%;transform:translate(-50%)}.seat-slot-bottom.has-speech:before{bottom:-8px;left:50%;transform:translate(-50%) rotate(45deg)}.felt-center{position:absolute;z-index:3;top:36%;left:50%;display:grid;gap:10px;width:min(310px,42%);transform:translate(-50%,-50%);place-items:center;text-align:center;color:#fff}.deck-stack{position:relative;width:66px;height:88px}.deck-stack .card-back{position:absolute;inset:0}.deck-stack .card-back:last-child{transform:translate(8px,6px) rotate(5deg)}.table-event-active .deck-stack{opacity:.38;transition:opacity .18s ease}.center-status{display:grid;gap:5px;max-width:100%;padding:10px 12px;border-radius:8px;background:#07242ea3;box-shadow:0 10px 22px #0000002e;transition:opacity .18s ease,transform .18s ease}.table-event-active .center-status{opacity:.36;transform:scale(.98)}.center-status span{color:#d6eef3;font-size:.75rem;font-weight:900;text-transform:uppercase}.center-status strong{font-size:clamp(.9rem,1.6vw,1.1rem)}.center-status small{color:#fffc}.bidding-meld-preview{display:grid;grid-template-columns:auto auto;align-items:center;gap:3px 8px;padding:8px;border-radius:8px;background:#ffffff1a}.bidding-meld-preview>span,.bidding-meld-preview>small{grid-column:1 / -1}.bidding-meld-preview>strong{display:grid;place-items:center;min-width:36px;min-height:28px;border-radius:999px;background:var(--gold);color:#251d08}.bidding-meld-preview div{grid-column:1 / -1;display:flex;flex-wrap:wrap;justify-content:center;gap:4px}.bidding-meld-preview b{padding:2px 6px;border-radius:999px;background:#0003;font-size:.72rem}.bidding-action-trail{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;max-width:100%}.bidding-action-trail span{display:inline-flex;gap:4px;align-items:center;padding:3px 7px;border:1px solid rgba(255,255,255,.12);border-radius:999px;color:#fff;background:#0000003d;font-size:.72rem;font-weight:800;text-transform:none}.bidding-action-trail b{color:var(--gold)}.bidding-action-trail .bid-pass-chip{opacity:.76}.table-move-history,.played-card-tableau{position:absolute;z-index:6;display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px;padding:10px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#fff;background:#07242eb8;box-shadow:0 14px 30px #0003;overflow:hidden}.table-move-history{top:92px;left:16px;width:min(310px,calc(100% - 32px));max-height:34vh}.played-card-tableau{top:318px;right:16px;width:min(340px,calc(100% - 32px));max-height:36vh}.table-move-history header,.played-card-tableau header{display:flex;align-items:center;justify-content:space-between;gap:10px}.table-move-history header span,.played-card-tableau header span{padding:2px 7px;border-radius:999px;color:#251d08;background:var(--gold);font-size:.72rem;font-weight:900}.table-move-history ol,.played-trick-list{min-height:0;margin:0;padding:0;overflow:auto}.table-move-history ol{display:grid;gap:5px;list-style:none}.move-event{display:grid;grid-template-columns:44px minmax(0,1fr);align-items:center;gap:6px;min-height:30px;padding:5px 6px;border-radius:6px;background:#ffffff14}.move-event>span:first-child{color:var(--gold);font-size:.68rem;font-weight:900;text-transform:uppercase}.move-event b{min-width:0;overflow:hidden;color:#ffffffe6;font-size:.76rem;text-overflow:ellipsis;white-space:nowrap}.move-card{width:24px;height:34px}.move-card+b{grid-column:3}.move-event:has(.move-card){grid-template-columns:44px 24px minmax(0,1fr)}.move-card .card-face,.played-history-card .card-face{min-height:100%;border-radius:4px}.move-card .card-corner,.played-history-card .card-corner{top:2px;left:2px;font-size:.46rem}.move-card .card-corner small,.played-history-card .card-corner small{font-size:.48rem}.move-card .card-corner-bottom,.played-history-card .card-corner-bottom{right:2px;bottom:2px;left:auto}.move-card .pip-field,.played-history-card .pip-field{width:58%;height:64%;font-size:.38rem}.move-card .pip-count-1 .card-pip,.played-history-card .pip-count-1 .card-pip{font-size:1.7em}.move-card .face-art,.played-history-card .face-art{width:60%;height:62%;border-width:1px;border-radius:4px}.move-card .face-banner,.played-history-card .face-banner{top:1px;min-width:12px;height:9px;font-size:.42rem}.move-card .face-head,.played-history-card .face-head{width:9px;height:9px;border-width:1px}.move-card .face-body,.played-history-card .face-body{width:14px;height:12px;border-width:1px;border-radius:7px 7px 4px 4px;font-size:.46rem}.played-trick-list{display:grid;gap:7px}.played-trick-row{display:grid;gap:5px;padding:7px;border-radius:7px;background:#ffffff14}.current-played-trick{outline:2px solid rgba(216,167,49,.42)}.played-trick-meta{display:flex;justify-content:space-between;gap:8px;font-size:.74rem}.played-trick-meta span{color:#ffffffb8;font-weight:800}.played-trick-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.played-history-card{position:relative;display:block;width:36px;height:50px}.played-history-card small{position:absolute;z-index:2;right:-2px;bottom:-2px;padding:1px 4px;border-radius:999px;color:#251d08;background:var(--gold);font-size:.48rem;font-weight:900}.empty-history-card{border:1px dashed rgba(255,255,255,.2);border-radius:5px;opacity:.55}.trick-board{position:absolute;z-index:2;top:50%;left:50%;width:min(360px,42vw);height:min(260px,30vw);transform:translate(-50%,-50%);pointer-events:none}.trick-board-hold{z-index:5}.trick-hold-banner{position:absolute;top:50%;left:50%;z-index:2;display:grid;gap:2px;min-width:132px;padding:8px 12px;border:1px solid rgba(216,167,49,.72);border-radius:999px;color:#fff;text-align:center;background:#07242ed1;box-shadow:0 12px 28px #0000003d;transform:translate(-50%,-50%);animation:trick-hold-pulse 1.8s ease both}.trick-hold-banner strong{color:var(--gold);font-size:.75rem;text-transform:uppercase}.trick-hold-banner span{font-size:.86rem;font-weight:900}.trick-slot{position:absolute;display:grid;place-items:center;width:82px;height:114px;border:1px dashed rgba(255,255,255,.3);border-radius:8px;color:#ffffffbd;font-size:.78rem;font-weight:900;opacity:.62;transition:opacity .18s ease,border-color .18s ease}.trick-slot .played-table-card{animation:table-card-play-in .98s cubic-bezier(.2,.88,.2,1)}.has-played-card{opacity:1;border-color:transparent}.trick-slot-top .played-table-card{--play-from-x: 0;--play-from-y: -150px;--play-from-rotate: -8deg}.trick-slot-left .played-table-card{--play-from-x: -190px;--play-from-y: 0;--play-from-rotate: -18deg}.trick-slot-right .played-table-card{--play-from-x: 190px;--play-from-y: 0;--play-from-rotate: 18deg}.trick-slot-bottom .played-table-card{--play-from-x: 0;--play-from-y: 190px;--play-from-rotate: 8deg}.trick-slot-top{top:0;left:50%;transform:translate(-50%)}.trick-slot-left{top:50%;left:0;transform:translateY(-50%) rotate(-7deg)}.trick-slot-right{top:50%;right:0;transform:translateY(-50%) rotate(7deg)}.trick-slot-bottom{left:50%;bottom:0;transform:translate(-50%)}.card-button{position:relative;display:grid;place-items:stretch;aspect-ratio:5 / 7;min-height:104px;padding:0;border:1px solid rgba(23,33,27,.22);border-radius:8px;background:#fff;color:var(--ink);box-shadow:0 8px 18px #17211b1a;overflow:hidden;transform:translateY(var(--card-rise, 0px)) rotate(var(--card-rotation, 0deg));transform-origin:center bottom}.card-button:hover:not(:disabled){box-shadow:0 12px 22px #17211b2e;transform:translateY(-10px) rotate(var(--card-rotation, 0deg))}.card-button.selected{outline:3px solid var(--gold);transform:translateY(-18px) rotate(var(--card-rotation, 0deg))}.card-face{position:relative;display:grid;place-items:center;width:100%;height:100%;min-height:96px;border-radius:8px;background:radial-gradient(circle at 50% 45%,rgba(255,255,255,.9),transparent 42%),linear-gradient(145deg,#fff,#f2eee6);color:var(--ink);font-weight:900}.compact-card{min-height:92px;box-shadow:0 8px 18px #0000002e}.compact-card-center{display:grid;justify-items:center;line-height:.9}.compact-card-center strong{font-size:1.4rem}.compact-card-center small{font-size:1.05rem}.card-corner{position:absolute;top:7px;left:7px;display:grid;justify-items:center;line-height:.9;z-index:2}.card-corner small{font-size:.86rem}.card-corner-bottom{inset:auto 7px 7px auto;transform:rotate(180deg)}.pip-field{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(4,1fr);align-items:center;justify-items:center;width:62%;height:70%;font-size:clamp(.82rem,1.55vw,1.42rem);line-height:1}.pip-count-1{display:grid;place-items:center}.pip-count-1 .card-pip{font-size:2.35em}.pip-count-9{grid-template-rows:repeat(3,1fr)}.pip-count-10 .card-pip:nth-child(5){grid-column:2}.pip-count-10 .card-pip:nth-child(10){grid-column:2;grid-row:4}.face-art{position:relative;display:grid;place-items:center;width:58%;height:68%;border:2px solid currentColor;border-radius:8px;overflow:hidden;background:linear-gradient(135deg,rgba(216,167,49,.34),transparent 42%),linear-gradient(315deg,rgba(15,111,134,.18),transparent 48%),#f8f2e8}.face-art:before,.face-art:after{content:"";position:absolute;width:120%;height:2px;background:currentColor;opacity:.22;transform:rotate(35deg)}.face-art:after{transform:rotate(-35deg)}.face-banner{position:absolute;top:6px;z-index:1;display:grid;place-items:center;min-width:24px;height:18px;border-radius:999px;color:#251d08;background:var(--gold);font-size:.82rem}.face-head{z-index:1;width:28px;height:28px;border:2px solid currentColor;border-radius:50% 50% 44% 44%;background:radial-gradient(circle at 38% 42%,currentColor 0 2px,transparent 3px),radial-gradient(circle at 62% 42%,currentColor 0 2px,transparent 3px),linear-gradient(#e6b98d,#d99b67)}.face-body{z-index:1;display:grid;place-items:center;width:42px;height:34px;border:2px solid currentColor;border-radius:18px 18px 10px 10px;background:#ffffff8c;font-size:1.3rem}.rank-queen .face-head{border-radius:50%;background:radial-gradient(circle at 38% 42%,currentColor 0 2px,transparent 3px),radial-gradient(circle at 62% 42%,currentColor 0 2px,transparent 3px),linear-gradient(#f0c3a0,#db8f92)}.rank-jack .face-banner{background:#d7eaf0}.card-back{display:block;width:58px;height:78px;border:3px solid #ffffff;border-radius:8px;background:linear-gradient(45deg,rgba(255,255,255,.16) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.16) 50%,rgba(255,255,255,.16) 75%,transparent 75%),#b65f32;background-size:12px 12px;box-shadow:0 6px 14px #00000038}.mini-card-back{width:25px;height:34px;border-width:2px;border-radius:5px}.pass-flight{position:absolute;z-index:6;top:43%;left:50%;display:flex;gap:5px;transform:translate(-50%,-50%);pointer-events:none}.pass-flight .card-back{animation:pass-card-flight 1.2s ease-in-out infinite}.pass-flight .card-back:nth-child(2){animation-delay:90ms}.pass-flight .card-back:nth-child(3){animation-delay:.18s}.pass-flight .card-back:nth-child(4){animation-delay:.27s}.pass-back-to-partner .card-back{animation-direction:reverse}.table-event-overlay{position:absolute;z-index:11;top:46%;left:50%;pointer-events:none;--event-from-x: 0px;--event-from-y: 0px;--event-from-rotate: 0deg}.event-from-top{--event-from-y: -230px;--event-from-rotate: -8deg}.event-from-left{--event-from-x: -430px;--event-from-rotate: -16deg}.event-from-right{--event-from-x: 430px;--event-from-rotate: 16deg}.event-from-bottom{--event-from-y: 260px;--event-from-rotate: 9deg}.event-card-flight{width:82px;height:114px;transform:translate(-50%,-50%);animation:event-card-to-center var(--event-duration, 1.32s) cubic-bezier(.17,.84,.24,1) both;filter:drop-shadow(0 16px 26px rgba(0,0,0,.28))}.table-event-callout{display:grid;gap:3px;min-width:150px;max-width:260px;padding:10px 13px;border:1px solid rgba(255,255,255,.22);border-radius:8px;color:#fff;text-align:center;background:#07242edb;box-shadow:0 18px 34px #0000003d;transform:translate(-50%,-50%);animation:event-callout-to-center var(--event-duration, 1.28s) ease both}.table-event-callout span{color:var(--gold);font-size:.74rem;font-weight:900;text-transform:uppercase}.table-event-callout strong{font-size:.98rem}.meld-reveal-board{position:absolute;z-index:7;top:20%;left:50%;width:min(920px,calc(100% - 400px));max-height:min(54vh,470px);padding:12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;background:#07242ec7;box-shadow:0 18px 40px #00000038;overflow:auto;transform:translate(-50%)}.meld-reveal-board h2{margin:0;color:#fff;text-align:center;text-transform:uppercase}.meld-context{display:block;margin:2px 0 10px;color:#ffffffc2;text-align:center;text-transform:uppercase}.meld-reveal-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.meld-seat{min-width:0;display:grid;align-content:start;gap:7px;padding:9px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#0000002e}.meld-seat header{display:flex;justify-content:space-between;gap:8px}.meld-seat header span{color:#ffffffb8;font-size:.75rem;font-weight:900;text-transform:uppercase}.meld-down{outline:2px solid rgba(216,167,49,.62)}.meld-private{opacity:.76}.meld-total{display:grid;place-items:center;width:42px;height:42px;margin:0 auto;border-radius:999px;background:var(--gold);color:#251d08;font-weight:900}.meld-card-spread{display:flex;flex-wrap:wrap;justify-content:center;gap:4px;min-height:50px;padding:7px;border:1px solid rgba(255,255,255,.12);border-radius:6px;background:#ffffff12}.meld-card-face{display:block;flex:0 0 34px;width:34px;height:48px}.meld-card-face .card-face,.meld-card-face .compact-card{min-height:48px;border-radius:5px}.meld-card-face .card-corner{top:3px;left:3px;font-size:.52rem}.meld-card-face .card-corner small{font-size:.58rem}.meld-card-face .card-corner-bottom{right:3px;bottom:3px;left:auto}.meld-card-face .pip-field{width:60%;height:66%;font-size:.44rem}.meld-card-face .pip-count-1 .card-pip{font-size:1.8em}.meld-card-face .face-art{width:58%;height:62%;border-width:1px;border-radius:4px}.meld-card-face .face-banner{top:2px;min-width:14px;height:10px;font-size:.48rem}.meld-card-face .face-head{width:11px;height:11px;border-width:1px}.meld-card-face .face-body{width:17px;height:14px;border-width:1px;border-radius:8px 8px 4px 4px;font-size:.56rem}.meld-entry-list{display:flex;flex-wrap:wrap;justify-content:center;gap:4px}.meld-entry-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 6px;border-radius:999px;color:#ffffffe0;background:#0003;font-size:.68rem;font-weight:900;line-height:1.1}.meld-entry-chip b{color:var(--gold)}.meld-entries p,.meld-seat>p{margin:0;font-size:.78rem;line-height:1.25}.suit-hearts,.suit-diamonds{color:var(--red)}.suit-spades,.suit-clubs{color:var(--ink)}.action-bar,.trump-buttons{display:flex;flex-wrap:wrap;gap:10px}.action-bar{min-height:44px;align-items:center;justify-content:center;padding:0;border:0;border-radius:0;background:transparent}.bid-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.bid-jump-control{min-height:40px;display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid rgba(255,255,255,.22);border-radius:8px;background:#ffffff1a;color:#ffffffe6;font-size:.72rem;font-weight:900;letter-spacing:0;text-transform:uppercase}.bid-jump-control input{width:68px;min-height:30px;padding:3px 7px;border:1px solid rgba(255,255,255,.36);border-radius:6px;background:#ffffffe6;color:var(--ink);font:inherit;font-size:.9rem;text-align:center}.state-strip{grid-template-columns:repeat(4,minmax(0,1fr));padding:10px;border-radius:6px;background:var(--linen);font-size:.88rem;font-weight:800}.trick-area,.meld-box,.summary-box{padding:12px;border:1px solid rgba(23,33,27,.12);border-radius:8px;background:#fbfaf6}.table-state-overlay .state-strip,.table-state-overlay .trick-area,.table-state-overlay .meld-box,.table-state-overlay .summary-box,.table-state-overlay>p{margin:0 10px 10px;color:var(--ink)}.played-cards{display:grid;grid-template-columns:repeat(4,minmax(100px,1fr));gap:10px}.played-card{display:grid;gap:6px;padding:12px;border-radius:8px;background:#fff;box-shadow:0 8px 20px #17211b14}.hand-area{padding:10px;border:1px solid rgba(255,255,255,.24);border-radius:8px;background:#07242e80;box-shadow:0 14px 32px #00000038}.hand-area h2{margin-bottom:8px;color:#fff;font-size:.82rem;text-transform:uppercase}.hand-grid{display:grid;grid-template-columns:repeat(12,minmax(54px,1fr));gap:5px;align-items:end}.table-hand-dock{position:absolute;z-index:8;right:18px;bottom:18px;left:18px;display:grid;gap:8px;justify-items:center}.table-hand-dock .action-bar{min-height:42px;padding:7px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#07242eb8;box-shadow:0 12px 26px #0000002e}.table-action-prompt{display:grid;gap:3px;max-width:min(320px,100%);padding:8px 12px;border:1px solid rgba(255,255,255,.18);border-radius:8px;color:#fff;text-align:center;background:#07242ec2;box-shadow:0 12px 26px #0000002e}.table-action-prompt span,.table-action-prompt small{color:#ffffffc2;font-size:.74rem;font-weight:900;text-transform:uppercase}.table-hand-dock .hand-area{width:100%}.error{margin-top:12px;color:var(--red);font-weight:800}@keyframes table-card-play-in{0%{opacity:0;transform:translate(var(--play-from-x, 0),var(--play-from-y, 120px)) rotate(var(--play-from-rotate, 10deg)) scale(.82)}70%{opacity:1}to{opacity:1;transform:translate(0) rotate(0) scale(1)}}@keyframes event-card-to-center{0%{opacity:0;transform:translate(calc(-50% + var(--event-from-x)),calc(-50% + var(--event-from-y))) rotate(var(--event-from-rotate)) scale(.7)}6%{opacity:1}76%{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}92%{opacity:1;transform:translate(-50%,-50%) rotate(0) scale(1)}to{opacity:0;transform:translate(-50%,-50%) rotate(0) scale(1)}}@keyframes event-callout-to-center{0%{opacity:0;transform:translate(calc(-50% + var(--event-from-x)),calc(-50% + var(--event-from-y))) scale(.86)}8%{opacity:1}82%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.98)}}@keyframes speech-bubble-pop{0%{opacity:1;scale:.94}8%,88%{opacity:1;scale:1}to{opacity:0;scale:.96}}@keyframes trick-hold-pulse{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}14%,84%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.98)}}@keyframes pass-card-flight{0%{opacity:0;transform:translate(-120px,-26px) rotate(-18deg)}18%{opacity:1}74%{opacity:1}to{opacity:0;transform:translate(120px,26px) rotate(18deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:1ms!important}}@media(max-width:1120px){.table-info-panel{grid-template-columns:minmax(0,1fr) auto;align-items:start}.seat-list,.score-row,.prompt,.invite-text{grid-column:1 / -1}.hand-grid{grid-template-columns:repeat(6,minmax(54px,1fr))}.table-room-overlay,.table-state-overlay{width:min(300px,calc(50% - 24px))}.trick-board{width:320px;height:230px}}@media(max-width:760px){.app-shell{padding:10px}.table-surface{min-height:calc(100vh - 20px);padding:10px}.top-bar,.grid,.table-info-panel,.state-strip{grid-template-columns:1fr;display:grid}.status-pill{width:fit-content}.ruleset-segmented,.ruleset-detail-grid{grid-template-columns:1fr}.ruleset-modal{max-height:calc(100vh - 20px);padding:14px}.ruleset-rule-row{grid-template-columns:1fr}.table-stage{min-height:1080px;padding:8px}.felt-table{min-height:1064px;border-width:10px;border-radius:42px}.seat-station{width:calc(100% - 28px);max-width:260px}.seat-slot-top{top:124px}.seat-slot-left,.seat-slot-right{top:auto;transform:none}.seat-slot-left{left:14px;bottom:540px}.seat-slot-right{top:236px;right:14px}.seat-slot-bottom{bottom:470px}.felt-center{top:34%;width:min(260px,74%)}.deck-stack{width:52px;height:70px}.deck-stack .card-back{width:46px;height:62px}.center-status{gap:3px;padding:8px 10px}.trick-board{top:49%;width:250px;height:210px}.trick-slot{width:58px;height:80px}.compact-card{min-height:74px}.pip-field{font-size:.84rem}.face-art{width:62%;height:66%}.face-head{width:20px;height:20px}.face-body{width:30px;height:24px;font-size:.95rem}.hand-grid{grid-template-columns:repeat(4,minmax(58px,1fr));gap:8px}.played-cards{grid-template-columns:repeat(2,minmax(100px,1fr))}.table-room-overlay{top:10px;right:10px;left:10px;z-index:9;width:auto}.table-state-overlay{display:none}.table-scoreboard{top:74px;right:10px;left:10px;width:auto;min-width:0}.table-move-history{top:174px;right:10px;left:10px;width:auto;max-height:124px}.played-card-tableau{top:596px;right:10px;left:10px;width:auto;max-height:170px}.table-hand-dock{right:10px;bottom:10px;left:10px}.card-button{min-height:104px}.pass-flight{top:42%}.meld-reveal-board{top:405px;width:calc(100% - 44px);padding:10px}.meld-reveal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.app-shell.is-entry{background:radial-gradient(circle at 16% 12%,rgba(216,167,49,.2),transparent 22rem),radial-gradient(circle at 84% 20%,rgba(15,111,134,.35),transparent 24rem),linear-gradient(145deg,#0b4e79,#0f6f86 44%,#17352d)}.app-shell.is-entry .table-surface{border-color:#ffffff29;color:#fff;background:linear-gradient(145deg,rgba(255,255,255,.1),transparent 38%),#07242eb3;box-shadow:0 26px 90px #00000047}.app-shell.is-entry .top-bar{padding:6px 6px 12px}.app-shell.is-entry .eyebrow,.app-shell.is-entry .room-form label,.app-shell.is-entry .lobby-empty{color:#ffffffb8}.app-shell.is-entry .status-pill{border-color:#d8a73152;color:#f7e5a7;background:#d8a7311f}.app-shell.is-entry .panel{border-color:#ffffff26;color:#fff;background:linear-gradient(145deg,rgba(255,255,255,.08),transparent 42%),#061b2dc7;box-shadow:0 18px 40px #0003}.app-shell.is-entry .panel h2,.app-shell.is-entry .lobby-browser h3{color:#fff9e8}.app-shell.is-entry .room-form input,.app-shell.is-entry .room-form select{border-color:#ffffff2e;color:#fff9e8;background:#ffffff14}.app-shell.is-entry .ruleset-selector legend{color:#ffffffb8}.app-shell.is-entry .ruleset-help-button{border-color:#ffffff2e;color:#fff9e8;background:#ffffff1a}.app-shell.is-entry .ruleset-choice{border-color:#ffffff2e;color:#fff9e8;background:#ffffff14}.app-shell.is-entry .ruleset-choice.is-selected{border-color:#d8a731eb;color:#211805;background:var(--gold)}.app-shell.is-entry .room-form select option{color:var(--ink)}.lobby-browser{display:grid;gap:10px;margin-bottom:14px}.lobby-browser-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.lobby-browser-header h3{margin:0;font-size:1rem}.lobby-browser-header span{color:var(--gold);font-size:.78rem;font-weight:900;text-transform:uppercase}.lobby-refresh{min-height:34px}.lobby-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.lobby-controls label{display:grid;gap:4px;color:#ffffffbd;font-size:.72rem;font-weight:900;text-transform:uppercase}.lobby-controls select{min-width:0;min-height:36px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#fff9e8;background:#ffffff14;font:inherit;text-transform:none}.lobby-controls option{color:var(--ink)}.lobby-list{display:grid;gap:8px}.lobby-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:4px 10px;width:100%;min-height:62px;padding:10px;border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#fff;text-align:left;background:linear-gradient(135deg,rgba(216,167,49,.14),transparent 45%),#ffffff14}.lobby-row:hover:not(:disabled){border-color:#d8a7318a;box-shadow:0 10px 26px #0000002e}.lobby-row span{display:grid;gap:2px;min-width:0}.lobby-row strong,.lobby-row small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby-row strong{color:#fff9e8;font-size:.96rem}.lobby-row small{color:#ffffffad;font-size:.78rem;font-weight:800}.lobby-row b{display:grid;place-items:center;min-width:76px;min-height:32px;border-radius:999px;color:#251d08;background:var(--gold);font-size:.85rem;letter-spacing:0}.lobby-row em{grid-column:1 / -1;color:#ffffffb8;font-size:.74rem;font-style:normal;font-weight:900;text-transform:uppercase}.lobby-empty{margin:0;font-size:.9rem;font-weight:800}.seat-avatar,.scoreboard-team{border-color:color-mix(in srgb,var(--team-accent, #fff) 44%,transparent)}.seat-avatar{background:linear-gradient(135deg,var(--team-color, #2f7d5c),color-mix(in srgb,var(--team-color, #2f7d5c) 72%,#000));color:var(--team-text, #fff);font-size:.72rem}.scoreboard-team{box-shadow:inset 0 0 0 1px color-mix(in srgb,var(--team-color, #2f7d5c) 34%,transparent)}.card-button.from-partner{border-color:var(--team-accent, #f3c766);box-shadow:0 0 0 2px color-mix(in srgb,var(--team-accent, #f3c766) 60%,transparent)}
