:root{font-family:Space Grotesk,Inter,system-ui,-apple-system,sans-serif;color:#e2e8f0;background:radial-gradient(circle at 60% 14%,rgba(215,179,90,.22) 0%,rgba(215,179,90,.07) 20%,transparent 44%),radial-gradient(circle at 14% 86%,rgba(120,53,15,.14) 0%,transparent 40%),linear-gradient(165deg,#15171c,#0e1014 42%,#08090c);min-height:100%;--glass: rgba(20, 22, 29, .74);--border: rgba(201, 162, 74, .24);--glow: rgba(201, 162, 74, .28);--accent: #16a34a;--accent2: #f97316;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--topbar-h: 56px;--hostbar-h: 64px;--top-bar-h: var(--topbar-h);--host-bar-h: var(--hostbar-h);--vh: 1vh;--vw: 1vw;--card-w: clamp(58px, 9vmin, 118px);--card-h: calc(var(--card-w) * 1.45)}*{box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%;text-size-adjust:100%}body{margin:0;background:transparent;height:100%}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 54% 20%,rgba(215,179,90,.11),transparent 52%),radial-gradient(circle at 34% 11%,rgba(203,213,225,.04),transparent 38%);pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(255,255,255,.03) 1px,transparent 0);background-size:3px 3px;opacity:.35;pointer-events:none;z-index:0}.page{max-width:1080px;margin:0 auto;padding:10px 20px 48px;position:relative;z-index:1}.hero-shell{position:relative;overflow:hidden}.hero-shell:before,.hero-shell:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(120,53,15,.18),transparent 38%),radial-gradient(circle at 80% 20%,rgba(215,179,90,.18),transparent 36%),radial-gradient(circle at 50% 72%,rgba(161,98,7,.14),transparent 42%);filter:blur(20px);z-index:0}.hero{display:grid;gap:12px;margin-bottom:28px;position:relative;z-index:1;padding:24px 0}.eyebrow{text-transform:uppercase;letter-spacing:.08em;font-size:12px;margin:0;color:#cbd5e1}h1{margin:0;font-size:clamp(32px,6vw,46px);line-height:1.1;color:#f8fafc}.lede{margin:0;max-width:720px;color:#cbd5e1;line-height:1.6}.glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--glass);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:0 20px 60px #00000040,0 0 0 1px #ffffff0d}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:center}.choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin:16px 0;max-width:1100px;align-items:start}@media (max-width: 768px){.choice-grid{grid-template-columns:1fr;max-width:640px}}.choice-card h2{margin:0 0 8px;color:#f8fafc}.choice-card{display:grid;gap:10px}.choice-card .button{justify-self:start}.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:4px}.cta-row.wrap{justify-content:flex-start}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;border-radius:12px;border:2px solid transparent;font-size:16px;font-weight:700;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;color:#0c1224}.button-content{display:inline-flex;align-items:center}.button-spinner{width:12px;height:12px;border-radius:999px;border:2px solid currentColor;border-right-color:transparent;animation:spinner-rotate .8s linear infinite}.button.loading{cursor:wait}.button:disabled{opacity:.72;cursor:not-allowed}.button.small{padding:6px 10px;font-size:12px}.button.primary{background:#0f172acc;color:#f8fafc;border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 24px #02061773}.button.success{background:linear-gradient(140deg,#22c55ee6,#10b981e6);color:#07210f;border:1px solid rgba(34,197,94,.6);box-shadow:0 10px 24px #16a34a59}.button.ghost{background:#ffffff14;border-color:#ffffff2e;color:#e2e8f0}.button.tiny{padding:4px 8px;font-size:12px}.button:hover{transform:translateY(-1px)}.button.primary:hover{box-shadow:0 0 0 1px #fbbf2459,0 12px 30px #f59e0b47}.button.success:hover{box-shadow:0 0 0 1px #22c55e66,0 12px 30px #16a34a59}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#cbd5e1}.playground-menu{position:fixed;top:calc(var(--safe-top) + 12px);right:12px;z-index:40;display:grid;gap:8px;justify-items:end}.playground-panel{min-width:180px;padding:12px}.input,select.input{background:#0f172ab3;border:1px solid rgba(148,163,184,.3);border-radius:12px;color:#e2e8f0;padding:10px 12px;font-size:14px}.input-error{border-color:#f87171b3;box-shadow:0 0 0 2px #f871714d;background:#f8717114}.error-text{color:#f87171f2;margin-top:4px;font-weight:600}.home-wrap{max-width:1000px;margin:0 auto;padding:55px 20px 20px;display:grid;gap:12px}.home-wrap:before{content:none}.home-header h2{margin:0 0 8px;color:#f8fafc;font-size:clamp(22px,3.4vw,34px)}.home-actions{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.home-card{padding:14px;display:grid;gap:10px;background:#14171ef0;border-radius:16px;border:1px solid rgba(201,162,74,.34);box-shadow:0 14px 28px #02061773;transition:transform .16s ease,box-shadow .16s ease,background .16s ease,border-color .16s ease;cursor:pointer;min-width:0}.home-card h3{margin:0;color:#f8fafc;font-size:16px;font-weight:700}.home-global-inputs{margin-top:-1px;padding:8px 10px}.input-code{letter-spacing:.18em;text-transform:uppercase;font-variant-numeric:tabular-nums}.cta-row.compact{gap:8px}.input{padding:6px 10px;border-radius:10px;border-color:#c9a24a33;background:#0e1016c7}.home-card .button.primary{width:auto;justify-self:start}.home-card.primary{transform:translateY(-1px);background:#181c24fa;border-color:#d7b35a7a;box-shadow:0 18px 46px #0206178c}.home-card.secondary{opacity:.85}.home-card:hover{transform:translateY(-5px);background:#1c212b;border-color:#e5c270b8;box-shadow:0 28px 80px #020617a6}.micro{margin:0;font-size:12px;color:#e2e8f0b3}.pin-input{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.4rem;justify-content:center;width:100%;max-width:100%;margin:0 auto}.pin-box{width:100%;min-width:0;height:3.4rem;aspect-ratio:auto;background:#090c14f2;border:2px solid rgba(226,232,240,.45);border-radius:6px;text-align:center;font-size:clamp(22px,3.4vw,30px);color:#f8fafc;letter-spacing:.14em;outline:none;box-shadow:inset 0 0 0 1px #ffffff0f}.pin-box:hover{border-color:#f0f8ffcc}.pin-box:focus{border-color:#fbbf24;box-shadow:0 0 0 4px #fbbf2459,0 0 32px #f59e0b80}.input:focus{outline:none;border-color:#94a3b88c;box-shadow:0 0 0 3px #94a3b838}.playground-menu .button{opacity:.4;transform:scale(.75)}.home-links{display:flex;gap:10px;justify-content:center;align-items:center;margin-top:8px}.link-button{background:transparent;border:0;padding:0;color:#e2e8f0b3;font-size:12px;cursor:pointer}.link-button:hover{color:#f8fafce6}.link-dot{color:#e2e8f066}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#06070aa8;display:grid;place-items:center;z-index:50;padding:20px}.modal-card{background:radial-gradient(circle at 70% 12%,rgba(201,162,74,.07),transparent 42%),#101218fa;border:1px solid rgba(201,162,74,.34);border-radius:16px;padding:20px;width:min(520px,100%);box-shadow:0 24px 60px #02061799;max-height:80vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.modal-header h3{margin:0;color:#f8fafc}.modal-close{background:transparent;border:1px solid rgba(148,163,184,.4);color:#e2e8f0;padding:6px 10px;border-radius:10px;cursor:pointer}.modal-close:hover{border-color:#e2e8f0cc}.modal-body{display:grid;gap:14px;max-height:calc(80vh - 80px);overflow:auto;padding-right:4px}.modal-list{margin:0;padding-left:22px;color:#e2e8f0cc;line-height:1.6}.modal-section h4{margin:0 0 6px;color:#f8fafc;font-size:14px;letter-spacing:.04em;text-transform:uppercase}.lobby-shell{display:grid;gap:16px;padding-top:25px;padding-bottom:calc(var(--host-bar-h) + 26px + var(--safe-bottom))}.lobby-header{display:grid;gap:12px}.lobby-header h2{margin:0;color:#f8fafc;font-size:clamp(20px,3vw,32px)}.lobby-actions{display:flex;gap:10px;flex-wrap:wrap}.settings-summary{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:0;padding:8px 12px;border-radius:12px;background:#0f172aa6;border:1px solid rgba(226,232,240,.15);color:#e2e8f0d9;font-size:12px;font-weight:600}.lobby-room{display:inline-flex;align-items:center;gap:8px;background:#121c30e6;border:1px solid rgba(226,232,240,.2);border-radius:999px;padding:6px 12px;width:fit-content}.room-pill{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#e2e8f099}.room-code{font-weight:700;color:#f8fafc;letter-spacing:.08em}.room-copy{background:#ffffff14;border:1px solid rgba(226,232,240,.2);color:#e2e8f0;border-radius:999px;padding:4px 10px;cursor:pointer}.settings-button{background:#fbbf242e;border:1px solid rgba(251,191,36,.42);color:#e2e8f0;border-radius:999px;padding:4px 10px;cursor:pointer}.lobby-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start}.lobby-section{background:#121c30b3;border:1px solid rgba(226,232,240,.2);border-radius:16px;padding:14px;display:grid;gap:12px;min-height:0}.section-header h3{margin:0 0 8px;color:#f8fafc}.summary-row{display:flex;gap:8px;flex-wrap:wrap}.summary-pill{background:#ffffff14;border:1px solid rgba(226,232,240,.15);border-radius:999px;padding:4px 10px;font-size:12px;color:#e2e8f0bf}.summary-pill.complete{color:#e2e8f0;border-color:#94a3b899;background:#94a3b81f}.summary-pill.complete:after{content:"✓";margin-left:6px;color:#e2e8f0e6}.roles-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.role-card{background:#0e1626b3;border:1px solid rgba(226,232,240,.2);border-radius:12px;padding:10px;display:grid;gap:8px}.role-name{font-weight:600;color:#f8fafc}.role-stepper{display:grid;grid-template-columns:30px 1fr 30px;align-items:center;gap:6px}.role-step{background:#ffffff14;border:1px solid rgba(226,232,240,.2);border-radius:8px;color:#e2e8f0;height:28px;cursor:pointer}.role-count{text-align:center;font-weight:600}.role-chip-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.role-chip{display:grid;gap:8px;padding:8px 10px;background:#0e1626b3;border:1px solid rgba(226,232,240,.2);border-radius:12px;color:#e2e8f0;cursor:pointer;text-align:left;transition:transform .14s ease,border-color .14s ease,background .14s ease}.role-chip.readonly{cursor:default}.role-chip.readonly:hover{transform:none;border-color:#e2e8f033;background:#0e1626b3}.role-chip-info{display:flex;align-items:center;gap:6px}.role-chip-count{background:#ffffff14;border:1px solid rgba(226,232,240,.2);border-radius:999px;padding:2px 8px;font-size:12px;width:fit-content}.role-pair{background:#22c55e33;border:1px solid rgba(34,197,94,.4);border-radius:999px;padding:2px 6px;font-size:10px;color:#86efac}.role-chip:hover{transform:translateY(-2px);border-color:#e2e8f066;background:#162034cc}.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:10px;background:#0e162699;border:1px solid rgba(226,232,240,.15)}.settings-label{display:inline-flex;align-items:center;gap:6px;color:#e2e8f0;font-weight:600}.help-wrap{position:relative;display:inline-flex;align-items:center}.help-icon{width:18px;height:18px;border-radius:999px;border:1px solid rgba(148,163,184,.45);background:#0f172a99;color:#cbd5f5;font-size:12px;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:help;padding:0}.help-wrap .help-icon:after{content:none}.help-bubble{position:absolute;top:24px;left:50%;transform:translate(-50%);z-index:2;min-width:200px;max-width:260px;padding:8px 10px;border-radius:10px;background:#0f172af5;border:1px solid rgba(148,163,184,.35);color:#e2e8f0;font-size:12px;line-height:1.35;box-shadow:0 12px 28px #02061773}.help-bubble-above{bottom:26px;top:auto}.help-bubble-below{top:26px}.settings-grid{margin-top:12px;display:grid;gap:10px}.settings-field{display:grid;gap:6px}.settings-help{color:#e2e8f0ad;font-size:12px;line-height:1.35}.settings-select{background:#0f172aa6;border:1px solid rgba(226,232,240,.25);border-radius:10px;color:#f8fafc;padding:8px 10px;font-weight:600;cursor:pointer}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:12px 4px 4px;border-top:1px solid rgba(148,163,184,.2);margin-top:6px;align-items:center}.modal-footer .modal-close{border-color:#94a3b84d;padding:8px 12px}.toggle{width:42px;height:22px;border-radius:999px;background:#94a3b84d;position:relative}.toggle:after{content:"";width:18px;height:18px;border-radius:50%;background:#f8fafc;position:absolute;top:2px;left:2px;transition:transform .16s ease}.toggle.on{background:#22c55e66}.toggle.on:after{transform:translate(20px)}.players-list{display:grid;gap:8px;align-content:start}.player-ready-cta{display:flex;gap:10px;margin-top:12px}.player-ready-cta .button{flex:1}.lobby-bottom-bar{z-index:26}.player-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:12px;background:#0e162699;border:1px solid rgba(226,232,240,.15)}.player-actions{display:inline-flex;align-items:center;gap:8px}.status-pill{border-radius:999px;padding:4px 10px;font-size:12px;border:1px solid rgba(226,232,240,.2)}.kick-button{background:transparent;border:1px solid rgba(148,163,184,.35);color:#e2e8f0d9;border-radius:999px;padding:4px 10px;font-size:12px;cursor:pointer}.kick-button:hover{background:#f871711f;border-color:#f8717173;color:#fecaca}@media (min-width: 1100px){.lobby-shell{gap:14px;max-width:1060px;margin:0 auto;padding-bottom:calc(var(--host-bar-h) + 24px + var(--safe-bottom))}.lobby-grid{grid-template-columns:minmax(520px,1.15fr) minmax(420px,.95fr);gap:14px}.lobby-section{padding:14px 16px;gap:10px}.section-header h3{font-size:30px;margin-bottom:6px}.role-chip-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.role-chip{min-height:50px;padding:8px 10px;border-radius:12px}.role-chip-info{font-size:15px}.role-chip-count{font-size:13px;padding:1px 9px}.players-list{max-height:clamp(240px,42vh,460px);overflow-y:auto;padding-right:4px}.player-row{min-height:56px;border-radius:12px;padding:8px 10px}.player-row strong{font-size:16px}.lobby-bottom-bar{width:min(420px,calc(100vw - 32px));justify-content:center}}.status-pill.ready{color:#16a34a;border-color:#22c55e66}.status-pill.waiting{color:#e2e8f0}.ready-status{font-weight:600}.ready-status.ready{color:#22c55e}.ready-status.waiting{color:#f87171}.host-badge{margin-left:8px;padding:2px 6px;border-radius:999px;border:1px solid rgba(148,163,184,.4);font-size:10px;font-weight:700;color:#cbd5f5;text-transform:uppercase;letter-spacing:.04em}@media (max-width: 640px){.home-wrap{padding:55px 20px 20px}.home-actions{grid-template-columns:1fr}}@media (max-width: 480px){.modal-body{padding-right:0}.modal-list{padding-left:26px}}@media (max-width: 480px){.pin-input{gap:.25rem}.pin-box{height:2.6rem;font-size:1.1rem;letter-spacing:.08em}}@media (min-width: 900px){.home-actions{grid-template-columns:1.15fr .85fr}}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:12px}.card{aspect-ratio:2 / 3;border-radius:14px;background:#0f172ab3;border:1px solid rgba(148,163,184,.25);display:grid;place-items:center;color:#e2e8f0;font-weight:600;width:100%}.card-face{width:100%;height:100%;padding:8px;text-align:center;display:grid;align-items:start;justify-items:center;position:relative}.field input,select,input{padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.18);font-size:14px;min-width:140px;background:#ffffff14;color:#e2e8f0}select{min-width:160px}select option{color:#0f172a;background-color:#f8fafc}input[type=number]{width:80px}.error{color:#f97316;font-weight:700}.pill-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.pill{padding:6px 10px;border-radius:999px;background:#00000059;color:#f8fafc;font-weight:700;font-size:13px;border:1px solid rgba(255,255,255,.18);box-shadow:0 6px 16px #00000059}.pill.small{padding:4px 8px;font-size:12px}.pill.success{background:#16a34a33;border-color:#16a34a66;color:#22c55e}.pill.error-pill{background:#ef444433;border-color:#ef444466;color:#ef4444}.icon-button{background:transparent;border:none;color:inherit;cursor:pointer;margin-left:6px;font-size:14px}.menu-button{border:1px solid rgba(255,255,255,.18);border-radius:10px;padding:6px 10px;font-size:16px;color:#e2e8f0;background:#ffffff14}.menu-dropdown{position:absolute;top:44px;right:12px;background:#0d111ff2;border:1px solid var(--border);border-radius:10px;padding:10px;box-shadow:0 12px 30px #00000059;display:grid;gap:8px;min-width:200px;z-index:10}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:9}.pill-row.mini{gap:6px}.game-shell{min-height:calc(var(--vh, 1vh) * 100);background:radial-gradient(ellipse at top,rgba(255,255,255,.06),transparent 60%);padding:0 8px;overflow:hidden;display:flex;flex-direction:column}.app-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:var(--glass);border:1px solid var(--border);box-shadow:0 8px 30px #00000040}.bar-left,.bar-right{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.board{flex:1;display:grid;place-items:center;justify-items:stretch;height:calc(var(--vh, 1vh) * 100 - var(--topbar-h) - var(--hostbar-h));padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);margin-top:12px}.panel{background:var(--glass);border:1px solid var(--border);border-radius:16px;padding:12px;box-shadow:0 12px 40px #0003}.table-panel{width:100%;max-width:none}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.panel-head h3{margin:0;color:#f8fafc}.panel-body{color:#e2e8f0}.players-inline{max-height:240px;overflow-y:auto;padding:6px 2px;scrollbar-width:thin}.stack{display:grid;gap:10px}.row{display:flex;gap:8px;align-items:center}.row.wrap{flex-wrap:wrap}.player-grid{display:grid;gap:10px}.player-card{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:10px;border-radius:12px;border:1px solid var(--border);background:#ffffff0d}.player-card.you{border-color:#16a34a66;box-shadow:0 0 0 1px #16a34a4d}.avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,#b45309,#f59e0b);display:grid;place-items:center;color:#fff;font-weight:800;letter-spacing:.02em}.player-line{display:flex;gap:6px;align-items:center}.player-name{font-weight:800;color:#f8fafc}.player-status{display:flex;align-items:center;gap:8px;color:#cbd5e1;font-size:13px}.chip{background:#ffffff1f;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:4px 8px;font-weight:700;color:#e2e8f0}.chip.accent{background:#16a34a33;border-color:#16a34a66;color:#22c55e}.dot{width:10px;height:10px;border-radius:999px;background:#cbd5e1}.dot.on{background:#22c55e;box-shadow:0 0 0 6px #22c55e33}.private{background:#ffffff0a;padding:8px 10px;border-radius:8px;border:1px dashed rgba(255,255,255,.2)}.token-grid{display:grid;gap:10px}.token-row{border:1px solid var(--border);border-radius:10px;padding:10px;display:grid;gap:8px;background:#ffffff0a}.token-controls{display:grid;gap:6px}.token-cell{display:flex;align-items:center;gap:8px;justify-content:space-between}.token-count{font-weight:700}.token-buttons{display:flex;gap:4px}.table{position:relative;width:100%;max-width:min(1200px,100vw - 16px);min-width:0;min-height:0;padding:12px;margin:0 auto;background:linear-gradient(180deg,#ffffff0f,#ffffff05);border-radius:22px;border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 60px #0000008c}.table.table-grid{display:flex;flex-direction:column;align-items:center;gap:12px;padding:0}.seats-auto{width:100%;max-width:1400px;grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.seats-auto.mid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.seats-auto.many{grid-template-columns:repeat(auto-fit,minmax(110px,1fr))}.seats-auto.compact{grid-template-columns:repeat(auto-fit,minmax(90px,1fr))}.seats-auto.compact.mid{grid-template-columns:repeat(auto-fit,minmax(82px,1fr))}.seats-auto.compact.many{grid-template-columns:repeat(auto-fit,minmax(64px,1fr))}.seats-auto.compact.many .seat--grid{max-width:120px}.table.table-surround{display:grid;grid-template-areas:"top top top" "left center right" "bottom bottom bottom";grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto 1fr auto;gap:12px;padding:12px}.surround{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.top-band{grid-area:top}.bottom-band{grid-area:bottom}.middle-band{grid-area:center;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px}.left-band{grid-area:left}.right-band{grid-area:right}.table.table-grid .center-row{margin-bottom:calc(var(--card-h) * .15)}.center-row{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:12px;width:100%}.center-cards.row{display:flex;justify-content:center;align-items:center;gap:12px}.center-cards.triangle{position:relative;width:calc(var(--card-w) * 2.2);height:calc(var(--card-h) * 1.75)}.center-cards.triangle .c0{position:absolute;left:0%;top:0%}.center-cards.triangle .c1{position:absolute;left:48%;top:0%}.center-cards.triangle .c2{position:absolute;left:24%;top:34%;transform:translate(-50%) scale(.96) translateY(14px)}.seats-grid{position:relative;z-index:3;display:grid;gap:12px;padding:16px;width:100%;max-width:100%;justify-items:center;align-items:start}.seats-grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.seats-grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.table-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:2;pointer-events:none}.table.table-grid .table-center{position:static;left:auto;top:auto;transform:none;margin-top:8px;pointer-events:auto}.card-slot{width:var(--card-w);height:var(--card-h);position:relative}.card-slot.actionable{cursor:pointer}.suspect-select{position:absolute;left:50%;bottom:6px;transform:translate(-50%);z-index:4}.suspect-select select{min-width:120px;padding:6px 10px;border-radius:999px;border:1px solid rgba(148,163,184,.45);background:#0c101aeb;color:#e2e8f0;font-size:.75rem;text-transform:capitalize}.mini-modal{position:fixed;left:50%;bottom:28px;transform:translate(-50%);z-index:60;pointer-events:none}.mini-modal.host{bottom:96px}.result-panel{position:fixed;left:50%;top:18%;transform:translate(-50%);z-index:65;pointer-events:none}.result-card-shell{min-width:220px;max-width:min(90vw,460px);padding:14px 16px;border-radius:16px;background:radial-gradient(circle at 62% 10%,rgba(201,162,74,.08),transparent 42%),#0e1015f2;border:1px solid rgba(201,162,74,.32);color:#e2e8f0;text-align:center;box-shadow:0 18px 40px #0006}.result-title{font-size:.9rem;font-weight:700;letter-spacing:.02em;margin-bottom:10px}.result-subtitle{margin-top:10px;font-size:.8rem;opacity:.7}.result-cards{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.result-card{width:120px}.result-card img,.result-card .card-face{width:100%;height:auto;border-radius:5px;box-shadow:0 10px 24px #00000059,0 0 0 1px #ffffff14;object-fit:cover}.mini-modal-card{padding:10px 14px;border-radius:12px;background:radial-gradient(circle at 66% 12%,rgba(201,162,74,.08),transparent 44%),#0f1218f0;border:1px solid rgba(201,162,74,.3);color:#e2e8f0;box-shadow:0 10px 30px #00000059;text-align:center;max-width:260px}.mini-modal-text{font-size:.85rem;margin-top:4px}.hero-card{display:grid;justify-items:center;width:260px;gap:10px}.hero-card img,.hero-card .card-face{width:100%;height:auto;max-height:360px;background-size:contain;background-repeat:no-repeat;background-position:center;border-radius:16px;box-shadow:0 12px 40px #0006,0 0 0 1px #ffffff14;object-fit:cover}.hero-card.framed{margin:0 auto}.under-card{margin-top:14px;font-size:18px;font-weight:800;color:#f8fafc;text-transform:capitalize;text-shadow:0 3px 12px rgba(0,0,0,.35)}@media (max-width: 640px){:root{--card-w: clamp(30px, 14vw, 60px);--card-h: calc(var(--card-w) * 1.42)}.table{padding:8px;gap:10px}.seats-grid{gap:8px;padding:8px 6px 10px}.seats-auto{grid-template-columns:repeat(auto-fit,minmax(76px,1fr))}.center-row{gap:10px}}@media (max-width: 950px){:root{--card-w: clamp(38px, 7.2vw, 78px);--card-h: calc(var(--card-w) * 1.4)}.table{padding:10px;gap:10px}.seats-grid{gap:8px;padding:8px 6px 10px}.seats-auto{grid-template-columns:repeat(auto-fit,minmax(96px,1fr))}.seats-auto.mid{grid-template-columns:repeat(auto-fit,minmax(90px,1fr))}.seats-auto.many{grid-template-columns:repeat(auto-fit,minmax(82px,1fr))}.seats-auto.compact{grid-template-columns:repeat(auto-fit,minmax(78px,1fr))}.seats-auto.compact.mid{grid-template-columns:repeat(auto-fit,minmax(72px,1fr))}.seats-auto.compact.many{grid-template-columns:repeat(auto-fit,minmax(66px,1fr))}.center-row{gap:8px}}@media (max-height: 860px){:root{--card-w: clamp(40px, 7vw, 80px);--card-h: calc(var(--card-w) * 1.35)}.table-panel .panel-body{overflow-y:auto}.table{padding:6px;gap:8px}.seats-grid{gap:8px;padding:8px 6px 10px}.card-footer{margin-top:4px;font-size:11px}.vote-badge{margin-top:4px;padding:4px 8px;font-size:11px}}@media (max-height: 450px){:root{--card-w: clamp(34px, 6vw, 72px);--card-h: calc(var(--card-w) * 1.3)}.table-panel .panel-body{padding:calc(var(--top-bar-h) + 6px) 8px calc(var(--host-bar-h) + 10px)}.table{padding:4px;gap:6px}.seats-grid{gap:6px;padding:6px 4px 8px}.card-footer{margin-top:2px;font-size:10px}.vote-badge{margin-top:2px;padding:3px 6px;font-size:10px}}.table-info{position:fixed;top:calc(12px + var(--safe-top));left:12px;right:12px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px;pointer-events:auto;z-index:15;background:#0c101aeb;border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px 12px;box-shadow:0 12px 30px #00000059;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.info-left,.info-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.info-right{justify-content:flex-end;margin-left:auto}.info-pill{display:inline-flex;align-items:center;gap:6px}.share-pill{flex-wrap:wrap;gap:10px}.share-link{color:#e2e8f0;font-weight:600;text-decoration:underline}.share-link:hover{color:#fff}.phase-badge{padding:6px 10px;border-radius:999px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);font-weight:700;color:#e2e8f0}.phase-chip{justify-self:center;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:14px;background:linear-gradient(135deg,#b453093d,#fbbf2438);border:1px solid rgba(255,255,255,.2);color:#e2e8f0;box-shadow:0 10px 30px #00000040}.phase-stack{justify-self:center;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.phase-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;opacity:.8}.phase-value{font-weight:800}.floating-settings{position:fixed;top:12px;right:12px;z-index:16}.settings-icon{font-size:18px;border:1px solid rgba(255,255,255,.25);background:#ffffff14;border-radius:10px;padding:8px 10px;color:#f8fafc}.card-face{width:100%;height:100%;position:relative;border-radius:12px;border:1px solid var(--border);display:grid;place-items:center;color:#e2e8f0;background:linear-gradient(135deg,#ffffff1f,#ffffff14);box-shadow:0 16px 36px #00000073,0 0 0 1px #ffffff14}.card-face.down{background:linear-gradient(135deg,#0b1222,#11182c);background-size:cover;background-position:center;background-repeat:no-repeat;padding:0}.card-face.up{background:linear-gradient(135deg,#16a34a,#f59e0b);color:#0c1224;background-size:cover;background-position:center}.card-face.suspect-marked:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#090c145c;mix-blend-mode:multiply;pointer-events:none;z-index:1}.card-face .suspect-tokens{position:absolute;top:6px;right:6px;display:flex;gap:8px;z-index:4}.card-face.down.suspect-marked .suspect-tokens{top:50%;left:50%;right:auto;transform:translate(-50%,-50%);gap:0;align-items:center;justify-content:center;width:100%;height:100%}.card-face .role-token{width:clamp(28px,calc(var(--card-w) * .32),56px);height:clamp(28px,calc(var(--card-w) * .32),56px);border-radius:50%;background-size:cover;background-repeat:no-repeat;box-shadow:0 4px 12px #00000073,0 0 0 1px #00000059,0 0 0 1.5px #fffffff2;mix-blend-mode:normal}.card-face.down.suspect-marked .role-token{width:calc(var(--card-w) * .75);height:calc(var(--card-w) * .75);box-shadow:0 10px 24px #00000080,0 0 0 2px #00000073,0 0 0 2px #fffffffa;filter:brightness(1.12) contrast(1.05)}.card-face.down .card-role,.suspect-chips,.token-bubble{display:none}.card-label{position:absolute;top:10px;left:50%;transform:translate(-50%);padding:4px 8px;border-radius:10px;background:#0000008c;color:#f8fafc;font-weight:800;font-size:12px;letter-spacing:.01em;text-transform:capitalize;text-shadow:0 2px 8px rgba(0,0,0,.65);filter:drop-shadow(0 1px 4px rgba(0,0,0,.35))}@media (max-width: 520px){.card-label{top:6px;padding:3px 6px;font-size:10px}}.card-back{font-size:12px;text-transform:uppercase;letter-spacing:.08em}.card-name{font-weight:800;font-size:12px;text-align:center;line-height:1.2}.card-role{font-weight:700;font-size:12px;text-align:center}.under-card{margin-top:8px;font-size:16px;font-weight:800;color:#f8fafc;text-transform:capitalize}.table-ring{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3}.seat--ring{position:absolute;transform:translate(-50%,-50%);width:var(--card-w)}.seat--grid{position:relative;width:100%;max-width:160px}.seat--grid .card-slot{width:100%;height:auto;aspect-ratio:5 / 7}.seat--grid .card-face{width:100%;height:100%}.seat--inner{position:absolute;transform:translate(-50%,-50%)}.seat--inner .card-slot{width:calc(var(--card-w) * .9);height:calc(var(--card-h) * .9)}.actionable .card-face{box-shadow:0 0 0 2px #16a34a80,0 0 18px #16a34a66;cursor:pointer}.seat.highlight .card-face{border-color:#fbbf24e6;box-shadow:0 0 0 2px #fbbf24cc,0 0 22px #fbbf24cc;background:linear-gradient(135deg,#fbbf24e6,#f59e0bd9);color:#0c1224}.seat.eliminated .card-face{filter:grayscale(.85) brightness(.8);opacity:.9}.elimination-tag{margin-top:6px;padding:4px 10px;border-radius:999px;background:#ef44442e;border:1px solid rgba(239,68,68,.6);color:#fecaca;font-size:.7rem;letter-spacing:.04em;text-transform:uppercase}.highlight-tag{position:absolute;top:-18px;left:50%;transform:translate(-50%);padding:4px 8px;border-radius:999px;background:#fbbf24f2;color:#0c1224;font-weight:800;font-size:11px;box-shadow:0 8px 20px #00000040;border:1px solid rgba(0,0,0,.15);pointer-events:none}.host-inline-cta{margin-top:12px}.action-toast{position:fixed;left:50%;bottom:16px;transform:translate(-50%);padding:8px 12px;border-radius:12px;background:#0c101aeb;border:1px solid rgba(255,255,255,.12);color:#e2e8f0;display:flex;align-items:center;gap:10px;box-shadow:0 12px 30px #00000059;z-index:50;pointer-events:auto}.action-toast.secondary{bottom:54px;background:#10b9812e;border-color:#10b98166}.action-toast select{background:#ffffff14;color:#e2e8f0;border:1px solid var(--border);border-radius:10px;padding:6px 8px}.suspect-chips{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px;justify-content:center}.pill.tiny{padding:4px 6px;font-size:11px}.token-bubble{margin-top:6px;background:#f9731633;color:#f97316;border-radius:999px;padding:4px 8px;font-weight:700;font-size:12px;text-align:center}.card-footer{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:6px;color:#e2e8f0;font-weight:700;font-size:12px}.vote-badge{margin-top:6px;display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#ffffff14;border:1px solid var(--border);color:#e2e8f0}.token-drag-source{position:absolute;bottom:10px;left:10px;display:flex;gap:10px;align-items:center}.token-chip{padding:8px 12px;background:#ffffff1f;border:1px solid var(--border);border-radius:999px;cursor:grab}.clear-zone{padding:8px 12px;border:1px dashed rgba(255,255,255,.25);border-radius:12px}.table-panel .panel-body{position:relative;min-height:0;height:calc(var(--vh, 1vh) * 100 - var(--top-bar-h) - var(--host-bar-h) - var(--safe-top) - var(--safe-bottom) - 20px);padding:calc(var(--top-bar-h) + 12px) 12px calc(var(--host-bar-h) + 18px);overflow:hidden}.role-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:10px}.role-chip{padding:10px;border:1px solid var(--border);border-radius:10px;background:#ffffff0d;display:flex;align-items:center;justify-content:space-between}.role-chip.disabled{opacity:.45;cursor:not-allowed;border-color:#94a3b833;background:#0f172a80;box-shadow:none;transform:none}.role-chip.disabled:hover{transform:none;border-color:#94a3b833;background:#0f172a80}.role-buttons{display:flex;gap:6px;align-items:center}.overlay-callout{padding:10px 12px;border-radius:12px;background:#f973162e;color:#fbbf24;font-weight:700}.role-select{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:6px}.toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle input{position:absolute;opacity:0;pointer-events:none}.toggle-track{width:52px;height:28px;border-radius:999px;background:#94a3b840;border:1px solid rgba(148,163,184,.35);padding:2px;display:inline-flex;align-items:center;transition:background .15s ease,border-color .15s ease}.toggle-thumb{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#cbd5e1,#94a3b8);box-shadow:0 6px 14px #94a3b859;transition:transform .18s ease,background .15s ease,box-shadow .15s ease;transform:translate(0)}.toggle input:checked+.toggle-track{background:#22c55e33;border-color:#22c55e99}.toggle input:checked+.toggle-track .toggle-thumb{transform:translate(24px);background:linear-gradient(135deg,#f59e0b,#22c55e);box-shadow:0 8px 18px #f59e0b73}.toggle-label{color:#e2e8f0;font-weight:600}.help-icon{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;width:16px;height:16px;border-radius:999px;border:1px solid rgba(226,232,240,.5);color:#e2e8f0;font-size:11px;font-weight:700;cursor:help;position:relative}.help-icon:after{content:attr(data-tooltip);position:absolute;bottom:140%;left:50%;transform:translate(-50%);background:#0f172af5;color:#e2e8f0;border:1px solid rgba(148,163,184,.35);border-radius:10px;padding:8px 10px;font-size:12px;font-weight:600;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .14s ease;z-index:20}.help-icon:hover:after,.help-icon:focus:after{opacity:1}.button.selected{border-color:#16a34a;box-shadow:0 0 0 2px #16a34a4d}.host-bar{position:fixed;bottom:calc(16px + var(--safe-bottom));left:50%;transform:translate(-50%);display:inline-flex;gap:10px;padding:10px 12px;background:#0c101aeb;border:1px solid rgba(255,255,255,.2);border-radius:14px;box-shadow:0 12px 40px #00000059;pointer-events:auto;z-index:30}.host-bar .button{padding:6px 10px;font-size:12px;min-width:110px;white-space:normal}@media (max-width: 520px){.host-bar{width:calc(100% - 24px);justify-content:space-between}.host-bar .button{flex:1}}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#07080cb8;display:flex;align-items:center;justify-content:center;z-index:20;padding:16px;min-height:100svh;height:100dvh}.overlay-card{background:radial-gradient(circle at 68% 14%,rgba(201,162,74,.08),transparent 44%),#101218f5;border:1px solid rgba(201,162,74,.28);border-radius:14px;padding:16px;width:min(620px,100%);box-shadow:0 20px 60px #00000059;color:#e2e8f0}.action-banner{position:fixed;left:50%;bottom:calc(16px + env(safe-area-inset-bottom,0px));transform:translate(-50%);padding:8px 14px;border-radius:999px;background:#0c101aeb;border:1px solid rgba(255,255,255,.2);color:#e2e8f0;font-weight:600;font-size:12px;z-index:18;text-align:center}.action-banner-host{bottom:calc(64px + env(safe-area-inset-bottom,0px))}.countdown-card{width:min(420px,92%);text-align:center}.countdown-card h3{margin:6px 0 8px;color:#f8fafc}.board-shell{min-height:100svh;height:auto;padding:clamp(6px,2vw,18px);position:relative;overflow:visible}.board-top{display:flex;justify-content:center;align-items:center;margin-bottom:clamp(6px,1.4vw,10px);position:sticky;top:calc(8px + env(safe-area-inset-top,0px));z-index:16;pointer-events:none}.board-stage{position:relative;margin:0 auto;max-width:860px;padding-top:15px}@media (min-width: 900px),(orientation: landscape) and (min-width: 568px){.board-stage{max-width:1040px}}.board-grid-blur{filter:blur(2px);opacity:.45;transform:scale(.98)}.board-grid{transition:filter .2s ease,opacity .2s ease,transform .2s ease}.center-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(8px,1.8vw,14px);max-width:min(720px,100%);margin:0 auto}.board-stage .player-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(10px,2vw,16px)}.center-row .card,.player-grid .card{max-width:clamp(64px,18vw,98px);justify-self:center}.board-stage .player-grid .card-stack{flex:0 1 clamp(64px,18vw,98px)}.center-block{display:grid;gap:8px;margin-bottom:clamp(14px,2.8vw,22px)}.center-label{text-transform:uppercase;letter-spacing:.08em;font-size:11px;color:#d7b35ac2;text-align:center}.player-block{display:grid;gap:8px}.board-divider{height:1px;background:#e2e8f01f;width:min(320px,80%);margin:0 auto 10px}.center-row .card{border-color:#94a3b873;box-shadow:0 8px 22px #02061766}.card-stack{display:grid;gap:6px;justify-items:center;position:relative}.card-name{font-size:10px;color:#e2e8f0a6;text-align:center;line-height:1.2}.card-clickable{cursor:pointer}.card-selectable{box-shadow:0 0 0 3px #fbbf24fa,0 0 0 6px #fcd34d85,0 0 26px #f59e0b8c;border-color:#fbbf24fa!important;animation:selectablePulse 1s ease-in-out infinite}.card-selected{box-shadow:0 0 0 2px #22c55ef2,0 0 20px #22c55e73;border-color:#22c55ef2!important;animation:none}.card-blink{animation:cardBlink 1s ease-in-out infinite}.card-note{width:100%;font-size:10px;font-weight:700;color:#fcd34dfa;text-transform:uppercase;letter-spacing:.06em;text-align:center}@keyframes cardBlink{0%,to{box-shadow:0 0 0 1px #22c55e8c,0 10px 20px #22c55e33}50%{box-shadow:0 0 0 2px #22c55efa,0 0 24px #22c55e8c}}@keyframes selectablePulse{0%,to{box-shadow:0 0 0 3px #fbbf24fa,0 0 0 6px #fcd34d73,0 0 20px #f59e0b66}50%{box-shadow:0 0 0 3px #fbbf24fa,0 0 0 7px #fde68ab8,0 0 34px #f59e0ba8}}.card-tokened .card-face,.card-voted .card-face{filter:brightness(.6) saturate(.9)}.card-tokened .card-face:after,.card-voted .card-face:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#04081259;border-radius:inherit}.card-token{position:absolute;width:clamp(35px,7.5vw,50px);height:clamp(35px,7.5vw,50px);right:50%;bottom:55%;transform:translate(50%,50%);border-radius:999px;background:#0a0e1640;padding:0;box-shadow:0 8px 18px #02061773;border:1px solid rgba(226,232,240,.2);object-fit:cover;z-index:2}.card-vote-count{position:absolute;right:50%;bottom:55%;transform:translate(50%,50%);width:clamp(26px,7vw,34px);height:clamp(26px,7vw,34px);border-radius:999px;background:#ffffff1f;border:1px solid rgba(226,232,240,.65);color:#f8fafc;font-size:14px;font-weight:700;display:grid;place-items:center;text-shadow:0 2px 6px rgba(2,6,23,.6);z-index:2}.card-eliminated{box-shadow:0 0 0 2px #ef4444f2,0 0 24px #7f1d1d73;border-color:#ef4444e6!important}.card-eliminated .card-face:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#7f1d1d66}.card-winner{box-shadow:0 0 0 2px #facc15f2,0 0 24px #a1620766;border-color:#facc15e6!important}.card-result-both{box-shadow:0 0 0 2px #facc15e6,0 0 0 5px #ef4444b8,0 0 28px #a1620759;border-color:#facc15f2!important}.card-status-row{position:absolute;left:50%;top:-18px;transform:translate(-50%);z-index:4;display:flex;align-items:center;justify-content:center;gap:6px;pointer-events:none}.card-status{border-radius:999px;padding:2px 8px;font-size:10px;font-weight:800;letter-spacing:.02em;text-transform:uppercase;line-height:1}.card-status-eliminated{background:#7f1d1de6;color:#fee2e2;border:1px solid rgba(248,113,113,.95)}.card-status-winner{background:#78350fe6;color:#fef3c7;border:1px solid rgba(250,204,21,.95)}.card-status-both{background:linear-gradient(90deg,#7f1d1df2,#78350ff2);color:#fff7ed;border:1px solid rgba(251,191,36,.92)}.card-menu{position:absolute;background:#121826f2;border:1px solid rgba(226,232,240,.2);border-radius:12px;padding:6px;display:grid;gap:4px;z-index:20;min-width:160px;max-height:min(240px,45vh);overflow-y:auto;max-width:220px}.card-menu-bottom{top:calc(100% + 6px);transform-origin:top center}.card-menu-top{bottom:calc(100% + 6px);transform-origin:bottom center}.card-menu-center{left:50%;transform:translate(-50%)}.card-menu-left{left:0}.card-menu-right{right:0}.card-menu button{background:#ffffff0f;border:1px solid rgba(226,232,240,.15);color:#e2e8f0;border-radius:10px;padding:6px 8px;font-size:12px;text-align:left;cursor:pointer}.card-menu button:hover{border-color:#e2e8f059;background:#ffffff1a}.center-name{display:none}.you-badge{margin-left:6px;padding:1px 6px;border-radius:999px;border:1px solid rgba(34,197,94,.6);color:#22c55e;font-size:9px;font-weight:700}@media (max-width: 360px){.board-stage .player-grid{gap:10px}}.center-row .card,.player-grid .card{width:100%}.dev-controls{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.dev-controls .pill{background:#0c101ab3;cursor:pointer}.app-loading{min-height:100vh;display:grid;place-items:center;padding:24px;color:#e2e8f0;font-weight:600;background:radial-gradient(circle at 60% 14%,rgba(215,179,90,.18) 0%,rgba(215,179,90,.07) 20%,transparent 46%),linear-gradient(170deg,#16181d,#0e1014 42%,#08090c)}.spinner{width:44px;height:44px;border-radius:50%;border:4px solid rgba(148,163,184,.35);border-top-color:#f8fafc;animation:spinner-rotate 1s linear infinite}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.action-overlay .overlay-card{width:min(520px,100%)}.action-card h3{margin:6px 0 8px;color:#f8fafc;font-size:clamp(20px,3vw,28px)}.action-card .button{margin-top:12px}.role-card-content{display:flex;gap:24px;align-items:center}.role-info h3{margin:6px 0 8px;font-size:clamp(22px,3vw,32px);color:#f8fafc}.role-info .button{margin-top:12px}.role-info{flex:1;min-width:0}.role-art{width:clamp(160px,32vw,260px);max-width:45%}.role-art img{width:100%;height:auto;display:block}.role-card{max-width:900px;padding:32px 32px 36px;min-height:360px;background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.05),transparent 40%),#0a0e1af2;box-shadow:0 30px 80px #0000008c;border:1px solid rgba(255,255,255,.16);border-radius:18px}.role-card .hero-card img,.role-card .hero-card .card-face{max-height:clamp(220px,45vh,420px);object-fit:contain}.role-grid-modal{display:grid;grid-template-columns:1.1fr 1fr;gap:28px;align-items:center}@media (max-width: 640px){.overlay{align-items:center;padding-top:calc(12px + var(--safe-top));padding-bottom:calc(12px + var(--safe-bottom))}.role-card{padding:22px 18px 24px;width:100%;min-height:0}.role-grid-modal{grid-template-columns:1.2fr .8fr;gap:16px;justify-items:stretch;align-items:start}.hero-card{width:min(36vw,220px);justify-self:end}.hero-card img,.hero-card .card-face{max-height:26vh;object-fit:contain}}@media (max-width: 900px) and (orientation: landscape){.overlay{align-items:center;padding-top:calc(8px + var(--safe-top));padding-bottom:calc(8px + var(--safe-bottom))}.role-card{width:min(760px,100%);padding:18px 18px 20px}.role-grid-modal{grid-template-columns:1.1fr .9fr;gap:14px;align-items:center}.hero-card img,.hero-card .card-face{max-height:32vh}}@media (max-width: 420px){.role-grid-modal{grid-template-columns:1.15fr .85fr;gap:12px}.hero-card{width:min(40vw,200px)}.hero-card img,.hero-card .card-face{max-height:24vh}}.role-text h2{margin:8px 0 16px;color:#f8fafc;font-size:26px;letter-spacing:-.02em}.role-text .lede{margin-bottom:20px}.game-shell{padding:0!important;overflow:visible!important}.board{margin-top:0!important}.panel.table-panel{border-radius:0!important;background:transparent!important;border:none!important;box-shadow:none!important;width:100%!important;max-width:none!important}.table{border-radius:0!important;border:none!important;width:100%!important;max-width:none!important;height:100%!important}.table-info{left:0!important;right:0!important;top:0!important;border-radius:0!important}.table{background:none!important;border:none!important;box-shadow:none!important;max-width:none!important}.board{background:radial-gradient(ellipse at 52% 33%,#d7b35a1c,#090a0d0a 49%),radial-gradient(ellipse at 2% 50%,rgba(0,0,0,.42),transparent 28%),radial-gradient(ellipse at 98% 50%,rgba(0,0,0,.42),transparent 28%),linear-gradient(160deg,#14171c,#0d1014 46%,#090a0d)}.seat{position:relative;display:flex;flex-direction:column;align-items:center}.seat.you:after{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;background:radial-gradient(circle,rgba(255,255,255,.08),transparent 55%);border-radius:16px;z-index:0;pointer-events:none}.seat.you>*{position:relative;z-index:1}.table .center-row{display:flex;justify-content:center;align-items:center;gap:18px}@media (max-width: 480px){:root{--card-w: clamp(26px, 12vw, 50px);--card-h: calc(var(--card-w) * 1.45)}.table .center-row{gap:14px}.seats-grid{gap:8px}.card-footer .pill.tiny{display:inline-block;text-align:center;white-space:normal}}@media (max-width: 520px) and (max-height: 520px){:root{--card-w: clamp(26px, 12vw, 48px);--card-h: calc(var(--card-w) * 1.45)}.table .center-row{gap:12px}.seats-grid{gap:8px}.card-footer .pill.tiny{display:inline-block;text-align:center;white-space:normal}}.phase-bar{display:grid;grid-auto-flow:column;align-items:center;gap:10px;padding:8px 12px;border-radius:14px;background:#0c101ad9;border:1px solid rgba(255,255,255,.2);box-shadow:0 12px 30px #00000059;pointer-events:auto;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.phase-pill{display:inline-flex;align-items:baseline;gap:8px}.phase-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#e2e8f0b3}.phase-value{font-weight:800;color:#f8fafc}.phase-timer{padding:4px 8px;border-radius:999px;background:#ffffff14;border:1px solid rgba(255,255,255,.2);font-weight:700;font-size:12px;color:#e2e8f0}.phase-timer.phase-timer-critical{background:#dc262642;border-color:#f87171e6;color:#fee2e2;animation:phaseTimerCriticalBlink .8s ease-in-out infinite}@keyframes phaseTimerCriticalBlink{0%,to{opacity:1;box-shadow:0 0 #dc262600}50%{opacity:.45;box-shadow:0 0 14px #f87171bf}}
