: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}button,input,select{touch-action:manipulation}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{width:24px;height:31px;flex:none}.banner-chip{width:28px;height:28px;flex:none}.avatar-medal{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex:none;background:radial-gradient(circle at 35% 30%,color-mix(in srgb,var(--c) 60%,#fff) 0%,var(--c) 52%,color-mix(in srgb,var(--c) 55%,#000) 100%);border:2px solid #8a6420;box-shadow:inset 0 0 0 1px #d9a943a6,inset 0 2px 6px #00000059,0 2px 5px #0000004d}.avatar-medal img{width:86%;height:86%;display:block;object-fit:contain;filter:drop-shadow(0 1px 2px rgba(0,0,0,.45))}.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;min-width:0}.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;animation:cardIn .2s ease both}@keyframes cardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.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-name .you.bot{background:var(--ink-soft);color:#fff}.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);animation:readyPop .3s ease}.pc-remove{background:none;border:1px solid var(--line);border-radius:8px;color:var(--ink-soft);width:26px;height:26px;font-size:13px;line-height:1;cursor:pointer}.pc-remove:hover{color:var(--danger);border-color:currentColor}@keyframes readyPop{0%{transform:scale(1)}50%{transform:scale(1.25)}to{transform:scale(1)}}.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:hover:not(:disabled):not(.on){background:#fff3da}.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(#19100859,#1910088c),url(/board-table.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,#f3ead4,#e0ca97);border:1px solid var(--gold);box-shadow:inset 0 0 0 1px var(--line),var(--shadow);border-radius:10px;padding:8px 14px 8px 12px;color:var(--ink)}.hud-card.me{border-color:var(--gold-2);box-shadow:inset 0 0 0 1px var(--line),inset 0 0 0 2px var(--gold-2),var(--shadow)}.hud-card.off{opacity:.5}.hud-card.dead{filter:grayscale(.85);opacity:.6}.hud-card{position:relative;border-left:10px solid var(--c)}.hud-card:before{content:"";position:absolute;top:0;bottom:0;left:-10px;width:10px;pointer-events:none;opacity:.7}.hud-card.pat-stripes:before{background-image:linear-gradient(0deg,transparent 35%,rgba(255,255,255,.35) 35% 50%,transparent 50% 85%,rgba(255,255,255,.35) 85%);background-size:100% 16px}.hud-card.pat-dots:before{background-image:radial-gradient(circle at 4px 4px,rgba(255,255,255,.4) 0 2px,transparent 2.2px);background-size:12px 12px}.hud-card.pat-grid:before{background-image:linear-gradient(rgba(255,255,255,.3) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.3) 1px,transparent 1px);background-size:10px 10px}.hud-card.pat-diag:before{background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.32) 0 2px,transparent 2px 10px)}.hud-card.pat-rings:before{background-image:radial-gradient(circle,transparent 0 5px,rgba(255,255,255,.35) 5px 6.5px,transparent 7px);background-size:16px 16px}.hud-card.pat-cross:before{background-image:linear-gradient(rgba(255,255,255,.35) 2px,transparent 2px),linear-gradient(90deg,rgba(255,255,255,.35) 2px,transparent 2px);background-size:14px 14px;background-position:6px 6px}.hud-card.pat-weave: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:8px 8px}.hud-card>*{position:relative}.hud-rank{width:22px;height:22px;font-size:12px;flex:none}.hud-rank .icon{width:13px;height:13px;vertical-align:-2px}.hud-shield{flex:none;display:grid;place-items:center;width:30px;filter:drop-shadow(0 2px 2px rgba(0,0,0,.3))}.hud-chip{width:30px;height:30px}.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;color:var(--ink);display:flex;align-items:center;gap:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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:var(--ink-soft);white-space:nowrap;display:flex;align-items:center;gap:5px}.hud-sub .fallen{color:var(--danger);display:inline-flex;align-items:center;gap:4px}.hud-score{font-family:var(--display);font-size:30px;font-weight:700;line-height:1;color:var(--ink);font-variant-numeric:tabular-nums}.hud-score.bump{animation:scoreBump .5s ease}@keyframes scoreBump{40%{transform:scale(1.25)}}.score-flyer{position:fixed;z-index:55;transform:translate(-50%);font-family:var(--display);font-weight:800;font-size:18px;pointer-events:none;white-space:nowrap;text-shadow:0 1px 0 rgba(47,36,23,.4);animation:scoreFlyerRise 1.1s ease-out both}.score-flyer.positive{color:var(--gold-2)}.score-flyer.negative{color:var(--danger)}@keyframes scoreFlyerRise{0%{opacity:0;transform:translate(-50%,6px) scale(.9)}15%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%,-28px) scale(1)}}.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:#2f241740;opacity:1;border-color:var(--line-dark)}.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;border:1px solid var(--gold);border-radius:14px;box-shadow:inset 0 0 0 1px var(--line)}.map-slot:after{content:"";position:absolute;right:10px;bottom:10px;width:140px;height:140px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64' fill='none' stroke='%23b8862f'><circle cx='32' cy='32' r='30' stroke-width='1'/><circle cx='32' cy='32' r='26' stroke-width='.5'/><path d='M32 2v60M2 32h60' stroke-width='.5' opacity='.6'/><path d='M13 13l38 38M51 13L13 51' stroke-width='.5' opacity='.5'/><path d='M32 6l4 22 22 4-22 4-4 22-4-22-22-4 22-4z' stroke-width='1.2' fill='%23b8862f' fill-opacity='.15'/></svg>") center / contain no-repeat;opacity:.45;pointer-events:none}@media (max-width: 640px){.map-slot:after{display:none}}.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}#bevel{pointer-events:none}.bevel-highlight,.bevel-shade{fill:none}.bevel-highlight{stroke:#fffcf0bf;stroke-width:3.5;transform:translateY(-1.1px)}.bevel-shade{stroke:#1f1408b3;stroke-width:4.5;transform:translateY(1.4px)}.hl-expand{animation:hlGold 1.1s ease-in-out infinite alternate}.hl-attack{animation:hlRed 1.1s ease-in-out infinite alternate}.hl-rebuild{animation:hlRebuild 1.4s 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}}@keyframes hlRebuild{0%{stroke:#d9a943;stroke-width:3}to{stroke:#ffe9a0;stroke-width:6}}.map-plaque{pointer-events:none}.plaque-base{fill:var(--panel);opacity:.97;stroke:var(--ink);stroke-width:1.1;stroke-linejoin:round}.plaque-gold-stroke{fill:none;stroke:var(--gold);stroke-width:.9;stroke-linejoin:round}.plaque-crown{fill:none;stroke:var(--gold);stroke-width:1.1;stroke-linecap:round;stroke-linejoin:round}.plaque-crenel{fill:var(--gold-2);stroke:var(--ink);stroke-width:.7;stroke-linejoin:round}.plaque-dot{fill:var(--gold);stroke:var(--ink);stroke-width:.4}.plaque-seal{fill:var(--danger);stroke:var(--ink);stroke-width:.7}.map-pill-text{font-family:var(--sans);font-size:10.5px;font-weight:700;text-anchor:middle;pointer-events:none;fill:var(--ink)!important}.tier-castle .map-pill-text,.tier-rich .map-pill-text{font-size:11px}.plaque-grow{animation:plaquePulse .5s ease}@keyframes plaquePulse{0%,to{transform:scale(1)}45%{transform:scale(1.25)}}.map-value-flyer{font-family:var(--sans);font-size:13px;font-weight:800;text-anchor:middle;fill:var(--gold-2);stroke:var(--ink);stroke-width:.6;paint-order:stroke;pointer-events:none}.map-tower{pointer-events:none;filter:drop-shadow(0 1px 1px rgba(0,0,0,.35))}.map-tower.off{filter:grayscale(1) brightness(.6);opacity:.38}.map-tower.tower-new{animation:towerPop .3s ease both;transform-box:fill-box;transform-origin:bottom center}@keyframes towerPop{0%{transform:scale(0)}to{transform:scale(1)}}.map-tower.tower-crumble{animation:towerCrumble .7s ease-in both;transform-origin:bottom center}@keyframes towerCrumble{0%{transform:rotate(0) translateY(0);opacity:1;filter:none}to{transform:rotate(20deg) translateY(6px);opacity:.38;filter:grayscale(1) brightness(.6)}}.map-flag{filter:drop-shadow(0 2px 3px rgba(0,0,0,.45)) drop-shadow(0 0 6px color-mix(in srgb,currentColor 70%,transparent))}.map-flag-plant{animation:flagPlant .35s cubic-bezier(.2,.8,.2,1) both;transform-box:fill-box;transform-origin:bottom center}@keyframes flagPlant{0%{transform:scale(.2,.1);opacity:0}60%{transform:scaleX(1.05);opacity:1}to{transform:scale(1);opacity:1}}.map-hatch{fill:url(#pat-hatch);opacity:.28;pointer-events:none}.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}.phase-banner{position:relative;background:linear-gradient(180deg,#1c3d5e,#0b1d30);border:2px solid var(--gold);border-radius:12px;padding:7px 52px;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:16px;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;overscroll-behavior:contain}.ld-body .ev{font-size:14px;padding:7px 0;border-bottom:1px dashed #2e5a86;color:#a9c4dd}.ld-body .ev:first-child{color:#eef5fc;animation:evIn .25s ease}@keyframes evIn{0%{opacity:0}to{opacity:1}}.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;display:flex;justify-content:center}.action-bar{pointer-events:auto;display:flex;align-items:center;gap:10px;width:fit-content;max-width:100%;background:linear-gradient(180deg,#1c3d5ef0,#091828f0);border:1.5px solid var(--gold);border-radius:999px;padding:6px 8px 6px 16px;box-shadow:inset 0 0 0 2px var(--table-2),0 6px 16px #0006;animation:bannerPop .3s ease both}.action-bar.locked{border-color:var(--table-line);box-shadow:0 6px 16px #0006;padding-right:16px}.ab-hint{display:flex;align-items:baseline;gap:6px;white-space:nowrap}.ab-hint b{font-family:var(--display);color:var(--gold-2);font-size:13px;letter-spacing:.5px;text-transform:uppercase}.ab-hint span{font-size:13px;color:var(--parch-on-dark)}.ab-btns{display:flex;align-items:center;gap:8px}.btn-stone{font-family:var(--sans);font-weight:600;cursor:pointer;padding:7px 12px;border-radius:999px;color:#eaf2fa;background:linear-gradient(180deg,#2e5a86,#1c3d5e);border:1px solid #3f6f9e;font-size:13px;white-space:nowrap}.btn-stone:hover{filter:brightness(1.12)}.btn-stone.ghost{background:transparent}.action-bar .ring{width:40px;height:40px}.action-bar .ring-num{font-size:14px}.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:flex;overflow-y:auto;overscroll-behavior:contain;padding:20px;background:radial-gradient(80% 80% at 50% 40%,#091828d9,#030a12f2);animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.conquest-old,.conquest-grow,#fx{pointer-events:none}.fx-ripple-group{transform-box:view-box}.fx-ripple{fill:none;stroke-width:3;animation:fxRipple 1.6s ease-out both}.fx-gold .fx-ripple{stroke:#ffd24a}.fx-red .fx-ripple{stroke:#ff5a4e}@keyframes fxRipple{0%{transform:scale(1);opacity:.9;stroke-width:3}to{transform:scale(2.2);opacity:0;stroke-width:.5}}.fx-region-pop{animation:fxRegionPop .5s ease both;transform-box:fill-box;transform-origin:center}@keyframes fxRegionPop{0%{transform:scale(1);fill-opacity:1}35%{transform:scale(1.06);fill-opacity:.55}to{transform:scale(1);fill-opacity:.9}}.fx-flash-red{animation:fxFlashRed 1.6s ease-out}.fx-flash-gold{animation:fxFlashGold 1.6s ease-out}@keyframes fxFlashRed{0%,55%{stroke:#ff5a4e;stroke-width:4.5}}@keyframes fxFlashGold{0%,55%{stroke:#ffd24a;stroke-width:4.5}}.capital-vignette{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;pointer-events:none;background:radial-gradient(120% 120% at 50% 50%,transparent 45%,rgba(162,59,44,.35) 100%);animation:capitalVignette .9s ease-out both}@keyframes capitalVignette{0%{opacity:0}25%{opacity:1}to{opacity:0}}.q-card{position:relative;width:min(720px,100%);margin:auto;background:url(/parchment.jpg) center / cover 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;text-wrap:balance}.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:#fffaeb8c;border:1px solid var(--line);border-left:3px solid var(--line-dark);border-radius:10px;padding:13px 16px;font:inherit;color:var(--ink);transition:transform .08s,background .15s,border-color .15s,box-shadow .15s}.q-tile:hover:not(:disabled){background:#fff4d6d9;border-color:var(--gold-2);border-left-color:var(--gold);transform:translateY(-2px);box-shadow:0 4px 10px #3c2c142e}.q-tile:active{transform:translateY(0)}.q-tile.spectate{cursor:default;opacity:.85}.q-tiles .q-tile{animation:tileIn .2s ease both}.q-tiles .q-tile:nth-child(1){animation-delay:0ms}.q-tiles .q-tile:nth-child(2){animation-delay:45ms}.q-tiles .q-tile:nth-child(3){animation-delay:90ms}.q-tiles .q-tile:nth-child(4){animation-delay:135ms}@keyframes tileIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.q-tile.picked{background:var(--gold-2);border-color:var(--gold);transform:scale(.98)}.q-letter{position:relative;display:grid;place-items:center;width:34px;height:34px;flex:none;border-radius:50%;font-family:var(--display);font-weight:700;color:#fff3e0;background:radial-gradient(circle at 35% 30%,#c4503f,#a23b2c 62%,#7c281c);box-shadow:inset 0 -2px 3px #00000059,inset 0 1px 2px #ffffff40,0 1px 3px #00000059;text-shadow:0 1px 1px rgba(0,0,0,.4)}.q-tile.picked .q-letter{background:radial-gradient(circle at 35% 30%,#e8bc5a,var(--gold) 62%,#8a6420);color:#2a1c06;text-shadow:0 1px 1px rgba(255,255,255,.35)}.q-choice{font-size:17px;flex:1;font-family:var(--serif)}.q-est{display:flex;flex-direction:column;align-items:center;gap:2px;margin:8px 0 16px}.q-est input{width:min(320px,80%);min-width:0;font-size:42px;text-align:center;padding:2px 10px 6px;border:none;border-bottom:3px solid var(--gold);border-radius:0;background:transparent;color:var(--ink);font-family:var(--display);font-weight:700;font-variant-numeric:tabular-nums}.q-est input::-webkit-inner-spin-button,.q-est input::-webkit-outer-spin-button{-webkit-appearance:none}.q-est input:focus,.q-est input:focus-visible{outline:none;border-bottom-color:var(--gold-2)}.q-est input::placeholder{font-size:20px;font-weight:400;letter-spacing:1px;color:var(--line-dark)}.q-unit{max-width:80%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-style:italic;color:var(--ink-soft);font-family:var(--serif)}.btn-gold.q-submit{width:auto;align-self:center;margin:0 auto;padding:12px 36px;border-radius:999px;display:block}.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:"✎ "}.q-verdict{position:relative;text-align:center;font-family:var(--display);font-weight:700;font-size:17px;padding:8px 14px;border-radius:10px;margin-bottom:12px;animation:bannerPop .3s ease both}.q-verdict.good{background:#e4f3dd;color:#24631f;border:1px solid #57a44b;animation:verdictStamp .45s cubic-bezier(.22,1.4,.32,1) both}.q-verdict.bad{background:#f6e0da;color:#8c2318;border:1px solid var(--danger);animation:verdictShake .3s ease-in-out both}.q-verdict.note{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#2a1c06;border:1px solid #8a6420;margin:12px 0 0}@keyframes verdictStamp{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}@keyframes verdictShake{0%,to{transform:translate(0)}20%{transform:translate(-5px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(2px)}}.fleck-burst{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible}.fleck-burst .fleck{position:absolute;left:50%;top:50%;width:8px;height:3px;border-radius:9px 2px;opacity:0;box-shadow:0 0 0 1px #78521c26;animation:goldFleck .9s ease-out both}@keyframes goldFleck{0%{opacity:0;transform:translate(-50%,-50%) rotate(0) scale(.4)}20%{opacity:.95}to{opacity:0;transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) rotate(var(--r)) scale(1)}}.g-diff{font-size:13px;color:var(--ink-soft);margin-left:4px}.est-guess.mine b{color:var(--gold)}.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);transition:filter .2s}.vs-chip.answered{filter:brightness(1.12)}.vs-chip.answered:after{content:"✓";margin-left:6px;color:var(--gold-2);text-shadow:0 1px 1px rgba(0,0,0,.6)}.vs-x{line-height:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.q-tile.reveal{cursor:default;background:#fffaeb8c}.q-tile.reveal.bad{background:#ecdcd4;border-color:var(--danger);color:var(--ink)}.q-tile.reveal.good{position:relative;border-width:3px;border-color:#fff4cf;box-shadow:0 0 0 3px var(--gold),0 0 22px 6px #ffd24a8c}.q-tile.reveal.good.throb{animation:tileThrob .9s ease-in-out 3}@keyframes tileThrob{0%,to{transform:scale(1);box-shadow:0 0 0 3px var(--gold),0 0 10px 2px #ffd24a59}50%{transform:scale(1.035);box-shadow:0 0 0 4px var(--gold),0 0 30px 10px #ffd24ad9}}.q-tile.reveal.good.settled{transform:translateY(-2px) scale(1.015);box-shadow:0 0 0 3px var(--gold),0 0 22px 7px #ffd24a99,0 4px 14px #b8862f59}.q-correct-mark{position:absolute;top:-9px;left:-6px;font-size:13px;line-height:1;color:var(--gold-2);text-shadow:0 0 4px rgba(255,210,74,.9),0 1px 1px rgba(0,0,0,.5)}.q-tile.reveal.good .q-letter{background:radial-gradient(circle at 35% 30%,#e8bc5a,var(--gold) 62%,#8a6420);color:#2a1c06;text-shadow:0 1px 1px rgba(255,255,255,.35)}.est-answer{font-family:var(--display);font-size:42px;font-weight:700;text-align:center;color:var(--gold);margin:8px 0 14px;font-variant-numeric:tabular-nums}.est-answer span{font-size:20px;color:var(--ink-soft)}.est-stair-wrap{display:flex;justify-content:center;padding:8px 0 24px}.est-cards{display:flex;align-items:flex-start;gap:10px;flex-wrap:nowrap}.est-card{position:relative;display:flex;flex-direction:column;flex:none;width:var(--est-card-w, 120px);height:var(--est-card-h, 150px);border-radius:12px;background:var(--panel);border:1px solid var(--line);overflow:hidden;opacity:0;transform:translateY(10px) scale(.9);transition:transform .6s cubic-bezier(.2,.8,.2,1),opacity .35s ease,border-color .3s ease,box-shadow .3s ease}.est-card.shown{opacity:1;transform:translateY(0) scale(1)}.est-card.placed{transition:transform .6s cubic-bezier(.2,.8,.2,1),opacity .35s ease,border-color .3s ease,box-shadow .3s ease}.est-card.mine{box-shadow:0 0 0 2px var(--c)}.est-card-head{display:flex;align-items:center;gap:5px;padding:6px 8px;background:color-mix(in srgb,var(--c) 55%,var(--panel))}.est-card-chip{flex:none}.est-card-name{font-family:var(--display);font-size:11px;color:#fff;text-shadow:0 1px 1px rgba(0,0,0,.4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.est-card-crown{flex:none;width:14px;height:14px;color:var(--gold-2);filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}.est-card-guess{flex:1;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:26px;font-weight:700;color:var(--ink);font-variant-numeric:tabular-nums}.est-card-time{position:absolute;right:6px;bottom:6px;font-family:var(--display);font-size:10px;color:var(--ink);background:var(--panel);border:1px solid var(--gold);border-radius:6px;padding:2px 5px;font-variant-numeric:tabular-nums}.est-card.winner{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold),0 4px 16px #b8862f66}.est-card.winner.mine{box-shadow:0 0 0 2px var(--gold),0 4px 16px #b8862f66}.stage-interstitial{position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;display:flex;align-items:center;justify-content:center;padding:24px;pointer-events:none;background:radial-gradient(80% 80% at 50% 40%,#0918288c,#030a12b3);animation:stageFadeIn .4s ease both}.stage-interstitial.out{animation:stageFadeOut .7s ease both}.stage-card{position:relative;width:min(560px,100%);aspect-ratio:1536 / 640;background:url(/round-banner.jpg) center / contain no-repeat;animation:stageCardIn .4s cubic-bezier(.2,.8,.2,1) both}.stage-interstitial.out .stage-card{animation:stageCardOut .7s cubic-bezier(.4,0,.6,1) both}.stage-text{position:absolute;left:22%;right:22%;top:34%;bottom:20%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(4px,1.2vw,8px);text-align:center;overflow:hidden}.stage-title{font-family:var(--display);font-weight:700;font-size:clamp(15px,3.4vw,30px);letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);text-shadow:0 1px 0 rgba(255,252,240,.55);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;max-height:2.6em;line-height:1.15;width:100%}.stage-sub{font-family:var(--serif);font-style:italic;font-size:clamp(11px,1.6vw,15px);color:var(--ink-soft);max-width:34ch;width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;max-height:2.6em;line-height:1.3}.stage-interstitial.round .stage-card{aspect-ratio:1536 / 640}@keyframes stageFadeIn{0%{opacity:0}to{opacity:1}}@keyframes stageFadeOut{0%{opacity:1}to{opacity:0}}@keyframes stageCardIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}@keyframes stageCardOut{0%{opacity:1;transform:none}to{opacity:0;transform:scale(.9) translateY(10px)}}.stage-interstitial.reduced{animation:stageFadeIn .15s ease both}.stage-interstitial.reduced.out{animation:stageFadeOut .15s ease both}.stage-interstitial.reduced .stage-card,.stage-interstitial.reduced.out .stage-card{animation:none}.results-overlay{align-items:center;justify-content:center}.results-card{width:100%;max-width:480px;max-height:100%;overflow-y:auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:28px 22px 22px;box-shadow:0 12px 34px #00000080}.victory-crest{position:relative;width:190px;height:190px;display:grid;place-items:center;filter:drop-shadow(0 4px 10px rgba(60,44,20,.4));animation:victoryIn .6s cubic-bezier(.2,.8,.2,1) both}.victory-crest .laurel{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}@keyframes victoryIn{0%{transform:scale(.6);opacity:0}60%{transform:scale(1.06)}to{transform:none;opacity:1}}.results-card .flourish{width:min(300px,70vw);height:auto;margin:-6px 0 4px;opacity:.9}.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;animation:standingIn .3s ease both}.standing.win{border-color:var(--gold);box-shadow:var(--shadow);animation:standingIn .3s ease both}@keyframes standingIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.standing .rank{font-size:18px;font-weight:700}.standing.win .medal{animation:medalStamp .5s cubic-bezier(.2,.8,.2,1) both;animation-delay:.3s}@keyframes medalStamp{0%{opacity:0;transform:scale(.3)}60%{opacity:1;transform:scale(1.15)}to{opacity:1;transform:scale(1)}}.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:18px;height:18px}.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-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 (max-width: 600px){.q-tiles{grid-template-columns:1fr}.hud{grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:6px}.hud-card{padding:4px 6px;gap:5px;border-left-width:6px}.hud-sub,.hud-shield{display:none}.hud-name{font-size:13px}.hud-name .tag{display:none}.hud-score{font-size:20px}}@media (max-height: 540px){.game{padding:6px 8px 8px;gap:6px}.board-stage{gap:6px}.phase-banner{padding:4px 44px}.pb-title{font-size:13px;letter-spacing:1px}.pb-sub{display:none}.order-strip{margin-top:4px}.ticker{margin-top:2px;font-size:11px}.hud{gap:6px;grid-template-columns:repeat(auto-fit,minmax(0,1fr))}.hud-card{padding:3px 8px;gap:6px}.hud-sub{display:none}.hud-name{font-size:13px}.hud-score{font-size:18px}.overlay{padding:10px}.q-card{padding:14px 16px 12px}.q-head{margin-bottom:8px}.q-text{font-size:17px;margin:4px 0 10px}.q-tiles{grid-template-columns:1fr 1fr;gap:8px}.q-tile{padding:8px 10px;gap:8px}.q-letter{width:26px;height:26px}.q-choice{font-size:14px}.q-est input{font-size:28px;padding:0 8px 4px}.btn-gold{padding:10px}.btn-gold.q-submit{padding:9px 26px}.q-verdict{padding:5px 10px;font-size:14px;margin-bottom:8px}.est-answer{font-size:30px;margin:4px 0 8px}.vs-strip{margin-bottom:6px}.ring{transform:scale(.78);transform-origin:top right}}body[data-reduced-motion] :is(*,.phase-banner,.action-bar,.q-card,.overlay,.standing.win){animation:none!important;transition:none!important}body[data-reduced-motion] .ring-fg{transition:none!important}body[data-reduced-motion] :is(.fx-ripple,.fx-region-pop,.conquest-old,.conquest-grow,.fleck-burst,.score-flyer,.map-value-flyer){display:none!important;animation: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:12px}.avatar-choice{aspect-ratio:1;border-radius:50%;border:2px solid var(--line);background:radial-gradient(circle at 35% 30%,#fff8ea,#ecdfc2);cursor:pointer;display:grid;place-items:center;transition:transform .08s,border-color .15s,box-shadow .15s}.avatar-choice:hover{transform:translateY(-2px);border-color:var(--gold-2)}.avatar-choice.selected{border-color:var(--gold-2);border-width:3px;box-shadow:0 0 0 1px var(--gold-2);transform:scale(1.05)}.swatch-row{display:flex;gap:10px;flex-wrap:wrap}.swatch{width:42px;height:54px;padding:0;background:transparent;border:none;cursor:pointer;transition:transform .08s,filter .15s}.swatch .shield-swatch{width:100%;height:100%;display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35))}.swatch:hover{transform:translateY(-2px)}.swatch.selected{transform:scale(1.1)}.swatch.selected .shield-swatch{filter:drop-shadow(0 0 5px var(--gold-2)) drop-shadow(0 2px 4px rgba(0,0,0,.3))}.swatch.custom{position:relative;display:inline-block}.swatch.custom input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:0;padding:0}.custom-plus{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding-top:2px;font-family:var(--display);font-size:18px;font-weight:700;color:var(--ink-soft);pointer-events:none;text-shadow:0 1px 2px rgba(255,255,255,.6)}.swatch.custom.selected .custom-plus{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.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:-22px;transform:translate(-50%);width:240px;height:58px;background:url(/flourish.png) center / contain no-repeat}.hub-head h2{margin-bottom:34px}.play-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}.play-card{background:var(--panel);border:2px solid var(--line-dark);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow)}.play-card .btn:last-child,.play-card .join-row{margin-top:auto}.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>*{animation:pageIn .25s ease both}@keyframes pageIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}.shell-main h2{color:var(--parch-on-dark);font-family:var(--display)}.shell-main .muted,.shell-main .empty-state{color:#a9c4dd}.stats-page h3,.friends-section h3{color:var(--parch-on-dark);font-family:var(--display)}.shell-main .ledger th{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 6px calc(6px + env(safe-area-inset-bottom));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(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:18px}.stat{padding:14px;border:1px solid var(--line);border-radius:14px;background:var(--panel);display:grid;gap:2px;color:var(--ink)}.stat .muted{color:var(--ink-soft)}.kpi{font-family:var(--display);font-size:30px;font-weight:700;font-variant-numeric:tabular-nums}.ledger{width:100%;border-collapse:separate;border-spacing:0 6px}@media (max-width: 480px){.ledger{display:block;overflow-x:auto;white-space:nowrap}}.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;font-variant-numeric:tabular-nums}.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}}.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;color:var(--ink)}.badge-card b{color:var(--ink)}.badge-card .muted{color:var(--ink-soft)}.badge-card.locked{opacity:.85}.badge-card.locked .badge-medal{filter:grayscale(1)}.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.tier-bronze{background:linear-gradient(180deg,#c98f5c,#a9713d);border-color:#7a4e28}.badge-medal.tier-silver{background:linear-gradient(180deg,#c3c9cf,#9aa2ab);border-color:#6f7680}.badge-medal.tier-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));border-color:#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;color:var(--ink)}.friend-row .fr-name{flex:1;min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.friend-row .muted{color:var(--ink-soft)}.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:#f3ead4f0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--line-dark);border-radius:14px;box-shadow:inset 0 0 0 4px #f3ead4cc,inset 0 0 0 5px #9c85598c,0 24px 60px #140c0480;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:20px;height:20px;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}.os-row{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.order-strip-war{display:flex;flex-direction:column;align-items:center;gap:4px;margin-top:8px}.os-now{display:flex;align-items:center;gap:10px}.rounds-toggle-wrap{position:relative}.rounds-toggle{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;cursor:pointer;background:linear-gradient(180deg,#24507c,#16334f);border:1.5px solid var(--gold);color:var(--gold-2);box-shadow:0 3px 8px #00000059;transition:filter .15s}.rounds-toggle:hover{filter:brightness(1.15)}.rounds-toggle[aria-expanded=true]{box-shadow:0 0 0 2px var(--table-2),0 0 0 4px var(--gold-2)}.rounds-toggle .icon{width:16px;height:16px}.rounds-panel{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:20;width:max-content;min-width:150px;max-width:240px;background:var(--panel);border:1px solid var(--line-dark);border-radius:10px;box-shadow:0 12px 28px #0006;padding:6px;display:flex;flex-direction:column;gap:2px;animation:tileIn .18s ease both}.rp-row{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:6px;border-left:3px solid transparent}.rp-n{font-family:var(--display);font-weight:700;font-size:12px;color:var(--ink-soft);width:1.4em;text-align:right;flex:none}.rp-chips{display:flex;gap:3px;flex-wrap:wrap}.rp-chip{width:16px;height:16px}.rp-row.past{opacity:.45}.rp-row.current{border-left-color:var(--gold);background:#b8862f24}.rp-row.current .rp-n{color:var(--gold)}.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}}
