:root{color:#172033;background:#f5f1e9;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--canvas: #f5f1e9;--paper: #fffdf8;--paper-soft: #f7faf7;--ink: #172033;--muted: #657086;--line: #d9ded7;--line-strong: #172033;--teal: #126c68;--teal-dark: #0d4e4a;--coral: #d4513c;--gold: #c58a22;--blue: #3157b7;--violet: #6d5bd0;--green: #16875d;--shadow: 0 20px 60px rgba(43, 50, 65, .12);--shadow-soft: 0 14px 34px rgba(43, 50, 65, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(90deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,#fbf7ef,#eef5f1 54%,#f3f5fa);background-size:32px 32px,32px 32px,auto}button,input,select{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid rgba(18,108,104,.28);outline-offset:2px}h1,h2,h3,p{margin:0}h1{color:#101827;font-size:clamp(2.65rem,7vw,5.8rem);line-height:.9}h2{color:#111827;font-size:clamp(1.65rem,3vw,2.55rem);letter-spacing:0;line-height:.96}h3{color:#172033;font-size:1rem;line-height:1.1}.shell{min-height:100vh;padding:24px 18px 32px}.topbar{align-items:center;display:flex;justify-content:flex-start;gap:16px;margin:0 auto 18px;max-width:1230px}.lobby-shell .topbar{justify-content:flex-start;margin-bottom:22px;max-width:1320px;text-align:left}.eyebrow{color:var(--teal);font-size:.78rem;font-weight:900;letter-spacing:0;margin:0 0 6px;text-transform:uppercase}.lobby-panel{display:grid;gap:28px;grid-template-columns:minmax(260px,.75fr) minmax(0,1fr);margin:0 auto;max-width:1320px}.brand-block{align-content:start;display:grid;gap:16px;padding:20px 4px}.brand-block p{color:var(--muted);font-size:1.03rem;line-height:1.55;max-width:35rem}.lobby-forms{display:grid;gap:14px}.lobby-actions{background:#fffdf8eb;border:1px solid rgba(23,32,51,.12);border-radius:8px;box-shadow:var(--shadow-soft);display:grid;gap:13px;grid-template-columns:minmax(190px,1fr) minmax(140px,.55fr) minmax(138px,auto);padding:18px}.lobby-actions h3{align-self:center;grid-column:1 / -1}.lobby-actions[data-action=join]{grid-template-columns:minmax(132px,.45fr) minmax(190px,1fr) minmax(126px,auto)}label{color:#4d596d;display:grid;font-size:.84rem;font-weight:850;gap:7px;min-width:0}input,select{background:#fff;border:1px solid #cfd8cf;border-radius:7px;color:var(--ink);min-height:46px;padding:10px 12px;transition:border-color .14s ease,box-shadow .14s ease;width:100%}input:hover,select:hover{border-color:#acbaad}.lobby-actions button,.keypad button,.leave-button{border-radius:7px;font-weight:900;min-height:46px;transition:background .14s ease,box-shadow .14s ease,transform .14s ease}.lobby-actions button,.keypad button{background:var(--teal);box-shadow:0 10px 18px #126c682e;color:#fff;padding:0 16px}.lobby-actions button{align-self:end;height:46px;min-height:46px;min-width:0;white-space:nowrap}.lobby-actions button:hover,.keypad button:hover{background:var(--teal-dark);transform:translateY(-1px)}.toast{background:#fff4ef;border:1px solid #f2c7ba;border-radius:8px;bottom:1rem;box-shadow:0 18px 38px #0f172a1f;color:#a53825;font-size:.9rem;font-weight:850;left:auto;line-height:1.35;max-width:min(24rem,calc(100vw - 2rem));padding:10px 12px;position:fixed;right:1rem;width:max-content;z-index:30}.toast.info{background:#edf8f6;border-color:#a9d9d2;color:var(--teal-dark)}.game-shell .board-zone>.toast,.lobby-panel>.toast{width:max-content}.game-grid{align-items:start;display:grid;gap:16px;grid-template-columns:minmax(220px,272px) minmax(420px,1fr) minmax(230px,286px);margin:0 auto;max-width:1230px}.scoreboard,.activity{align-content:start;display:grid;gap:12px}.lobby-code-wrap,.player,.activity,.modifier-list,.board-zone{background:#fffdf8f0;border:1px solid rgba(23,32,51,.12);border-radius:8px;box-shadow:var(--shadow-soft)}.lobby-code-wrap{display:grid;gap:7px;padding:15px}.lobby-code-wrap span,.score-wrap span{color:#667085;font-size:.72rem;font-weight:900;text-transform:uppercase}.lobby-code-wrap strong{color:#101827;font-size:1.6rem;letter-spacing:0;line-height:1}.lobby-code-wrap small{color:var(--teal);font-size:.86rem;font-weight:900}.leave-button{background:#efe8dc;color:#3e342b;margin-top:0;padding:0 12px;width:100%}.leave-button:hover{background:#e3d7c7}.players{display:grid;gap:9px}.player{align-items:center;display:grid;gap:8px 12px;grid-template-columns:minmax(0,1fr) auto;min-height:88px;padding:14px}.player.self{border-color:#126c6880;box-shadow:inset 4px 0 0 var(--teal),var(--shadow-soft)}.player-copy{display:grid;gap:5px;min-width:0}.player strong{color:#111827;display:block;font-size:1rem;overflow-wrap:anywhere}.player-state{align-items:center;color:var(--muted);display:inline-flex;font-size:.8rem;font-weight:850;gap:6px}.player-state:before{background:#98a2b3;border-radius:999px;content:"";height:7px;width:7px}.player-state.online:before{background:var(--green)}.score-wrap{display:grid;gap:5px;justify-items:end}.score{align-items:center;background:#edf8f6;border:1px solid #c7e4df;border-radius:8px;color:var(--teal-dark);display:flex;font-size:1.5rem;font-weight:950;height:48px;justify-content:center;min-width:56px;padding:0 10px}.badges{display:flex;flex-wrap:wrap;gap:6px;grid-column:1 / -1;min-height:0}.badges span{background:#f0eee7;border:1px solid rgba(23,32,51,.08);border-radius:999px;color:#4d596d;font-size:.74rem;font-weight:850;padding:4px 8px}.modifier-list{display:grid;gap:9px;padding:14px}.legend-row{align-items:center;color:#4d596d;display:grid;font-size:.84rem;gap:9px;grid-template-columns:40px minmax(0,1fr);line-height:1.25}.mod-chip,.marker{align-items:center;border-radius:999px;display:inline-flex;font-size:.68rem;font-weight:950;justify-content:center}.mod-chip{height:26px}.DoublePoints,.mod-DoublePoints .marker{background:#fff0c2;color:#83540a}.Freeze,.mod-Freeze .marker{background:#e4edff;color:var(--blue)}.Shield,.mod-Shield .marker{background:#dcf5eb;color:#116447}.Steal,.mod-Steal .marker{background:#ffe6df;color:#9f3525}.Insight,.mod-Insight .marker{background:#eeebff;color:#5543b8}.board-zone{display:grid;gap:14px;justify-items:center;padding:18px}.match-header{align-items:center;display:flex;justify-content:center;width:min(100%,650px)}.game-status-pill{align-items:center;background:#f0eee7;border:1px solid rgba(23,32,51,.1);border-radius:999px;color:#172033;display:inline-flex;font-size:.78rem;font-weight:950;justify-content:center;min-height:28px;min-width:88px;padding:0 13px;text-transform:uppercase}.mobile-score-strip{display:none}.mobile-score{align-items:center;background:#f7faf7;border:1px solid rgba(18,108,104,.18);border-radius:8px;color:#344054;gap:8px;justify-content:space-between;min-width:0;padding:7px 9px}.mobile-score.self{border-color:#126c6873;box-shadow:inset 3px 0 0 var(--teal)}.mobile-score span{font-size:.82rem;font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-score strong{align-items:center;background:#edf8f6;border-radius:6px;color:var(--teal-dark);display:inline-flex;font-size:1.02rem;font-weight:950;justify-content:center;min-height:30px;min-width:38px;padding:0 8px}.hint,.frozen-banner{border-radius:8px;font-size:.88rem;font-weight:850;line-height:1.35;padding:9px 11px;width:min(100%,650px)}.hint{background:#f0edff;border:1px solid #cfc7ff;color:#5141a6}.frozen-banner{background:#e8f0ff;border:1px solid #c7d7ff;color:var(--blue)}.board-zone>.toast{width:min(100%,650px)}.board{aspect-ratio:1;background:var(--line-strong);border:4px solid var(--line-strong);border-radius:8px;box-shadow:0 18px 40px #17203324;display:grid;gap:1px;grid-template-columns:repeat(9,minmax(0,1fr));max-width:650px;overflow:hidden;width:min(100%,650px)}.cell{align-items:center;background:#fffdf8;color:var(--ink);display:grid;grid-template-rows:1fr auto;min-height:0;min-width:0;padding:4px;position:relative;transition:background .12s ease,box-shadow .12s ease,transform .12s ease}.cell:not(:disabled):hover{background:#f4fbf8;box-shadow:inset 0 0 0 2px #126c6838}.cell:nth-child(3n){border-right:3px solid var(--line-strong)}.cell:nth-child(n+19):nth-child(-n+27),.cell:nth-child(n+46):nth-child(-n+54){border-bottom:3px solid var(--line-strong)}.cell:nth-child(9n){border-right:0}.cell.given{background:#ebe5d8;color:#111827;font-weight:950}.cell.mine{background:#ddf3ea;color:#07553f}.cell.theirs{background:#ffebe4;color:#96341f}.cell.selected{outline:4px solid var(--gold);outline-offset:-4px}.cell.opponent-selected{box-shadow:inset 0 0 0 4px #d4513cb8}.cell.opponent-selected:after{background:var(--coral);border-radius:999px;color:#fff;content:"OP";font-size:.56rem;font-weight:950;line-height:1;padding:3px 5px;position:absolute;right:3px;top:3px}.value{align-self:center;font-size:clamp(1.05rem,3.2vw,2.08rem);font-weight:900;line-height:1}.marker{bottom:3px;height:18px;justify-self:center;min-width:28px;padding:0 5px;position:absolute}.keypad{display:grid;gap:8px;grid-template-columns:repeat(9,minmax(0,1fr));max-width:650px;width:min(100%,650px)}.keypad button{min-width:0;padding:0}.keypad button:disabled{background:#c4cbd4;box-shadow:none;color:#667085}.activity{align-content:start;display:grid;grid-template-rows:auto minmax(0,1fr);max-height:min(540px,calc(100vh - 150px));min-height:0;overflow:hidden;padding:16px}.activity h2{font-size:1rem;line-height:1.1}.events{align-content:start;display:grid;gap:8px;grid-auto-rows:max-content;max-height:min(446px,calc(100vh - 214px));min-height:0;overflow:auto;padding-right:4px;scrollbar-gutter:stable}.events p{align-items:start;border-bottom:1px solid rgba(23,32,51,.08);color:#4d596d;display:grid;font-size:.86rem;gap:4px 10px;grid-template-columns:10px minmax(0,1fr) auto;line-height:1.4;min-height:42px;padding-bottom:8px}.events p:before{align-self:start;background:var(--teal);border-radius:999px;box-shadow:0 0 0 4px #126c681a;content:"";grid-column:1;grid-row:1;height:7px;margin-top:6px;width:7px}.events p span{grid-column:2;min-width:0}.events time{color:#7a8395;font-size:.72rem;font-weight:850;grid-column:3;grid-row:1;white-space:nowrap}@media(max-width:1040px){.game-grid{grid-template-columns:1fr;max-width:780px}.scoreboard{grid-template-columns:190px 1fr}.modifier-list{grid-column:1 / -1}.activity{max-height:none;min-height:120px;overflow:visible}.events{max-height:none;overflow:visible}}@media(min-width:1041px){body{overflow:hidden}.shell{display:grid;grid-template-rows:auto minmax(0,1fr);height:100vh;overflow:hidden;padding-bottom:18px}.game-grid{align-items:stretch;height:100%;min-height:0;overflow:hidden}.scoreboard,.board-zone{align-self:start}.scoreboard{max-height:none;overflow:visible}.activity{align-self:start}.board-zone{--play-size: min(100%, calc(100vh - 330px) , 650px);align-content:start;overflow:visible;justify-self:center;width:min(100%,calc(var(--play-size) + 72px))}.board,.keypad,.match-header,.hint,.frozen-banner,.board-zone>.toast{width:var(--play-size)}}@media(min-width:1041px)and (max-height:800px){.shell{padding-bottom:12px;padding-top:16px}.topbar{margin-bottom:10px}.eyebrow{font-size:.7rem}h1{font-size:clamp(2.55rem,5vw,4.5rem)}.game-grid{min-height:0}.lobby-code-wrap,.player,.modifier-list,.activity,.board-zone{box-shadow:0 8px 22px #2b324112}.lobby-code-wrap,.player{padding:12px}.scoreboard{gap:6px}.player{min-height:62px}.score{font-size:1.15rem;height:36px;min-width:42px}.badges span{font-size:.7rem;padding:3px 7px}.modifier-list{gap:4px;padding:8px}.legend-row{font-size:.76rem;gap:7px}.mod-chip{height:20px}.leave-button{min-height:42px}.board-zone{--play-size: min(100%, calc(100vh - 235px) , 500px);gap:10px;padding:14px}}@media(max-width:760px){.lobby-panel{grid-template-columns:1fr;gap:16px}.brand-block{padding:6px 0 0}.lobby-actions,.lobby-actions[data-action=join]{grid-template-columns:1fr}}@media(max-width:640px){.shell{padding:12px 14px 20px}.topbar{align-items:start;gap:10px;margin-bottom:12px}h1{font-size:clamp(2.25rem,13vw,3.4rem)}.scoreboard{grid-template-columns:1fr}.board-zone{order:1}.scoreboard{order:2}.activity{order:3}.board-zone{gap:10px;padding:10px}.mobile-score-strip{display:grid;gap:8px;grid-template-columns:repeat(2,minmax(0,1fr));width:100%}.mobile-score{display:flex}.board{border-width:3px;width:100%}.cell{padding:2px}.cell:nth-child(3n){border-right-width:1px}.cell:nth-child(n+19):nth-child(-n+27),.cell:nth-child(n+46):nth-child(-n+54){border-bottom-width:1px}.value{font-size:clamp(1rem,7vw,1.65rem)}.marker{bottom:2px;font-size:.58rem;height:15px;min-width:24px}.keypad{grid-template-columns:repeat(3,minmax(0,1fr))}.keypad button{min-height:48px}}.game-shell{background:linear-gradient(90deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,#fbf7ef,#eef5f1 54%,#f3f5fa);background-size:32px 32px,32px 32px,auto;color:#111827;padding:42px clamp(28px,4.4vw,72px) 48px}.game-shell .topbar{align-items:flex-start;gap:16px;margin:0 auto 12px;max-width:1450px}.game-shell .topbar:before{background-image:radial-gradient(circle,#b6c0c8 2px,transparent 2.5px);background-size:9px 9px;content:"";height:28px;margin-top:4px;opacity:.9;width:28px}.game-shell .eyebrow{color:#007564;font-size:.9rem;letter-spacing:0;margin-bottom:10px}.game-shell h1{color:#121b2c;font-size:clamp(4.15rem,5.2vw,5.6rem);line-height:.84}.game-shell .game-grid{--board-lift: 66px;--board-size: min(41vw, calc(100vh - 345px) , 660px);align-items:start;display:grid;gap:clamp(30px,3.4vw,56px);grid-template-columns:minmax(300px,1fr) var(--board-size) minmax(300px,1fr);margin:0 auto;max-width:1540px}.game-shell .scoreboard{align-content:start;display:grid;gap:12px;grid-template-columns:1fr;justify-self:end;width:320px}.game-shell .lobby-code-wrap,.game-shell .player,.game-shell .activity,.game-shell .modifier-list{background:#ffffffe6;border:1px solid #dfe4ea;border-radius:10px;box-shadow:0 18px 36px #0f172a0f}.game-shell .lobby-code-wrap{gap:10px;min-height:140px;padding:22px}.lobby-code-head{align-items:center;display:flex;justify-content:space-between}.game-shell .lobby-code-wrap span,.game-shell .score-wrap span{color:#667085;font-size:.78rem;font-weight:950}.game-shell .lobby-code-wrap strong{color:#111827;font-size:1.75rem;line-height:.95}.copy-code-button{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:inline-flex;height:34px;justify-content:center;padding:0;width:34px}.copy-code-button span{border:2px solid #475467;border-radius:2px;display:block;height:14px;position:relative;width:12px}.copy-code-button span:before{border:2px solid #475467;border-radius:2px;content:"";height:14px;left:-6px;position:absolute;top:-6px;width:12px}.difficulty-pill{align-items:center;background:transparent;border-radius:0;color:#047857;display:inline-flex;font-size:.84rem;font-weight:950;height:auto;justify-content:center;width:max-content;padding:0}.game-shell .players{gap:12px}.game-shell .player{align-items:center;grid-template-columns:52px minmax(0,1fr) auto;min-height:90px;padding:18px}.game-shell .player.self{border-color:#dfe4ea;box-shadow:0 18px 36px #0f172a0f}.avatar{align-items:center;background:linear-gradient(135deg,#2aa276,#08724f);border-radius:999px;color:#fff;display:inline-flex;font-size:1.15rem;font-weight:950;height:52px;justify-content:center;width:52px}.avatar.ghost{background:#e5e7eb;color:#667085}.game-shell .player-copy{gap:6px}.game-shell .player strong{font-size:.95rem}.game-shell .player-state{color:#047857;font-size:.82rem;font-weight:850}.game-shell .score{background:#f8fafc;border:0;border-radius:8px;color:#00816e;font-size:1.2rem;height:40px;min-width:48px}.waiting-player{color:#667085}.waiting-dots{display:inline-flex;gap:12px}.waiting-dots i{background:#d8dde5;border-radius:999px;display:block;height:8px;width:8px}.game-shell .badges{grid-column:2 / -1}.game-shell .modifier-list{gap:12px;padding:20px}.game-shell .legend-row{color:#344054;font-size:.86rem;grid-template-columns:42px minmax(0,1fr)}.game-shell .mod-chip{height:28px}.game-shell .leave-button{background:linear-gradient(90deg,#fff5f2,#fff9f7);border:1px solid #fde3dc;border-radius:10px;box-shadow:0 18px 36px #0f172a0a;color:#dc2626;font-weight:950;min-height:66px}.game-shell .leave-button:hover{background:#fff1ed}.game-shell .board-zone{background:transparent;border:0;box-shadow:none;gap:18px;justify-items:center;padding:0;transform:translateY(calc(-1 * var(--board-lift)));width:var(--board-size)}.game-shell .match-header{min-height:48px;width:var(--board-size)}.game-shell .game-status-pill{background:#fff;border:1px solid #dfe4ea;box-shadow:0 10px 24px #0f172a0d;gap:10px;min-height:46px;min-width:150px}.game-shell .game-status-pill:before{align-items:center;background:#fff2d8;border-radius:999px;color:#f59e0b;content:"";display:inline-flex;height:28px;justify-content:center;width:28px}.game-shell .board{background:#fff;border:1.5px solid #536173;border-radius:6px;box-shadow:0 20px 44px #0f172a12;gap:0;width:var(--board-size)}.game-shell .cell{background:#ffffffc7;border-bottom:1px solid #d9dee5;border-right:1px solid #d9dee5;color:#0f172a;padding:5px}.game-shell .cell:nth-child(3n){border-right:2px solid #536173}.game-shell .cell:nth-child(9n){border-right:0}.game-shell .cell:nth-child(n+19):nth-child(-n+27),.game-shell .cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid #536173}.game-shell .cell:nth-child(n+73){border-bottom:0}.game-shell .cell.given{background:#f7f8fae6}.game-shell .value{font-size:clamp(1.55rem,calc(var(--board-size) / 15),2.25rem);font-weight:950}.game-shell .marker{bottom:10px;height:28px;min-width:34px}.game-shell .keypad{gap:14px;width:var(--board-size)}.game-shell .keypad button{background:#fff;border:1px solid #dfe4ea;box-shadow:0 9px 18px #0f172a12;color:#0f172a;min-height:52px}.game-shell .keypad button:hover{background:#f8fafc}.game-shell .keypad button:disabled{background:#fff;color:#0f172a;opacity:.98}.game-shell .activity{align-self:start;align-content:start;display:grid;gap:18px;grid-template-rows:auto minmax(0,auto);height:fit-content;max-height:min(42vh,360px);min-height:118px;overflow:hidden;padding:24px 28px;justify-self:start;width:350px}.activity-head{align-items:center;display:flex;justify-content:space-between}.game-shell .activity h2{color:#111827;font-size:1.15rem;font-weight:950}.activity-head span{border-right:2px solid #0f172a;border-top:2px solid #0f172a;height:8px;transform:rotate(-45deg);width:8px}.game-shell .events{align-content:start;display:grid;gap:14px;grid-auto-rows:max-content;max-height:260px;overflow:auto;padding-right:4px}.game-shell .events p{align-items:center;border-bottom:0;color:#475467;display:grid;font-size:.9rem;gap:10px;grid-template-columns:12px minmax(0,1fr) auto;line-height:1.35;min-height:24px;padding:0}.game-shell .events p:before{background:#00947e;box-shadow:none;height:8px;margin-top:0;width:8px}.game-shell .events time{color:#667085;font-size:.82rem;font-weight:950}@media(min-width:1041px){body{overflow:auto}body:has(.game-shell){overflow:hidden}.game-shell{display:block;height:100vh;overflow:hidden}.game-shell .game-grid{height:auto;overflow:visible}}@media(min-width:1041px)and (max-height:780px){.game-shell{padding-top:12px}.game-shell .topbar{margin-bottom:8px}.game-shell h1{font-size:clamp(2.8rem,4.3vw,3.85rem)}.game-shell .eyebrow{font-size:.78rem;margin-bottom:6px}.game-shell .game-grid{--board-lift: 48px;--board-size: min(31.5vw, calc(100vh - 195px) , 460px);gap:28px;grid-template-columns:minmax(272px,1fr) var(--board-size) minmax(272px,1fr);max-width:1180px}.game-shell .scoreboard{width:272px}.game-shell .activity{width:286px}.game-shell .lobby-code-wrap{gap:5px;min-height:70px;padding:10px 12px}.game-shell .lobby-code-wrap strong{font-size:1.35rem}.difficulty-pill{height:22px;padding:0 10px}.copy-code-button{height:28px;width:28px}.game-shell .player{gap:0 10px;min-height:58px;padding:9px 12px}.avatar{font-size:.9rem;height:36px;width:36px}.game-shell .modifier-list{gap:2px;padding:8px 10px}.game-shell .legend-row{font-size:.66rem;line-height:1.12}.game-shell .mod-chip{height:17px}.game-shell .leave-button{min-height:34px}.game-shell .match-header{min-height:38px}.game-shell .game-status-pill{min-height:34px;min-width:116px}.game-shell .game-status-pill:before{height:22px;width:22px}.game-shell .board-zone{gap:10px}.game-shell .keypad{gap:8px}.game-shell .keypad button{min-height:38px}.game-shell .activity{max-height:320px;padding:18px}}@media(max-width:1250px){body:has(.game-shell){overflow:auto}.game-shell{height:auto;min-height:100vh;overflow:visible;padding:24px 18px 32px}.game-shell .topbar:before{display:none}.game-shell .game-grid{--board-lift: 0px;--board-size: min(100%, calc(100vh - 270px) , 650px);grid-template-columns:1fr;max-width:780px}.game-shell .board-zone{margin:0 auto;order:1;width:var(--board-size)}.game-shell .scoreboard{justify-self:stretch;order:2;width:auto}.game-shell .activity{justify-self:stretch;order:3;width:auto}.game-shell .board,.game-shell .keypad,.game-shell .match-header,.game-shell .hint,.game-shell .frozen-banner,.game-shell .board-zone>.toast{width:100%}}@media(max-width:640px){.game-shell{padding:12px 14px 20px}.game-shell h1{font-size:clamp(2.25rem,13vw,3.4rem)}.game-shell .mobile-score-strip{display:grid}.game-shell .keypad{grid-template-columns:repeat(3,minmax(0,1fr))}}.lobby-shell,.game-shell{background:linear-gradient(90deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,rgba(23,32,51,.035) 1px,transparent 1px),linear-gradient(180deg,#fbf7ef,#eef5f1 54%,#f3f5fa);background-size:32px 32px,32px 32px,auto}.lobby-shell{padding:2rem 2rem 1.5rem}.lobby-shell .topbar,.lobby-panel{max-width:72rem}.lobby-shell .topbar{display:grid;gap:2rem;grid-template-columns:minmax(17rem,.8fr) minmax(30rem,1.2fr);justify-content:stretch;margin-bottom:1.5rem;width:100%}.lobby-shell .topbar>div{grid-column:1;justify-self:start;min-width:0;text-align:left;width:100%}.lobby-shell h1{font-size:5.25rem}.lobby-panel{align-items:start;gap:2rem;grid-template-columns:minmax(17rem,.8fr) minmax(30rem,1.2fr)}.brand-block{padding-top:1rem}.lobby-actions,.lobby-actions[data-action=join]{align-items:end;grid-template-columns:minmax(0,1fr) 12rem 9rem}.lobby-actions button{width:100%}body:has(.game-shell){overflow:auto}.game-shell{height:auto;min-height:100vh;overflow:visible;padding:1.25rem 2rem .75rem}.game-shell .topbar{align-items:flex-start;gap:1rem;margin:0 auto .75rem;max-width:92rem}.game-shell .topbar:before{flex:0 0 1.75rem}.game-shell .eyebrow{font-size:.86rem;margin-bottom:.5rem}.game-shell h1{font-size:clamp(3.65rem,4.4vw,4.4rem);line-height:.86}.game-shell .game-grid{--board-max: clamp(25rem, calc(100dvh - 20rem) , 32rem);--side-width: 20rem;align-items:start;column-gap:2rem;display:grid;grid-template-columns:minmax(16rem,1fr) minmax(28rem,var(--board-max)) minmax(16rem,1fr);margin:0 auto;max-width:92rem;overflow:visible;row-gap:2rem}.game-shell .scoreboard{align-content:start;display:grid;gap:.65rem;grid-template-columns:1fr;justify-self:end;margin-top:3rem;order:initial;width:min(100%,var(--side-width))}.game-shell .activity{align-self:start;height:auto;justify-self:start;margin-top:3rem;max-height:none;min-height:7.5rem;order:initial;overflow:hidden;width:min(100%,22rem)}.game-shell .board-zone{background:transparent;border:0;box-shadow:none;gap:.75rem;justify-self:center;max-width:var(--board-max);order:initial;padding:0;transform:none;width:100%}.game-shell .match-header,.game-shell .board,.game-shell .keypad,.game-shell .hint,.game-shell .frozen-banner,.game-shell .board-zone>.toast{width:100%}.game-shell .match-header{min-height:2.5rem}.game-shell .game-status-pill{min-height:2.5rem;min-width:9rem}.game-shell .board{max-width:var(--board-max)}.game-shell .value{font-size:clamp(1.5rem,5cqi,2.25rem)}.game-shell .marker{bottom:.45rem;height:1.5rem;min-width:2rem}.game-shell .keypad{gap:.55rem}.game-shell .keypad button{min-height:2.75rem}.game-shell .lobby-code-wrap{gap:.45rem;min-height:auto;padding:.95rem 1rem}.game-shell .lobby-code-wrap strong{font-size:1.55rem}.game-shell .players{gap:.65rem}.game-shell .player{gap:.45rem .75rem;grid-template-columns:2.75rem minmax(0,1fr) auto;min-height:4.6rem;padding:.8rem}.game-shell .avatar{font-size:1rem;height:2.75rem;width:2.75rem}.game-shell .score{font-size:1.1rem;height:2.25rem;min-width:2.75rem}.game-shell .waiting-player{color:#667085;min-height:6rem}.game-shell .waiting-score{pointer-events:none;visibility:hidden}.game-shell .modifier-list{gap:.45rem;padding:.8rem .95rem}.game-shell .legend-row{font-size:.78rem;gap:.5rem;grid-template-columns:2.45rem minmax(0,1fr);line-height:1.15}.game-shell .mod-chip{height:1.35rem}.game-shell .leave-button{min-height:3rem}.game-shell .events{max-height:18rem}@media(max-width:76rem){.lobby-shell h1,.game-shell h1{font-size:3.5rem}.lobby-panel,.lobby-shell .topbar{grid-template-columns:1fr}.brand-block{padding:0}.game-shell .topbar:before{display:none}.game-shell .game-grid{--board-max: clamp(20rem, calc(100dvh - 17.5rem) , 32rem);grid-template-columns:minmax(0,1fr);max-width:36rem}.game-shell .board-zone{order:1}.game-shell .scoreboard{justify-self:stretch;margin-top:0;order:2;width:100%}.game-shell .activity{justify-self:stretch;margin-top:0;order:3;width:100%}.game-shell .mobile-score-strip{display:grid}}@media(min-width:76.01rem){body:has(.game-shell){overflow:hidden}.game-shell{height:100dvh;overflow:hidden}.game-shell .scoreboard{gap:.5rem;margin-top:1.5rem}.game-shell .activity{margin-top:1.5rem}.game-shell .lobby-code-wrap{padding:.75rem .85rem}.game-shell .player,.game-shell .waiting-player{height:4.75rem;min-height:4.75rem;padding:.65rem .75rem}.game-shell .player{grid-template-columns:2.35rem minmax(0,1fr) auto}.game-shell .avatar{font-size:.88rem;height:2.35rem;width:2.35rem}.game-shell .player .player-copy{padding-bottom:.85rem}.game-shell .waiting-player .player-copy{padding-bottom:0}.game-shell .badges{left:3.85rem;right:3.75rem;top:3.35rem}.game-shell .modifier-list{gap:.28rem;padding:.55rem .75rem}.game-shell .legend-row{font-size:.7rem;gap:.45rem;grid-template-columns:2.25rem minmax(0,1fr);line-height:1.1}.game-shell .mod-chip{height:1.15rem}.game-shell .leave-button{min-height:2.45rem}}@media(max-width:58rem){.lobby-shell,.game-shell{padding:1.25rem}.lobby-shell h1,.game-shell h1{font-size:3.25rem}.lobby-actions,.lobby-actions[data-action=join]{grid-template-columns:1fr}}@media(max-width:42rem){.lobby-shell,.game-shell{padding:.875rem}.lobby-shell .topbar,.game-shell .topbar{margin-bottom:.9rem}.lobby-shell h1,.game-shell h1{font-size:3rem}.game-shell .game-grid{--board-max: 100%;row-gap:1.5rem}.game-shell .board-zone{gap:.9rem}.game-shell .keypad{grid-template-columns:repeat(3,minmax(0,1fr));gap:.875rem}.game-shell .keypad button{min-height:3.35rem}}.toast,.game-shell .board-zone>.toast,.lobby-panel>.toast{left:auto;max-width:min(24rem,calc(100vw - 2rem));position:fixed;right:1rem;width:max-content}@media(max-width:42rem){.toast,.game-shell .board-zone>.toast,.lobby-panel>.toast{left:.875rem;max-width:none;right:.875rem;width:auto}}:root{--canvas: #f6f1e8;--paper: #fffdf8;--paper-soft: #f7faf5;--ink: #111827;--muted: #667085;--line: #d8ddd5;--line-strong: #536173;--teal: #0f766e;--teal-dark: #115e59;--coral: #c24133;--gold: #b7791f;--blue: #3861b8;--violet: #6654c9;--green: #14835f;--shadow: 0 20px 60px rgba(30, 41, 59, .11);--shadow-soft: 0 14px 34px rgba(30, 41, 59, .07);--palette-canvas-a: #fbf7ef;--palette-canvas-b: #eef5f1;--palette-canvas-c: #f3f5f8;--palette-grid-line: rgba(17, 24, 39, .04);--palette-paper: rgba(255, 253, 248, .94);--palette-paper-solid: #fffdf8;--palette-border: #d9ded7;--palette-ink: #111827;--palette-muted: #667085;--palette-teal: #0f766e;--palette-teal-dark: #115e59;--palette-teal-soft: #d9f3ec;--palette-danger: #c24133;--palette-danger-soft: #fff1ed;--palette-board-grid: #536173;--palette-board-line: #d9dee5;--palette-cell-empty: #fffdf8;--palette-cell-given: #e8ddc9;--palette-cell-player: #cfeee7;--palette-cell-player-ink: #07543f;--palette-cell-opponent: #ffe4dc;--palette-cell-opponent-ink: #943326;--palette-select: #d99b2b;--palette-power-double-bg: #fff0c2;--palette-power-double-fg: #80520b;--palette-power-freeze-bg: #e5eeff;--palette-power-freeze-fg: #3157b7;--palette-power-shield-bg: #e1f3ee;--palette-power-shield-fg: #116447;--palette-power-steal-bg: #ffe3dc;--palette-power-steal-fg: #a33a2c;--palette-power-insight-bg: #eeeaff;--palette-power-insight-fg: #5b49ba}body,.lobby-shell,.game-shell{background:linear-gradient(90deg,var(--palette-grid-line) 1px,transparent 1px),linear-gradient(180deg,var(--palette-grid-line) 1px,transparent 1px),linear-gradient(180deg,var(--palette-canvas-a) 0%,var(--palette-canvas-b) 54%,var(--palette-canvas-c) 100%);background-size:32px 32px,32px 32px,auto;color:var(--palette-ink)}h1,h2,h3,.game-shell h1,.game-shell .activity h2{color:var(--palette-ink)}.eyebrow,.game-shell .eyebrow,.lobby-code-wrap small,.player-state,.game-shell .player-state{color:var(--palette-teal)}label,.brand-block p,.legend-row,.game-shell .legend-row,.events p,.game-shell .events p,.waiting-player,.game-shell .waiting-player{color:var(--palette-muted)}.lobby-actions,.lobby-code-wrap,.player,.activity,.modifier-list,.game-shell .lobby-code-wrap,.game-shell .player,.game-shell .activity,.game-shell .modifier-list{background:var(--palette-paper);border-color:var(--palette-border);box-shadow:var(--shadow-soft)}input,select,.copy-code-button,.keypad button,.game-shell .keypad button{background:#fff;border-color:var(--palette-border);color:var(--palette-ink)}input:hover,select:hover,.copy-code-button:hover,.keypad button:hover,.game-shell .keypad button:hover{background:var(--paper-soft);border-color:#bdc7c0}button:focus-visible,input:focus-visible,select:focus-visible{outline-color:#0f766e52}.lobby-actions button{background:var(--palette-teal);box-shadow:0 10px 18px #0f766e2e;color:#fff}.lobby-actions button:hover{background:var(--palette-teal-dark)}.avatar{background:linear-gradient(135deg,#289c78,var(--palette-teal-dark))}.avatar.ghost{background:#e7e9ed;color:var(--palette-muted)}.score,.mobile-score strong,.game-shell .score{background:#f5faf8;color:var(--palette-teal-dark)}.difficulty-pill{background:transparent;color:var(--palette-teal-dark)}.game-shell .game-status-pill{background:#fff;border-color:var(--palette-border);color:var(--palette-ink)}.game-shell .game-status-pill:before{background:#ffefd2}.game-shell .board{background:var(--palette-board-grid);border-color:var(--palette-board-grid)}.game-shell .cell{background:var(--palette-cell-empty);border-color:var(--palette-board-line);color:var(--palette-ink)}.game-shell .cell:not(:disabled):hover{background:#f7fbf8;box-shadow:inset 0 0 0 2px #0f766e2e}.game-shell .cell.given{background:var(--palette-cell-given);color:var(--palette-ink)}.game-shell .cell.mine{background:var(--palette-cell-player);color:var(--palette-cell-player-ink)}.game-shell .cell.theirs{background:var(--palette-cell-opponent);color:var(--palette-cell-opponent-ink)}.game-shell .cell.selected{outline-color:var(--palette-select)}.game-shell .cell.opponent-selected{box-shadow:inset 0 0 0 3px #c241338c}.game-shell .cell.opponent-selected:after{background:var(--palette-danger)}.DoublePoints,.mod-DoublePoints .marker{background:var(--palette-power-double-bg);color:var(--palette-power-double-fg)}.Freeze,.mod-Freeze .marker{background:var(--palette-power-freeze-bg);color:var(--palette-power-freeze-fg)}.Shield,.mod-Shield .marker{background:var(--palette-power-shield-bg);color:var(--palette-power-shield-fg)}.Steal,.mod-Steal .marker{background:var(--palette-power-steal-bg);color:var(--palette-power-steal-fg)}.Insight,.mod-Insight .marker{background:var(--palette-power-insight-bg);color:var(--palette-power-insight-fg)}.leave-button,.game-shell .leave-button{background-color:#fff4ef;background-image:none;border-color:#f7d8cf;color:var(--palette-danger);transform:none;transition:background-color .14s ease,border-color .14s ease,box-shadow .14s ease}.leave-button:hover,.game-shell .leave-button:hover{background-color:#fff0eb;background-image:none;border-color:#edc8bd;transform:none}.toast{box-shadow:0 18px 38px #1e293b21}.toast.info{background:#edf8f5;border-color:#a8d9d1;color:var(--palette-teal-dark)}.events p:before,.game-shell .events p:before,.player-state.online:before{background:var(--palette-teal)}.copy-code-button{color:#475467}.copy-code-button svg{display:block;fill:none;height:1.2rem;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.15;width:1.2rem}.copy-code-button:hover{color:var(--palette-teal-dark)}.game-shell .player{height:6.25rem;min-height:6.25rem;overflow:hidden;position:relative}.game-shell .player .avatar{align-self:center;grid-column:1;grid-row:1}.game-shell .player .player-copy{align-self:center;grid-column:2;grid-row:1;padding-bottom:1.05rem}.game-shell .player .score-wrap{align-self:center;grid-column:3;grid-row:1}.game-shell .waiting-player{height:6.25rem;min-height:6.25rem}.game-shell .waiting-player .player-copy{padding-bottom:0}.game-shell .badges{align-items:center;display:flex;flex-wrap:nowrap;gap:.35rem;grid-column:auto;height:1.1rem;left:4.3rem;min-height:0;overflow:hidden;position:absolute;right:3.95rem;top:4.45rem}.game-shell .badges:empty{display:flex;visibility:hidden}.game-shell .badges span{flex:0 1 auto;font-size:.63rem;line-height:1;max-width:100%;overflow:hidden;padding:.18rem .43rem;text-overflow:ellipsis;white-space:nowrap}.game-shell .cell.hinted{animation:insightPulse 1.5s ease-in-out infinite;box-shadow:inset 0 0 0 2px #6654c947}.game-shell .cell.hinted .value{color:var(--palette-power-insight-fg);opacity:.46}@keyframes insightPulse{0%,to{background:var(--palette-cell-empty)}50%{background:#f6f2ff}}.activity-head{justify-content:flex-start}.activity-head span{display:none}.game-shell .events p{align-items:center;column-gap:.75rem;grid-template-columns:.5rem minmax(0,1fr) auto;min-height:1.55rem}.events p:before,.game-shell .events p:before{align-self:center;height:.45rem;margin-top:0;place-self:center;width:.45rem}@media(min-width:76.01rem)and (max-height:62rem){.game-shell{padding-top:1.5rem}.game-shell .topbar{margin-bottom:1rem}.game-shell h1{font-size:4.35rem}.game-shell .game-grid{--board-max: clamp(28rem, calc(100dvh - 18rem) , 34rem)}}@media(min-width:76.01rem)and (max-height:50rem){.game-shell{padding-bottom:0}}@media(min-width:76.01rem){.game-shell{--game-board-max: clamp(25rem, calc(100dvh - 20rem) , 32rem);--game-side-width: 20rem;--game-grid-gap: 2rem}.game-shell .topbar,.game-shell .game-grid{column-gap:var(--game-grid-gap);grid-template-columns:minmax(16rem,1fr) minmax(28rem,var(--game-board-max)) minmax(16rem,1fr);max-width:92rem}.game-shell .topbar{display:grid;margin:0 auto .75rem;position:relative;width:100%}.game-shell .topbar>div{grid-column:1;grid-row:1;justify-self:end;width:min(100%,var(--game-side-width))}.game-shell .topbar:before{grid-column:1;grid-row:1;justify-self:end;margin-right:calc(var(--game-side-width) + .75rem)}.game-shell .game-grid{--board-max: var(--game-board-max);--side-width: var(--game-side-width)}}@media(min-width:76.01rem){.game-shell{--game-board-max: clamp(28rem, calc(100dvh - 15rem) , 34.5rem);--game-side-width: 14.75rem;--game-grid-gap: clamp(1.35rem, 2vw, 2rem);padding-top:.95rem}.game-shell .topbar{margin-bottom:.35rem}.game-shell .topbar:before{margin-right:calc(var(--game-side-width) + .65rem);opacity:.55}.game-shell .eyebrow{font-size:.76rem;margin-bottom:.3rem}.game-shell h1{font-size:clamp(3rem,3.7vw,3.7rem)}.game-shell .scoreboard,.game-shell .activity{margin-top:1rem}.game-shell .lobby-code-wrap,.game-shell .player,.game-shell .activity,.game-shell .modifier-list{background:#fffdf8d1;box-shadow:0 10px 24px #1e293b0b}.game-shell .lobby-code-wrap{gap:.25rem;padding:.68rem .78rem}.game-shell .lobby-code-wrap strong{font-size:1.35rem}.copy-code-button{height:1.7rem;width:1.7rem}.difficulty-pill{font-size:.72rem;height:auto;padding:0}.game-shell .player,.game-shell .waiting-player{height:4.25rem;min-height:4.25rem;padding:.55rem .65rem}.game-shell .player{grid-template-columns:2rem minmax(0,1fr) auto}.game-shell .avatar{font-size:.78rem;height:2rem;width:2rem}.game-shell .player .player-copy{padding-bottom:.7rem}.game-shell .player strong{font-size:.78rem}.game-shell .player-state{font-size:.7rem}.game-shell .lobby-code-wrap span,.game-shell .score-wrap span{font-size:.66rem}.game-shell .score{font-size:.95rem;height:2rem;min-width:2.25rem}.game-shell .badges{left:3.3rem;right:3.25rem;top:3rem}.game-shell .badges span{font-size:.58rem;padding:.15rem .35rem}.game-shell .modifier-list{gap:.18rem;padding:.45rem .65rem}.game-shell .legend-row{font-size:.62rem;gap:.36rem;grid-template-columns:1.85rem minmax(0,1fr)}.game-shell .mod-chip{font-size:.56rem;height:1rem}.game-shell .leave-button{font-size:.8rem;min-height:2.1rem}.game-shell .activity{max-height:13rem;padding:.75rem .85rem;width:min(100%,14.75rem)}.game-shell .activity h2{font-size:.95rem}.game-shell .events{gap:.36rem;max-height:9.6rem;overflow:hidden;scrollbar-width:none}.game-shell .events::-webkit-scrollbar{display:none}.game-shell .events p{font-size:.66rem;min-height:1.3rem}.game-shell .events time{font-size:.62rem}.game-shell .board{box-shadow:0 24px 54px #1118272b}.game-shell .value{font-size:clamp(1.65rem,calc(var(--game-board-max) / 13),2.65rem)}.game-shell .keypad button{min-height:2.55rem}}.game-shell .board-stage{display:grid;place-items:center;position:relative;width:var(--board-size)}.game-shell .board-stage .board{width:100%}.game-shell .board-stage.waiting .board{filter:blur(6px);opacity:.42;pointer-events:none;transform:scale(.985);transition:filter .18s ease,opacity .18s ease,transform .18s ease}.ready-panel{align-items:center;display:flex;top:0;right:0;bottom:0;left:0;justify-content:center;padding:1rem;position:absolute}.ready-card{align-items:center;background:#fffdf8e6;border:1px solid rgba(18,108,104,.18);border-radius:8px;box-shadow:0 16px 36px #0f172a1f;display:grid;gap:.65rem;justify-items:center;min-width:9.5rem;padding:.85rem 1rem}.ready-card span{color:var(--muted);font-size:.74rem;font-weight:950;text-transform:uppercase}.ready-card button{background:var(--teal);border:0;border-radius:7px;color:#fff;cursor:pointer;font:inherit;font-weight:950;min-height:2.35rem;min-width:7rem;padding:0 1rem}.ready-card button:hover{background:var(--teal-dark)}.ready-card button.is-ready,.ready-card button:disabled{background:#d9f4ee;color:var(--teal-dark)}.ready-card button.is-ready{border:1px solid rgba(18,108,104,.22);cursor:pointer}.ready-card button.is-ready:hover{background:#c5ece4}.game-shell .ready-badge{background:#d9f4ee;color:var(--teal-dark)}.result-banner{align-items:center;background:#fff;border:1px solid #dfe4ea;border-radius:8px;box-shadow:0 10px 24px #0f172a0d;color:var(--ink);display:inline-flex;font-size:.9rem;font-weight:950;justify-content:center;min-height:2.65rem;padding:0 1rem}@media(min-width:76.01rem){.game-shell .board-zone{gap:.8rem}.game-shell .scoreboard,.game-shell .activity{margin-top:1.65rem}.game-shell .activity{height:13rem;max-height:13rem;overflow:hidden}.game-shell .events{max-height:9.6rem;overflow-y:auto;padding-right:.25rem;scrollbar-color:rgba(18,108,104,.45) transparent;scrollbar-gutter:stable;scrollbar-width:thin}.game-shell .events::-webkit-scrollbar{display:block;width:.45rem}.game-shell .events::-webkit-scrollbar-track{background:transparent}.game-shell .events::-webkit-scrollbar-thumb{background:#126c6857;border-radius:999px}.game-shell .events::-webkit-scrollbar-thumb:hover{background:#126c6885}}body:has(.game-shell){overflow-x:hidden;overflow-y:auto}.game-shell{height:auto;min-height:100dvh;overflow:visible}.game-shell .game-grid{--board-size: min(100%, var(--board-max, 32rem))}.game-shell .board-zone{inline-size:var(--board-size);max-inline-size:100%}.game-shell .board-stage,.game-shell .board,.game-shell .keypad,.game-shell .mobile-score-strip,.game-shell .frozen-banner,.game-shell .result-banner{inline-size:100%;max-inline-size:100%}.game-shell .board-stage,.game-shell .board{width:100%}.game-shell .mobile-score-strip{gap:.5rem;grid-template-columns:repeat(2,minmax(0,1fr));justify-self:stretch}.game-shell .mobile-score{display:flex}@media(min-width:76.01rem){body:has(.game-shell){overflow-y:auto}.game-shell{--game-board-size: min(34.5rem, 42vw, calc(100dvh - 10.25rem) );height:auto;overflow:visible}.game-shell .topbar,.game-shell .game-grid{grid-template-columns:minmax(13rem,1fr) var(--game-board-size) minmax(13rem,1fr)}.game-shell .game-grid{--board-size: var(--game-board-size)}}@media(max-width:76rem)and (min-width:42.01rem){.game-shell .game-grid{--board-size: min(100%, 32rem, calc(100dvh - 17.5rem) )}}@media(max-width:42rem){.game-shell{padding:.625rem .75rem}.game-shell .topbar{margin-bottom:.5rem}.game-shell .eyebrow{font-size:.68rem;margin-bottom:.2rem}.game-shell h1{font-size:clamp(2rem,11vw,2.65rem)}.game-shell .game-grid{--board-size: min(100%, calc(100dvh - 18rem) );row-gap:1rem}.game-shell .board-zone,.game-shell .mobile-score-strip{gap:.5rem}.game-shell .mobile-score{min-height:2.5rem;padding:.45rem .55rem}.game-shell .mobile-score strong{min-height:1.75rem}.game-shell .keypad{gap:.5rem}.game-shell .keypad button{min-height:2.75rem}}.copy-code-button{overflow:visible;position:relative}.copy-code-button svg{transition:opacity .15s ease,transform .18s ease}.copy-code-button .copied-icon{inset:50% auto auto 50%;opacity:0;position:absolute;transform:translate(-50%,-50%) scale(.45) rotate(-14deg)}.copy-code-button[data-copied=true]{background:var(--palette-teal);border-color:#0f766e66;box-shadow:0 0 0 .2rem #0f766e14;color:#fff}.copy-code-button[data-copied=true] .copy-icon{opacity:0;transform:scale(.82)}.copy-code-button[data-copied=true] .copied-icon{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0)}.copy-code-button[data-copy-error=true]{animation:copyButtonShake .42s ease;background:#fff7f5;border-color:#fecaca;box-shadow:0 0 0 .35rem #c241331a;color:var(--palette-danger)}.copy-code-button[data-copy-error=true] .copy-icon{transform:scale(.88)}.copy-code-button[data-copy-error=true]:after{animation:copiedBubble 1.4s ease forwards;background:#111827;border-radius:999px;bottom:calc(100% + .5rem);color:#fff;content:"Copied";font-size:.68rem;font-weight:950;left:50%;letter-spacing:0;line-height:1;padding:.42rem .55rem;pointer-events:none;position:absolute;transform:translate(-50%);white-space:nowrap}.copy-code-button[data-copy-error=true]:after{background:#7f1d1d;content:"Copy failed"}@keyframes copiedBubble{0%{opacity:0;transform:translate(-50%,.25rem) scale(.92)}18%,74%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-.2rem) scale(.96)}}@keyframes copiedRing{0%{opacity:.8;transform:scale(.88)}to{opacity:0;transform:scale(1.5)}}@keyframes copyButtonShake{0%,to{transform:translate(0)}22%{transform:translate(-2px)}44%{transform:translate(2px)}66%{transform:translate(-1px)}}.game-shell .board-stage.is-frozen .board{filter:saturate(.68) brightness(.95)}.game-shell .board-stage.is-frozen .cell{cursor:not-allowed}.game-shell .board-stage.is-finished .board{filter:blur(3px) saturate(.82) brightness(.96);pointer-events:none;transform:scale(.992);transition:filter .22s ease,transform .22s ease}.freeze-overlay{align-items:center;background:radial-gradient(circle at 22% 18%,rgba(255,255,255,.82),transparent 18%),radial-gradient(circle at 76% 74%,rgba(219,234,254,.72),transparent 22%),linear-gradient(135deg,#eff8ff9e,#2563eb29);border:1px solid rgba(96,165,250,.38);border-radius:8px;box-shadow:inset 0 0 0 1px #ffffff6b;display:grid;top:0;right:0;bottom:0;left:0;justify-items:center;overflow:hidden;pointer-events:auto;position:absolute;z-index:8}.freeze-overlay:before,.freeze-overlay:after{display:none}.victory-overlay{align-items:center;animation:resultOverlayIn .26s ease-out both;background:radial-gradient(circle at 26% 18%,rgba(255,255,255,.86),transparent 20%),radial-gradient(circle at 76% 76%,rgba(217,244,238,.7),transparent 24%),linear-gradient(135deg,#fffdf8b8,#0f766e2e);border:1px solid rgba(15,118,110,.28);border-radius:8px;box-shadow:inset 0 0 0 1px #ffffff75;display:grid;top:0;right:0;bottom:0;left:0;justify-items:center;overflow:hidden;pointer-events:auto;position:absolute;z-index:9}.victory-overlay.is-tie{background:radial-gradient(circle at 24% 18%,rgba(255,255,255,.84),transparent 20%),radial-gradient(circle at 76% 76%,rgba(238,234,255,.62),transparent 24%),linear-gradient(135deg,#fffdf8bd,#6d5bd029)}.victory-overlay.is-loss{background:radial-gradient(circle at 24% 18%,rgba(255,255,255,.84),transparent 20%),radial-gradient(circle at 76% 76%,rgba(254,226,226,.58),transparent 24%),linear-gradient(135deg,#fffdf8bd,#d4513c24)}.victory-card{align-items:center;animation:resultCardIn .32s cubic-bezier(.2,.8,.2,1) both;background:#ffffffdb;border:1px solid rgba(15,118,110,.24);border-radius:8px;box-shadow:0 18px 44px #0f172a29;color:var(--palette-teal-dark);display:grid;gap:.38rem;justify-items:center;min-width:min(15rem,76%);padding:1rem 1.25rem}.victory-card strong{color:var(--palette-ink);font-size:clamp(1.4rem,5cqi,2.15rem);line-height:1;text-align:center}.victory-detail{color:var(--palette-muted);font-size:.78rem;font-weight:850;line-height:1.25;text-align:center}.rematch-count{background:#f1f5f9db;border:1px solid rgba(100,116,139,.16);border-radius:999px;color:var(--palette-slate);font-size:.68rem;font-weight:950;line-height:1;margin-top:.16rem;padding:.38rem .58rem;text-transform:uppercase}.victory-kicker{color:var(--palette-teal);font-size:.72rem;font-weight:950;text-transform:uppercase}.play-again-button{background:var(--palette-teal);border-radius:7px;box-shadow:0 10px 18px #0f766e29;color:#fff;font-weight:950;margin-top:.32rem;min-height:2.35rem;min-width:7.5rem;padding:0 1rem;transition:background .14s ease,transform .14s ease}.play-again-button:hover{background:var(--palette-teal-dark);transform:translateY(-1px)}.play-again-button.is-ready{background:#d9f4eef5;box-shadow:inset 0 0 0 1px #0f766e33;color:var(--palette-teal-dark)}.play-again-button.is-ready:hover{background:#c5e8e0fa}@keyframes resultOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes resultCardIn{0%{opacity:0;transform:translateY(.45rem) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.game-shell .lobby-code-wrap{padding-right:4.25rem;position:relative}.lobby-code-head{display:block}.copy-code-button{align-items:center;display:inline-grid;justify-items:center;place-items:center}.game-shell .lobby-code-wrap .copy-code-button{position:absolute;right:1.35rem;top:2rem}.copy-code-button svg{inset:auto;margin:auto}.copy-code-button .copied-icon{inset:50% auto auto 50%}.events p:before,.game-shell .events p:before{background:#126c6829;border:1px solid rgba(18,108,104,.28);border-radius:999px;box-shadow:none;height:.38rem;width:.38rem}.freeze-card{align-items:center;background:#ffffffd1;border:1px solid rgba(96,165,250,.34);border-radius:8px;box-shadow:0 18px 44px #1e40af2e;color:#1e3a8a;display:grid;justify-items:center;min-width:min(12rem,72%);padding:1rem 1.15rem;position:relative;z-index:1}.freeze-kicker,.freeze-caption{font-size:.72rem;font-weight:950;text-transform:uppercase}.freeze-count{color:#1d4ed8;font-size:clamp(3rem,16cqi,6rem);font-weight:950;line-height:.95}@keyframes frostSweep{0%,18%{opacity:0;transform:translate(0) rotate(18deg)}42%{opacity:1}to{opacity:0;transform:translate(520%) rotate(18deg)}}.game-shell .players{gap:.6rem}.game-shell .player{align-items:center;background:#fffdf8f0;border:1px solid rgba(83,97,115,.18);border-radius:8px;box-shadow:0 12px 28px #1e293b0f;display:grid;gap:.58rem .65rem;grid-template-columns:minmax(0,1fr) auto;height:auto;min-height:0;overflow:visible;padding:.68rem .72rem;position:relative}.game-shell .player.self{border-color:#0f766e52;box-shadow:inset 3px 0 0 var(--palette-teal),0 12px 28px #1e293b0f}.game-shell .player.is-frozen{border-color:#3157b747}.game-shell .player.is-offline{opacity:.76}.game-shell .player-main{align-items:center;display:flex;gap:.6rem;min-width:0}.game-shell .avatar{flex:0 0 auto;font-size:.78rem;height:2.15rem;width:2.15rem}.game-shell .player-copy{gap:.22rem;min-width:0;padding:0}.game-shell .player-copy strong{align-items:center;color:var(--palette-ink);display:flex;font-size:.86rem;gap:.35rem;line-height:1.08;min-width:0}.game-shell .you-tag{display:none}.game-shell .player-state{align-items:center;color:var(--palette-muted);display:inline-flex;font-size:.68rem;font-weight:900;gap:.32rem;line-height:1}.game-shell .player-state:before{flex:0 0 auto;height:.42rem;width:.42rem}.game-shell .player-state.online{color:var(--palette-teal-dark)}.game-shell .player-state.offline{color:var(--palette-muted)}.game-shell .score-wrap{align-self:stretch;display:grid;gap:.18rem;justify-items:end;min-width:3rem}.game-shell .score-wrap span{font-size:.58rem;line-height:1}.game-shell .score{align-items:center;border:1px solid rgba(15,118,110,.1);border-radius:8px;display:grid;font-size:1.12rem;height:2.2rem;justify-content:center;line-height:1;min-width:2.65rem;padding:0 .48rem;place-items:center}.game-shell .badges{align-items:center;display:flex;flex-wrap:wrap;gap:.35rem;grid-column:1 / -1;height:auto;left:auto;min-height:1.2rem;overflow:visible;position:static;right:auto;top:auto}.game-shell .badges:empty{display:none}.game-shell .status-chip{align-items:center;background:#f4f6f8;border:1px solid rgba(83,97,115,.1);border-radius:999px;color:var(--palette-muted);display:inline-flex;flex:0 1 auto;font-size:.62rem;font-weight:950;line-height:1;max-width:100%;min-height:1.22rem;overflow:hidden;padding:.22rem .48rem;text-overflow:ellipsis;white-space:nowrap}.game-shell .ready-badge{background:var(--palette-teal-soft);border-color:#0f766e1f;color:var(--palette-teal-dark)}.game-shell .not-ready-badge{background:#f2f4f7;color:#667085}.game-shell .power-chip,.game-shell .guard-chip{background:var(--palette-power-shield-bg);color:var(--palette-power-shield-fg)}.game-shell .frozen-chip{background:var(--palette-power-freeze-bg);color:var(--palette-power-freeze-fg)}.game-shell .penalty-chip{background:var(--palette-danger-soft);color:var(--palette-danger)}.game-shell .waiting-player{color:var(--palette-muted);height:auto;min-height:0}.game-shell .waiting-player .player-copy{padding:0}.game-shell .waiting-score{opacity:0;pointer-events:none;visibility:hidden}.game-shell .mobile-score{align-items:stretch;display:grid;gap:.38rem;min-height:4.4rem;padding:.55rem .62rem}.game-shell .mobile-score-head{align-items:center;display:flex;gap:.5rem;justify-content:space-between;min-width:0}.game-shell .mobile-score-head span{color:var(--palette-ink);font-size:.8rem;font-weight:950;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-shell .mobile-score-head strong{align-items:center;background:#f5faf8;border-radius:7px;color:var(--palette-teal-dark);display:inline-flex;flex:0 0 auto;font-size:1rem;font-weight:950;justify-content:center;min-height:1.8rem;min-width:2.2rem;padding:0 .45rem}.game-shell .mobile-score-meta{align-items:center;display:flex;gap:.35rem;min-width:0}.game-shell .mobile-badges{display:flex;flex:1 1 auto;gap:.28rem;min-width:0;overflow:hidden}.game-shell .mobile-badges .status-chip{font-size:.56rem;min-height:1.05rem;padding:.18rem .34rem}@media(min-width:76.01rem){.game-shell .player{padding:.62rem .68rem}.game-shell .player-copy strong{font-size:.8rem}.game-shell .score{font-size:1.02rem;height:2.05rem;min-width:2.35rem}.game-shell .status-chip{font-size:.58rem;min-height:1.12rem;padding:.19rem .38rem}}@media(max-width:42rem){.game-shell .game-grid{--board-size: min(100%, calc(100dvh - 20rem) )}}body:has(.lobby-shell){overflow-x:hidden;overflow-y:auto}.lobby-shell{display:block;height:auto;min-height:100dvh;overflow:visible;padding:clamp(.875rem,2vw,2rem)}.lobby-shell .topbar,.lobby-shell .lobby-panel{max-width:72rem;width:min(100%,72rem)}.lobby-shell .topbar{display:block;margin:0 auto clamp(.75rem,2vw,1.35rem)}.lobby-shell .topbar>div{max-width:36rem;min-width:0;width:100%}.lobby-shell h1{font-size:clamp(2.7rem,6.3vw,5.25rem);line-height:.9}.lobby-panel{align-items:start;display:grid;gap:clamp(1rem,3vw,2rem);grid-template-columns:minmax(15.5rem,.82fr) minmax(24rem,1.18fr);margin:0 auto}.brand-block{gap:clamp(.65rem,1.4vw,1rem);min-width:0;padding:clamp(.1rem,1vw,.9rem) 0 0}.brand-block h2{font-size:clamp(1.55rem,3vw,2.45rem);max-width:25rem}.brand-block p{font-size:clamp(.9rem,1.25vw,1.03rem);max-width:29rem}.lobby-forms{gap:clamp(.75rem,1.2vw,1rem);min-width:0}.lobby-actions,.lobby-actions[data-action=join]{align-items:end;gap:.8rem;grid-template-columns:minmax(10rem,1fr) minmax(9.5rem,.72fr) minmax(8.5rem,auto);min-width:0;padding:clamp(.85rem,1.6vw,1.1rem)}.lobby-actions h3{margin-bottom:.05rem}.lobby-actions input,.lobby-actions select{min-height:2.7rem}.lobby-actions button{height:2.7rem;min-height:2.7rem;padding:0 .9rem}@media(max-width:68rem){.lobby-shell .topbar,.lobby-panel{max-width:44rem}.lobby-panel{grid-template-columns:1fr}.brand-block{padding:0}.brand-block h2,.brand-block p{max-width:36rem}}@media(max-width:52rem){.lobby-actions,.lobby-actions[data-action=join]{grid-template-columns:1fr}}@media(max-width:42rem){.lobby-shell{padding:.75rem}.lobby-shell .topbar{margin-bottom:.6rem}.lobby-shell .eyebrow{font-size:.68rem;margin-bottom:.2rem}.lobby-shell h1{font-size:clamp(2.15rem,13vw,2.65rem)}.brand-block{gap:.45rem}.brand-block h2{font-size:clamp(1.28rem,7vw,1.65rem);line-height:1}.brand-block p{font-size:.86rem;line-height:1.35}.lobby-panel{gap:.75rem}.lobby-forms{gap:.65rem}.lobby-actions,.lobby-actions[data-action=join]{gap:.6rem;padding:.75rem}.lobby-actions h3{font-size:.92rem}.lobby-actions label{font-size:.74rem;gap:.3rem}.lobby-actions input,.lobby-actions select,.lobby-actions button{min-height:2.45rem}.lobby-actions button{height:2.45rem}}
