:root{--paper: #ece0c8;--paper-2: #e3d4b3;--panel: #f3ead4;--ink: #2f2417;--ink-soft: #6b5b41;--gold: #b8862f;--gold-2: #d9a943;--line: #c3ad82;--line-dark: #9c8559;--danger: #a23b2c;--ok: #4f7a3a;--shadow: 0 8px 24px rgba(60, 44, 20, .22);--table: #16334f;--table-2: #0b1d30;--table-panel: #1c3d5e;--table-line: #2e5a86;--parch-on-dark: #eaf2fa;--serif: "EB Garamond", "Iowan Old Style", Palatino, Georgia, serif;--display: "Cinzel", "Iowan Old Style", Palatino, Georgia, serif;--sans: "EB Garamond", system-ui, "Segoe UI", serif;--radius: 12px}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{font-family:var(--serif);font-size:17px;color:var(--ink);background:radial-gradient(120% 90% at 50% -10%,#f4ecd6 0%,var(--paper) 55%,var(--paper-2) 100%);-webkit-font-smoothing:antialiased}.brand,h1,h2,h3,.seal-code,.standing .total,.hud-crowns,.ring-num{font-family:var(--display)}#app{min-height:100vh;display:flex;flex-direction:column}.screen{flex:1;width:100%;max-width:760px;margin:0 auto;padding:28px 18px 40px;display:flex;flex-direction:column}.home{align-items:center;text-align:center;justify-content:center;gap:6px}.crest{line-height:0;filter:drop-shadow(0 3px 6px rgba(60,44,20,.35))}svg.icon{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;vertical-align:-5px;flex:none}svg.icon.sm{width:17px;height:17px;vertical-align:-3px}svg.icon.gold{color:var(--gold)}.shield-chip,.banner-chip{width:24px;height:31px;flex:none}.brand{font-family:var(--serif);font-size:clamp(34px,8vw,52px);margin:2px 0 0;letter-spacing:.5px}.tagline{color:var(--ink-soft);margin:0 0 18px;font-size:15px}.card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;gap:12px}label{display:flex;flex-direction:column;gap:6px;text-align:left;font-weight:600;font-size:14px;color:var(--ink-soft)}input{font:inherit;padding:12px 14px;border-radius:10px;border:1px solid var(--line-dark);background:#fff8ea;color:var(--ink)}input:focus{outline:2px solid var(--gold-2);border-color:var(--gold-2)}.code-input{text-transform:uppercase;letter-spacing:4px;text-align:center;font-weight:700}.join-row{display:flex;gap:8px}.join-row .code-input{flex:1}.divider{color:var(--ink-soft);font-size:13px;position:relative}.btn{font:inherit;font-weight:600;cursor:pointer;padding:12px 16px;border-radius:10px;border:1px solid var(--line-dark);background:#f7eed7;color:var(--ink);transition:transform .06s,background .15s}.btn:hover{background:#fff3da;border-color:var(--gold-2)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-color:#8a6420;color:#2a1c06}.btn.primary:hover{filter:brightness(1.05)}.btn.ghost{background:transparent;border-color:var(--line)}.btn.tiny{padding:6px 10px;font-size:13px}.muted{color:var(--ink-soft);font-size:14px}.credits{color:var(--ink-soft);font-size:11px;margin-top:18px;opacity:.8}.credits a{color:var(--gold)}.lobby{gap:18px}.seal{align-self:center;text-align:center;background:var(--panel);border:2px solid var(--gold);border-radius:16px;padding:12px 22px;box-shadow:var(--shadow)}.seal-label{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--ink-soft)}.seal-code{font-family:var(--serif);font-size:40px;font-weight:700;letter-spacing:6px;color:var(--gold);line-height:1.1}.lobby-main h2{font-family:var(--serif);margin:0 0 2px;font-size:24px}.players{display:grid;gap:10px;margin-top:10px}.player-card{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 14px}.player-card.me{border-color:var(--gold);box-shadow:0 0 0 2px #d9a94340 inset}.player-card.empty{justify-content:center;color:var(--ink-soft);font-style:italic;border-style:dashed;gap:10px}.player-card.empty .banner-chip{opacity:.6}.pc-body{flex:1;min-width:0}.pc-name{font-weight:700}.pc-name .you{font-size:11px;background:var(--gold);color:#2a1c06;padding:1px 6px;border-radius:10px}.pc-title{font-size:13px;color:var(--ink-soft)}.pc-ready{font-size:13px;font-weight:700;color:var(--ink-soft)}.pc-ready.on{color:var(--ok)}.lobby-controls{display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.ctl{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.ctl-label{font-weight:700;font-size:13px;min-width:56px}.density{font-size:12px;color:var(--ink-soft)}.seg{display:inline-flex;border:1px solid var(--line-dark);border-radius:8px;overflow:hidden}.seg-btn{font:inherit;border:none;background:#f7eed7;padding:7px 14px;cursor:pointer;border-left:1px solid var(--line);text-transform:capitalize}.seg-btn:first-child{border-left:none}.seg-btn.on{background:var(--gold-2);color:#2a1c06;font-weight:700}.seg-btn:disabled{opacity:.4;cursor:not-allowed}.actions{justify-content:flex-end}body[data-board]{transition:background .5s ease;background:linear-gradient(#0b1d30d1,#0b1d30e6),url(/login-bg.jpg) center / cover fixed no-repeat var(--table-2)}.game{max-width:1400px;width:100%;flex:1;min-height:0;gap:10px;padding:12px 18px 14px;background:transparent}.hud{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.hud-card{display:flex;align-items:center;gap:10px;overflow:hidden;background:linear-gradient(180deg,#ffffff29,#0000002e),linear-gradient(180deg,var(--c),color-mix(in srgb,var(--c) 62%,#000));border:1px solid var(--gold);border-radius:10px;padding:8px 14px;color:#fff;box-shadow:0 6px 18px #00000059}.hud-card.me{border-color:var(--gold-2);box-shadow:inset 0 0 0 2px var(--table-2),inset 0 0 0 3px var(--gold-2),0 6px 18px #00000059}.hud-card.off{opacity:.5}.hud-card.dead{filter:grayscale(.85);opacity:.6}.hud-card{position:relative}.hud-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.55}.hud-card.pat-stripes:before{background-image:linear-gradient(0deg,transparent 35%,rgba(255,255,255,.22) 35% 50%,transparent 50% 85%,rgba(255,255,255,.22) 85%);background-size:100% 16px}.hud-card.pat-dots:before{background-image:radial-gradient(circle at 4px 4px,rgba(255,255,255,.26) 0 2px,transparent 2.2px);background-size:12px 12px}.hud-card.pat-grid:before{background-image:linear-gradient(rgba(255,255,255,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.18) 1px,transparent 1px);background-size:10px 10px}.hud-card.pat-diag:before{background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.2) 0 2px,transparent 2px 10px)}.hud-card.pat-rings:before{background-image:radial-gradient(circle,transparent 0 5px,rgba(255,255,255,.22) 5px 6.5px,transparent 7px);background-size:16px 16px}.hud-card.pat-cross:before{background-image:linear-gradient(rgba(255,255,255,.22) 2px,transparent 2px),linear-gradient(90deg,rgba(255,255,255,.22) 2px,transparent 2px);background-size:14px 14px;background-position:6px 6px}.hud-card.pat-weave:before{background-image:linear-gradient(rgba(255,255,255,.13) 2px,transparent 2px),linear-gradient(90deg,rgba(255,255,255,.13) 2px,transparent 2px);background-size:8px 8px}.hud-card>*{position:relative}.hud-shield{flex:none;display:grid;place-items:center;width:30px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.4))}.hud-chip{width:26px;height:33px}.hud-shield.attacking{color:var(--gold-2);animation:swordPulse 1s ease infinite alternate}@keyframes swordPulse{0%{transform:scale(1)}to{transform:scale(1.25)}}.hud-id{flex:1;min-width:0}.hud-name{font-weight:700;font-size:16px;display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.5)}.hud-name .tag{font-style:normal;font-size:10px;font-family:var(--sans);background:var(--gold);color:#241a0c;padding:1px 5px;border-radius:8px}.hud-sub{font-size:12px;color:#ffffffd0;white-space:nowrap;display:flex;align-items:center;gap:5px}.hud-sub .fallen{color:#ffd7d0;display:inline-flex;align-items:center;gap:4px}.hud-score{font-family:var(--display);font-size:30px;font-weight:700;line-height:1;text-shadow:0 2px 3px rgba(0,0,0,.55)}.tower-marker{display:inline-flex;align-items:end;gap:3px;height:15px}.tower-marker .tower{width:7px;border-radius:2px 2px 1px 1px;border:1px solid #7d5a1d;background:var(--gold-2)}.tower-marker .tower:nth-child(1),.tower-marker .tower:nth-child(3){height:10px}.tower-marker .tower:nth-child(2){height:14px}.tower-marker .tower.off{background:#000;opacity:.4;border-color:#fffdf6}.board-stage{position:relative;display:flex;flex-direction:column;gap:10px;flex:1;min-height:0}.pb-slot{flex:none;position:relative}.map-slot{position:relative;flex:1;min-height:0;display:grid;place-items:center;background:transparent;padding:0}.map-slot svg{position:absolute;top:12px;left:12px;width:calc(100% - 24px);height:calc(100% - 24px);display:block;filter:drop-shadow(0 5px 9px rgba(0,0,0,.32))}#map path{transition:fill .3s,stroke .2s,filter .2s,fill-opacity .2s}#map #mo{fill:none;stroke:#5f4a28;stroke-width:3;opacity:.5;pointer-events:none;stroke-linejoin:round}.hl-expand{animation:hlGold 1.1s ease-in-out infinite alternate}.hl-attack{animation:hlRed 1.1s ease-in-out infinite alternate}.hl:hover{filter:brightness(1.14)!important}@keyframes hlGold{0%{stroke:#ffd24a;stroke-width:2.5}to{stroke:#ffe9a0;stroke-width:4.5}}@keyframes hlRed{0%{stroke:#ff5a4e;stroke-width:2.5}to{stroke:#ff8d84;stroke-width:4.5}}.map-pill{fill:var(--panel);opacity:.96;stroke:var(--line-dark);stroke-width:.9;pointer-events:none}.map-pill-text{font-family:var(--sans);font-size:10.5px;font-weight:700;text-anchor:middle;pointer-events:none;fill:var(--ink)!important}.map-tower{fill:#00000052;stroke:#fffdf6;stroke-width:1;pointer-events:none}.map-tower.on{fill:var(--gold-2);stroke:#7d5a1d}.pat-mark{fill:#ffffff29}.pat-line{fill:none;stroke:#ffffff29;stroke-width:2.5}.pat-thin{fill:none;stroke:#ffffff1a;stroke-width:1.6}.pat-ring{fill:none;stroke:#ffffff29;stroke-width:1.6}.map-name{font-family:var(--serif);font-style:italic;font-size:10px;fill:#5c4a2e;opacity:.72;text-anchor:middle;pointer-events:none}.map-name.owned{fill:#fff;opacity:.85}.phase-banner{position:relative;background:linear-gradient(180deg,#1c3d5e,#0b1d30);border:2px solid var(--gold);border-radius:12px;padding:10px 56px;text-align:center;box-shadow:inset 0 0 0 3px var(--table-2),inset 0 0 0 4px var(--table-line),0 8px 20px #0006;animation:bannerPop .35s ease both}.pb-title{display:block;font-family:var(--display);font-weight:700;font-size:18px;color:var(--gold-2);letter-spacing:1.5px;text-transform:uppercase}.pb-sub{display:block;font-size:13px;color:var(--parch-on-dark);font-style:italic;margin-top:2px}.ticker{margin-top:8px;padding:0 56px;text-align:center;font-size:13px;font-style:italic;color:var(--parch-on-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;animation:tickerIn .35s ease both}.ticker:before,.ticker:after{content:"—✦—";color:var(--gold-2);margin:0 10px;font-style:normal}@keyframes tickerIn{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:none}}.log-fab{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;cursor:pointer;display:grid;place-items:center;font-size:19px;line-height:1;background:linear-gradient(180deg,#24507c,#16334f);border:1.5px solid var(--gold);box-shadow:0 4px 12px #0006;transition:filter .15s,box-shadow .15s}.log-fab:hover{filter:brightness(1.18);box-shadow:0 4px 16px #00000080,0 0 10px #d9a94355}.log-fab .icon{width:20px;height:20px;color:var(--gold-2);vertical-align:0}.log-drawer{position:fixed;top:12px;right:12px;bottom:12px;z-index:35;width:min(340px,88vw);display:flex;flex-direction:column;background:linear-gradient(180deg,#1e4a75,#122c48);border:1px solid #3f6f9e;border-radius:14px;box-shadow:0 24px 60px #0000008c;transform:translate(calc(100% + 24px));transition:transform .28s cubic-bezier(.2,.8,.2,1)}.log-drawer.open{transform:none}.ld-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #ffffff1a;font-family:var(--display);font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-2)}.ld-close{border:none;background:transparent;color:#a9c4dd;font:inherit;font-size:15px;cursor:pointer;padding:4px 8px;border-radius:6px}.ld-close:hover{color:#fff;background:#ffffff14}.ld-body{flex:1;overflow:auto;padding:6px 16px 14px}.ld-body .ev{font-size:14px;padding:7px 0;border-bottom:1px dashed #2e5a86;color:#a9c4dd}.ld-body .ev:first-child{color:#eef5fc}.ld-body:empty:after{content:"Nothing has happened yet…";display:block;padding:14px 0;color:#7796b3;font-style:italic}.ab-slot{position:absolute;left:12px;right:12px;bottom:12px;pointer-events:none}.action-bar{pointer-events:auto;display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,#1c3d5ef7,#091828f7);border:2px solid var(--gold);border-radius:12px;padding:10px 14px;box-shadow:inset 0 0 0 3px var(--table-2),inset 0 0 0 4px var(--table-line),0 10px 30px #00000080;animation:bannerPop .3s ease both}.action-bar.locked{border-color:var(--table-line);box-shadow:0 10px 30px #00000080}.ab-hint{flex:1}.ab-hint b{display:block;font-family:var(--display);color:var(--gold-2);font-size:15px;letter-spacing:1px;text-transform:uppercase}.ab-hint span{font-size:13px;color:var(--parch-on-dark)}.ab-btns{display:flex;align-items:center;gap:10px}.btn-stone{font-family:var(--sans);font-weight:600;cursor:pointer;padding:10px 16px;border-radius:9px;color:#eaf2fa;background:linear-gradient(180deg,#2e5a86,#1c3d5e);border:1px solid #3f6f9e}.btn-stone:hover{filter:brightness(1.12)}.btn-stone.ghost{background:transparent}.ring{position:relative;width:56px;height:56px;flex:none}.ring svg{width:100%;height:100%;transform:rotate(-90deg)}.ring-bg{fill:none;stroke:#0000004d;stroke-width:6}.ring-fg{fill:none;stroke:var(--gold-2);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .25s linear}.ring-num{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;font-weight:700;color:var(--gold-2);font-size:18px}.ring.danger .ring-fg{stroke:var(--danger)}.ring.danger .ring-num{color:#ff8d84;animation:swordPulse .5s ease infinite alternate}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:20px;background:radial-gradient(80% 80% at 50% 40%,#091828d9,#030a12f2);animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.q-card{position:relative;width:min(720px,100%);background:var(--panel);border:1px solid var(--line-dark);border-radius:14px;padding:34px 28px 26px;box-shadow:inset 0 0 0 5px var(--panel),inset 0 0 0 6px var(--line-dark),0 30px 70px #0000008c;color:var(--ink);animation:cardRise .35s cubic-bezier(.2,.8,.2,1) both}@keyframes cardRise{0%{transform:translateY(14px) scale(.97);opacity:0}to{transform:none;opacity:1}}.q-head{display:flex;align-items:flex-start;justify-content:center;margin-bottom:14px;position:relative}.q-head .ring{position:absolute;right:0;top:0}.q-head .ring-fg{stroke:var(--table-panel)}.q-head .ring-bg{stroke:#00000026}.q-head .ring-num{color:var(--table-panel)}.q-cat{font-family:var(--display);font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--ink);background:linear-gradient(180deg,var(--gold-2),var(--gold));padding:6px 22px;border-radius:8px;border:1px solid #8a6420;box-shadow:0 4px 10px #00000040}.q-text{font-family:var(--serif);font-size:24px;font-weight:600;line-height:1.3;margin:6px 0 18px;color:var(--ink);text-align:center}.q-tiles{display:grid;grid-template-columns:1fr 1fr;gap:12px}.q-tile{display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;background:#fbf3df;border:1px solid var(--line);border-radius:10px;padding:14px 16px;font:inherit;color:var(--ink);transition:transform .08s,background .15s,border-color .15s}.q-tile:hover:not(:disabled){background:#f3e4bc;border-color:var(--gold-2);transform:translateY(-2px)}.q-tile:active{transform:translateY(0)}.q-tile.spectate{cursor:default;opacity:.85}.q-letter{display:grid;place-items:center;width:34px;height:34px;flex:none;border-radius:50%;font-family:var(--display);font-weight:700;color:var(--parch-on-dark);background:var(--table-panel);border:1px solid #0003}.q-choice{font-size:17px;flex:1;font-family:var(--serif)}.q-est{display:flex;align-items:center;gap:10px;margin:4px 0 14px}.q-est input{flex:1;font-size:22px;text-align:center;padding:14px;border-radius:12px;border:1px solid var(--line-dark);background:#fff8ea;color:var(--ink);font-family:var(--display)}.q-est input:focus-visible{outline:3px solid var(--gold-2);outline-offset:1px}.q-unit{font-size:18px;color:var(--ink-soft);font-weight:600;font-family:var(--serif)}.btn-gold{width:100%;font-family:var(--display);font-weight:700;letter-spacing:.5px;cursor:pointer;padding:14px;border-radius:12px;color:#2a1c06;background:linear-gradient(180deg,var(--gold-2),var(--gold));border:1px solid #8a6420;font-size:16px}.btn-gold:hover{filter:brightness(1.06)}.wait-sub{color:var(--ink-soft);font-size:16px}.wait-sub.center{text-align:center;margin:-6px 0 0;font-family:var(--serif)}.wait-sub b{font-family:var(--display);color:var(--gold);font-size:18px}.q-card .wait-sub.center:first-of-type{font-style:italic;font-size:14px}.q-card .wait-sub.center:first-of-type:before{content:"✎ "}.vs-strip{text-align:center;margin-bottom:10px}.vs-title{font-family:var(--display);font-size:14px;letter-spacing:1px;color:var(--gold);margin-bottom:6px}.vs-chips{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}.vs-chip{background:var(--c);color:#fff;font-weight:700;padding:4px 14px;border-radius:20px;border:2px solid color-mix(in srgb,var(--c) 55%,#fff);text-shadow:0 1px 2px rgba(0,0,0,.5)}.vs-x{line-height:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.q-tile.reveal{cursor:default}.q-tile.reveal.good{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-color:#8a6420;color:var(--ink);box-shadow:0 4px 14px #b8862f66}.q-tile.reveal.good .q-letter{background:var(--ink);color:var(--gold-2)}.q-tile.reveal.bad{background:#ecdcd4;border-color:var(--danger);color:var(--ink)}.q-picks{display:flex;gap:4px}.pick-chip{display:inline-grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--c);color:#fff;font-weight:700;font-size:13px;border:2px solid #fff;box-shadow:0 1px 3px #0006}.est-answer{font-family:var(--display);font-size:42px;font-weight:700;text-align:center;color:var(--gold);margin:8px 0 14px}.est-answer span{font-size:20px;color:var(--ink-soft)}.est-guesses{display:flex;justify-content:center;gap:22px;flex-wrap:wrap}.est-guess{display:flex;align-items:center;gap:8px;font-size:20px;font-family:var(--display);color:var(--ink)}.results{align-items:center;text-align:center;gap:8px;justify-content:center}.standings{width:100%;max-width:480px;display:flex;flex-direction:column;gap:8px;margin:14px 0}.standing{display:grid;grid-template-columns:40px 16px 1fr auto auto;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 16px;text-align:left}.standing.win{border-color:var(--gold);box-shadow:var(--shadow);animation:bannerPop .4s ease both}.standing .rank{font-size:18px;font-weight:700}.medal{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:50%;font-family:var(--display);font-size:15px;border:2px solid #0002;color:#2a1c06}.medal.m1{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-color:#8a6420}.medal.m2{background:linear-gradient(180deg,#ded0ac,var(--line));border-color:#a08a5f}.medal.m3{background:linear-gradient(180deg,#c69a48,var(--gold));border-color:#8a6420;opacity:.85}.medal.m4{background:#efe5cd;border-color:var(--line);color:var(--ink-soft)}.standing .dot{width:16px;height:21px}.standing .nm{font-weight:600}.standing .brk{font-size:12px;color:var(--ink-soft)}.standing .total{font-size:24px;font-weight:700;color:var(--gold)}.result-actions{display:flex;gap:10px;justify-content:center}@keyframes bannerPop{0%{transform:translateY(-6px) scale(.98);opacity:0}to{transform:none;opacity:1}}button:focus-visible,input:focus-visible,.seg-btn:focus-visible,.q-tile:focus-visible,.log-fab:focus-visible,.ld-close:focus-visible{outline:3px solid var(--gold-2);outline-offset:2px}@media (max-width: 820px){.board{grid-template-columns:1fr}.board-side{order:-1}.q-tiles{grid-template-columns:1fr}.q-text{font-size:20px}.screen{padding:14px 12px 28px}.game{padding:10px 10px 12px}.standing{grid-template-columns:30px 14px 1fr auto}.standing .brk{display:none}.phase-banner{padding:8px 48px}.ticker{padding:0 48px}.log-fab{width:38px;height:38px;font-size:17px}.log-drawer{top:8px;right:8px;bottom:8px}.map-slot svg{top:8px;left:8px;width:calc(100% - 16px);height:calc(100% - 16px)}.hud{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.hud-card{padding:6px 10px;gap:8px}.hud-score{font-size:24px}.hud-shield{font-size:20px}}@media (prefers-reduced-motion: reduce){*,.phase-banner,.action-bar,.q-card,.overlay,.standing.win{animation:none!important;transition:none!important}.ring-fg{transition:none!important}}.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,16px);display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:8px;box-shadow:var(--shadow);opacity:0;transition:opacity .25s,transform .25s;z-index:50;max-width:90vw}.toast.dark{background:var(--ink);border:1px solid var(--gold);color:#f4ead2}.toast.light{background:var(--panel);border:2px solid var(--ink);color:var(--ink)}.toast .dot{width:16px;height:16px;border-radius:50%;background:var(--gold-2);border:2px solid var(--ink);flex:none}.toast.show{opacity:1;transform:translate(-50%)}.toast.click{cursor:pointer}.presence{width:10px;height:10px;border-radius:50%;background:var(--ok, #3a9440);display:inline-block}.presence.off{background:var(--ink-soft, #888)}@media (min-width: 620px){.lobby{display:grid;grid-template-columns:1fr}.actions{gap:10px}}.setup-card{max-width:440px;gap:14px}.label-row{font-weight:700;font-size:13px;color:var(--ink-soft);text-align:left}.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.avatar-choice{min-height:68px;border:2px solid var(--line);border-radius:14px;background:#fff8ea;cursor:pointer;display:grid;place-items:center}.avatar-choice.selected{border-color:var(--ink);box-shadow:0 0 0 3px var(--gold-2)}.swatch-row{display:flex;gap:10px;flex-wrap:wrap}.swatch{width:40px;height:40px;border-radius:12px;border:3px solid #0003;cursor:pointer}.swatch.selected{border-color:var(--ink);box-shadow:0 0 0 3px var(--gold-2)}.err{color:var(--danger);font-size:14px;min-height:18px;text-align:left}.me-row{display:flex;align-items:center;gap:10px;justify-content:center}#signin{display:grid}.conn-banner{position:fixed;top:12px;left:50%;transform:translate(-50%);z-index:60;display:flex;align-items:center;gap:8px;background:var(--ink);color:#f4ead2;border:1px solid var(--gold);border-radius:10px;padding:8px 14px;box-shadow:var(--shadow)}body[data-reduced-motion] *,body[data-reduced-motion] *:before,body[data-reduced-motion] *:after{animation:none!important;transition:none!important}.landing{align-items:center;text-align:center;justify-content:center;gap:8px}.steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;max-width:640px;margin:12px 0}.step-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px;font-size:14px;display:grid;gap:4px}.eyebrow{font-family:var(--display);font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}.hub-head h2,.profile-page h2,.settings-page h2{font-family:var(--display);margin:4px 0 14px}.hub-head{text-align:center;margin-bottom:6px}.hub-head .eyebrow{display:block;margin-bottom:6px}.hub-head h2{color:var(--parch-on-dark);font-size:clamp(26px,4vw,36px);letter-spacing:.5px;position:relative;display:inline-block;padding-bottom:14px}.hub-head h2:after{content:"";position:absolute;left:50%;bottom:0;transform:translate(-50%);width:140px;height:3px;background:linear-gradient(90deg,transparent,var(--gold-2),transparent)}.play-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:14px}.play-card{background:var(--panel);border:2px solid var(--line-dark);border-radius:18px;padding:18px;display:grid;gap:8px;align-content:start;box-shadow:var(--shadow)}.play-card.primary{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-color:#8a6420}.play-card.disabled{opacity:.6}.play-card.searching{animation:qm-pulse 1.6s ease-in-out infinite}@keyframes qm-pulse{0%,to{opacity:1}50%{opacity:.7}}.play-card h3{margin:0;font-family:var(--display);display:flex;align-items:center;gap:8px}.play-medal{width:44px;height:44px;margin:0 auto 4px;display:grid;place-items:center;border-radius:50%;border:2px solid var(--gold);box-shadow:0 3px 8px #0000004d}.play-medal .icon{width:22px;height:22px;color:#f3ead4}.play-medal.join{background:linear-gradient(180deg,#2e5a86,#16334f)}.play-medal.quick{background:linear-gradient(180deg,#5a8a49,#35502b)}.play-card.primary .play-medal{background:linear-gradient(180deg,#d9a943,#8a6420);border-color:#6b4d18}.play-card.primary .play-medal .icon,.play-card.primary h3,.play-card.primary p{color:#2a1c06}.play-card .btn.navy{font-family:var(--display);letter-spacing:.5px;color:#eaf2fa;text-align:center;background:linear-gradient(180deg,#2e5a86,#16334f);border:1px solid var(--gold-2)}.play-card .btn.navy:hover{filter:brightness(1.12)}.play-card .btn.green{font-family:var(--display);letter-spacing:.5px;color:#eaf2fa;text-align:center;background:linear-gradient(180deg,#5a8a49,#35502b);border:1px solid var(--gold-2)}.play-card .btn.green:hover{filter:brightness(1.12)}.play-card.primary .btn.primary{font-family:var(--display);letter-spacing:.5px;border:1px solid #6b4d18;box-shadow:inset 0 0 0 1px #ffffff59}.profile-head{display:flex;gap:14px;align-items:center;margin-bottom:14px}.set-row{display:flex;align-items:center;justify-content:space-between;gap:12px}@media (max-width: 860px){.play-grid,.steps-row{grid-template-columns:1fr}}.shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;width:100%;background:linear-gradient(#0b1d30cc,#0b1d30e0),url(/login-bg.jpg) center / cover fixed no-repeat var(--table-2)}.shell-side{margin:18px 0 18px 18px;padding:20px 16px;background:var(--panel);border-radius:10px;box-shadow:inset 0 0 0 4px var(--panel),inset 0 0 0 5px var(--line-dark),var(--shadow);display:flex;flex-direction:column;gap:14px;position:relative}.shell-side:after{content:"❦";text-align:center;color:var(--gold);font-size:16px;opacity:.8;margin-top:auto;padding-top:10px}.shell-brand{display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--display);font-weight:700;font-size:18px;padding-bottom:10px;border-bottom:1px solid var(--line)}.player-mini{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--line-dark);border-radius:12px;background:#fff8ea;box-shadow:inset 0 0 0 2px var(--panel)}.pm-id{display:grid;line-height:1.25;min-width:0}.pm-id b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.small{font-size:12px}.shell-nav{display:grid;gap:0}.nav-item{display:flex;align-items:center;gap:10px;min-height:44px;border:0;border-top:1px solid var(--line);background:transparent;border-radius:0;padding:10px 12px;font:700 15px var(--display);color:var(--ink);cursor:pointer;text-align:left}.nav-item:first-child{border-top:0}.nav-item:hover{background:#b8862f1f}.nav-item.active{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-top-color:transparent;border-radius:10px;color:#2a1c06;box-shadow:0 2px 6px #00000040,inset 0 0 0 1px #8a6420}.nav-item.active+.nav-item{border-top-color:transparent}.shell-main{padding:28px;min-width:0}.shell-main h2{color:var(--parch-on-dark);font-family:var(--display)}.shell-main .muted,.shell-main .empty-state{color:#a9c4dd}.page-pad{padding:24px}.shell-mobile{display:none}@media (max-width: 860px){.shell{grid-template-columns:1fr}.shell-side{display:none}.shell-main{padding:14px 12px 76px}.shell-mobile{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;position:fixed;left:0;right:0;bottom:0;background:var(--panel);border-top:2px solid var(--gold);box-shadow:inset 0 0 0 4px var(--panel),inset 0 3px 0 var(--line-dark);padding:6px;z-index:30}.mob-item{display:grid;place-items:center;gap:2px;border:0;background:transparent;min-height:48px;font:700 11px var(--display);color:var(--ink);border-radius:10px}.mob-item.active{color:#2a1c06;background:linear-gradient(180deg,var(--gold-2),var(--gold))}}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}.stat{padding:14px;border:1px solid var(--line);border-radius:14px;background:var(--panel);display:grid;gap:2px}.kpi{font-family:var(--display);font-size:30px;font-weight:700}.ledger{width:100%;border-collapse:separate;border-spacing:0 6px}.ledger th{font:700 12px var(--display);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-align:left;padding:0 10px}.ledger td{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px}.ledger td:first-child{border-left:1px solid var(--line);border-radius:12px 0 0 12px}.ledger td:last-child{border-right:1px solid var(--line);border-radius:0 12px 12px 0}.rank-pin{position:sticky;bottom:0;background:linear-gradient(180deg,var(--gold-2),var(--gold));border:2px solid var(--ink);border-radius:14px;padding:12px;font-weight:700}.skeleton{background:linear-gradient(90deg,var(--paper-2),var(--panel),var(--paper-2));background-size:240% 100%;animation:shimmer 1.4s linear infinite;border-radius:12px}.skeleton.block{height:92px}@keyframes shimmer{to{background-position:-240% 0}}@media (max-width: 860px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.badge-card{background:var(--panel);border:2px solid var(--line-dark);border-radius:18px;padding:16px;display:grid;gap:6px;justify-items:center;text-align:center}.badge-card.locked{filter:grayscale(1);opacity:.55}.badge-medal{width:48px;height:48px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(180deg,var(--gold-2),var(--gold));border:2px solid #8a6420}.badge-medal .icon{width:26px;height:26px}.progress{width:100%;height:8px;border-radius:999px;background:var(--paper-2);border:1px solid var(--line);overflow:hidden}.progress span{display:block;height:100%;background:linear-gradient(90deg,var(--gold-2),var(--gold));border-radius:999px}.friends-section{margin:18px 0}.friends-section h3{font-family:var(--display);margin:0 0 8px;font-size:16px}.friends-section>div{display:flex;flex-direction:column;gap:8px}.search-rows{display:flex;flex-direction:column;gap:8px;margin-top:10px}.friend-row{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 12px}.friend-row .fr-name{flex:1;min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-row .btn{flex:none}.empty-state{color:var(--ink-soft);font-style:italic;padding:20px 8px;text-align:center}.landing-art{max-width:none;margin:0;min-height:100vh;background:url(/login-bg.jpg) center / cover no-repeat var(--table-2);justify-content:center;align-items:flex-start;padding:5vh 6vw}.signin-panel{width:min(400px,100%);background:var(--panel);border:1px solid var(--line-dark);border-radius:8px;box-shadow:inset 0 0 0 5px var(--panel),inset 0 0 0 6px var(--line-dark),var(--shadow);padding:30px 26px 22px;display:flex;flex-direction:column;gap:10px;text-align:center}.signin-panel .crest{margin:0 auto}.signin-panel .eyebrow{margin:0}.signin-title{font-family:var(--display);font-size:34px;margin:0 0 6px;letter-spacing:1px}.signin-title:before{content:"— ";color:var(--gold)}.signin-title:after{content:" —";color:var(--gold)}.signin-card{display:flex;flex-direction:column;gap:12px}.signin-card label{display:grid;gap:4px;text-align:left;font-weight:700;font-size:13px;color:var(--ink-soft)}.signin-card input{font:inherit;width:100%;padding:11px 12px;border:1px solid var(--line-dark);border-radius:8px;background:#fff8ea;color:var(--ink)}.signin-card input:focus{outline:2px solid var(--gold-2);outline-offset:1px}.signin-hint{color:var(--ink-soft);font-size:13px;margin:0}.setup-panel{width:min(480px,100%)}.setup-title{font-size:30px}.setup-panel .swatch-row{justify-content:center}.order-strip{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:8px}.os-sep{color:var(--gold);opacity:.75;line-height:0}.os-pill{display:inline-flex;align-items:center;gap:7px;padding:4px 12px 4px 6px;border-radius:999px;color:#fff;border:1px solid var(--gold);font-size:14px;background:linear-gradient(180deg,#ffffff2e,#00000038),var(--c);box-shadow:0 3px 8px #00000059}.os-pill .os-n{font-family:var(--display);font-size:11px;background:#00000059;border-radius:999px;width:18px;height:18px;display:grid;place-items:center;flex:none}.os-pill.active{box-shadow:0 0 0 2px var(--table-2),0 0 0 4px var(--gold-2),0 3px 8px #00000073}.os-pill.dead{filter:grayscale(.9);opacity:.55}.os-chip{width:18px;height:23px;flex:none}.os-name{font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5);max-width:12ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lobby-table{max-width:none;margin:0;width:100%;min-height:100vh;background:linear-gradient(#0b1d30c7,#0b1d30db),url(/login-bg.jpg) center / cover no-repeat var(--table-2);padding:28px clamp(14px,5vw,48px) 48px}.lobby-table>*{width:100%;max-width:820px;margin-left:auto;margin-right:auto}.lobby-table .seal{width:min(560px,100%);padding:16px 26px 18px;border:2px solid var(--gold);border-radius:14px;box-shadow:inset 0 0 0 4px var(--panel),inset 0 0 0 5px var(--line-dark),var(--shadow)}.lobby-table .seal-label{color:var(--gold)}.lobby-table .seal-code{font-family:var(--display);font-size:52px;letter-spacing:10px;color:var(--ink)}.lobby-table .lobby-main h2{font-family:var(--display);font-size:28px;color:var(--parch-on-dark)}.lobby-table .lobby-main .muted{color:#a9c4dd}.lobby-table .lobby-main .muted b{color:var(--gold-2)}.lobby-table .player-card{border:1px solid var(--gold);border-radius:8px;padding:12px 16px;box-shadow:inset 0 0 0 3px var(--panel),inset 0 0 0 4px var(--line),var(--shadow)}.lobby-table .player-card.empty{border-style:solid}.lobby-table .lobby-controls{border:2px solid var(--gold);border-radius:12px;padding:20px;gap:14px;box-shadow:inset 0 0 0 4px var(--panel),inset 0 0 0 5px var(--line-dark),var(--shadow)}.lobby-table .actions .btn.primary{font-family:var(--display);letter-spacing:.5px}.landing-art .credits{margin-top:8px}@media (max-width: 899px){.landing-art{align-items:center;padding:24px 14px}}
