:root{color:#f8f2e6;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#24150f;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.35}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}.host-shell{background:linear-gradient(#110a071f,#110a0747),url(/assets/images/backgrounds/tabletop-party-16x9.png) 50%/cover no-repeat,#3a2217;grid-template-rows:auto 1fr;min-height:100vh;padding:clamp(18px,2.3vw,34px);display:grid}.host-bar{justify-content:space-between;align-items:flex-start;gap:24px;min-height:72px;display:flex}.eyebrow{color:#ffd772;letter-spacing:0;text-transform:uppercase;margin:0 0 6px;font-size:.78rem;font-weight:800}h1,h2,p{margin:0}.host-bar h1{text-shadow:0 4px 22px #00000073;font-size:clamp(2rem,4.6vw,4.8rem);line-height:.95}.join-strip{background:#160d09ad;border:1px solid #ffffff29;border-radius:8px;align-items:center;gap:10px;max-width:min(52vw,760px);padding:10px 12px;display:flex;box-shadow:0 16px 34px #00000038}.join-strip span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.icon-button{color:#2d1a12;background:#f1d486;border:0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.table-stage{align-items:center;min-height:calc(100vh - 132px);display:grid}.lobby-layout,.round-layout{grid-template-columns:minmax(360px,1fr) minmax(280px,420px);gap:clamp(18px,3vw,34px);width:100%;max-width:1240px;margin:0 auto;display:grid}.round-layout{grid-template-columns:1fr;align-content:center}.room-card,.players-panel,.prompt-card,.revealed-card,.final-layout{border-radius:8px;box-shadow:0 28px 65px #00000052}.room-card{color:#f8f2e6;background:#17100d;align-self:center;min-height:430px;padding:clamp(26px,4vw,56px)}.room-code{margin:16px 0 20px;font-size:clamp(5rem,14vw,11rem);font-weight:950;line-height:.9}.room-url{color:#f8f2e6c7;margin-bottom:30px;font-size:clamp(1rem,2vw,1.35rem)}.primary-button,.ghost-button{border:0;border-radius:8px;justify-content:center;align-items:center;gap:10px;min-height:48px;padding:0 18px;font-weight:850;display:inline-flex}.primary-button{color:#29160e;background:#ffd35f;box-shadow:0 14px 28px #48260d38}.ghost-button{color:#f8f2e6;background:#ffffff14;border:1px solid #ffffff26}.players-panel{background:#160d09c2;border:1px solid #ffffff24;align-self:center;padding:20px}.players-panel.compact{min-width:360px}.players-panel h2,.mobile-waiting h2{margin-bottom:14px;font-size:1.1rem}.player-list{gap:9px;display:grid}.player-row{background:#ffffff13;border-radius:8px;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;min-height:44px;padding:8px 11px;display:grid}.dot{background:#76665b;border-radius:999px;width:10px;height:10px}.dot.online{background:#6ee7a4;box-shadow:0 0 0 4px #6ee7a41f}.prompt-card{color:#fff9ec;background:#111;width:min(100%,1000px);max-width:1000px;min-height:270px;margin:0 auto;padding:clamp(28px,5.5vw,70px);position:relative}.prompt-card p{letter-spacing:0;font-size:clamp(2rem,5.2vw,5.4rem);font-weight:900;line-height:1.03}.prompt-card.compact{width:100%;min-height:148px;padding:22px}.prompt-card.compact p{font-size:clamp(1.25rem,6.2vw,2rem);line-height:1.08}.pick-badge,.round-badge,.submission-meter{background:#ffffff1a;border:1px solid #ffffff24;border-radius:8px;align-items:center;gap:8px;padding:10px 12px;font-weight:800;display:inline-flex}.pick-badge{position:absolute;bottom:18px;right:18px}.prompt-card.compact .pick-badge{margin-top:16px;position:static}.status-row{flex-wrap:wrap;justify-content:center;align-items:center;gap:16px;display:flex}.submission-grid{grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:18px;width:100%;max-width:1100px;margin:0 auto;display:grid}.reveal-layout{justify-items:center}.reveal-card-wrap{place-items:center;width:min(100%,960px);min-height:250px;display:grid}.revealed-card{color:#1b1712;background:#fff8e9;min-height:150px;padding:22px;font-size:clamp(1.05rem,2.1vw,1.8rem);font-weight:850;line-height:1.12;display:grid}.revealed-card.featured{text-align:center;place-items:center;width:100%;max-width:960px;min-height:240px;font-size:clamp(2rem,4.6vw,4.8rem);animation:.34s ease-out card-pop}.revealed-card.muted{color:#1b17129e;background:#fff8e9d1}.revealed-card.winner{outline:5px solid #ffd35f;transform:translateY(-5px)}.revealed-card footer{color:#665042;justify-content:space-between;align-self:end;align-items:end;margin-top:28px;font-size:.9rem;font-weight:700;display:flex}.like-count,.result-stats{align-items:center;gap:8px;display:inline-flex}.like-count{color:#7a3026;background:#7832281a;border-radius:999px;justify-self:start;margin-top:14px;padding:6px 9px;font-size:.86rem;font-weight:900}.revealed-card footer .like-count{margin-top:0}.result-banner{background:#160d09d1;border:1px solid #ffffff24;border-radius:8px;justify-self:center;align-items:center;gap:12px;padding:16px 20px;font-size:clamp(1.4rem,2.4vw,2.5rem);font-weight:900;display:inline-flex;box-shadow:0 20px 48px #00000040}@keyframes card-pop{0%{opacity:0;transform:translateY(16px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.final-layout{background:#160d09cc;border:1px solid #ffffff24;justify-items:center;gap:18px;width:100%;max-width:620px;margin:0 auto;padding:34px;display:grid}.final-layout h2{font-size:clamp(2rem,5vw,4.5rem)}.leaderboard{gap:8px;width:100%;display:grid}.leader-row{background:#ffffff14;border-radius:8px;grid-template-columns:38px 1fr auto;align-items:center;min-height:52px;padding:8px 14px;display:grid}.mobile-shell{color:#f8f2e6;min-height:100vh;padding:max(16px, env(safe-area-inset-top)) 16px max(18px, env(safe-area-inset-bottom));background:radial-gradient(circle at 18% -10%,#ffd35f47,#0000 34%),radial-gradient(circle at 112% 8%,#20c7b038,#0000 32%),linear-gradient(160deg,#18191b,#3a2016 48%,#151012)}.mobile-join{align-content:center;gap:18px;max-width:440px;min-height:calc(100vh - 34px);margin:0 auto;display:grid}.mobile-join h1{font-size:2.5rem;line-height:1}.join-form{gap:14px;display:grid}label{color:#f8f2e6c7;gap:6px;font-weight:800;display:grid}input{color:#1c1510;background:#fff7e8;border:0;border-radius:8px;width:100%;min-height:52px;padding:0 14px;font-size:1.2rem;font-weight:850}.form-error{color:#ffd0c4;font-weight:800}.player-top{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.player-top div{display:grid}.player-top span{color:#f8f2e6b8;font-size:.9rem}.score-pill{color:#29160e;background:#ffd35f;border-radius:999px;align-items:center;gap:5px;min-width:54px;padding:8px 12px;font-weight:900;display:inline-flex}.mobile-hint{color:#f8f2e6c2;margin:14px 0 10px;font-weight:800}.hand-list,.vote-list{gap:10px;padding-bottom:148px;display:grid}.replacement-list{padding-bottom:26px}.answer-card,.vote-card{color:#18120f;text-align:left;background:#fff7e8;border:3px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;width:100%;min-height:86px;padding:16px;font-weight:850;line-height:1.14;display:flex}.vote-card{align-items:stretch;gap:12px;display:grid}.answer-card.selected,.vote-card.selected{border-color:#ffd35f;box-shadow:0 0 0 4px #ffd35f2e}.vote-actions{grid-template-columns:minmax(84px,auto) 1fr;gap:8px;display:grid}.like-button,.small-vote-button{border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:42px;padding:0 12px;font-weight:900;display:inline-flex}.like-button{color:#69261f;background:#812d241f}.like-button.active{color:#fff7e8;background:#d94b3f}.small-vote-button{color:#29160e;background:#ffd35f}.sticky-action{bottom:max(16px, env(safe-area-inset-bottom));z-index:5;width:calc(100% - 32px);position:fixed;left:16px;right:16px}.sticky-action:disabled{display:none}.mobile-waiting{gap:16px;margin-top:18px;display:grid}.replacement-panel{gap:14px;display:grid}.replacement-actions{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px;display:grid}.empty-state{background:#160d09c7;border-radius:8px;place-self:center;padding:24px;font-size:1.4rem;font-weight:850}@media (width<=780px){.host-shell{padding:16px}.host-bar,.lobby-layout{grid-template-columns:1fr;display:grid}.join-strip{max-width:100%}.room-card{min-height:0}.prompt-card p{font-size:2rem}}
