:root{--bg:#0f1c2d;--panel:#162a40;--panel-strong:#1f3a57;--text:#e9f0f8;--accent:#ff8b3d;--good:#5dd38d;--danger:#ff5c74}*{box-sizing:border-box}body{color:var(--text);background:radial-gradient(circle at top left, #1f3652, var(--bg));margin:0;font-family:Trebuchet MS,Segoe UI,sans-serif}.app{max-width:100%;margin:0;padding:0}.game-layout{--top-shell-height:64px;height:100vh;min-height:100vh;padding-top:calc(var(--top-shell-height) + .35rem);padding-left:.75rem;padding-right:.75rem;overflow:clip}.panel{background:linear-gradient(155deg,#ffffff14,#ffffff05);border:1px solid #ffffff26;border-radius:14px;padding:1rem;box-shadow:0 10px 30px #00000038}.top-shell{z-index:25;height:var(--top-shell-height);justify-content:space-between;align-items:center;gap:.75rem;padding-top:.45rem;padding-bottom:.45rem;display:flex;position:fixed;top:.3rem;left:.75rem;right:.75rem}.top-shell-meta{align-items:center;gap:1rem;min-width:0;display:flex}.top-shell-title h1{margin:0;font-size:.92rem}.top-shell-title p{color:#e9f0f8d9;margin:.15rem 0 0;font-size:.72rem}.resource-strip{flex-wrap:wrap;gap:.5rem;display:flex}.resource-pill{background:#0a1826ad;border:1px solid #ffffff2e;border-radius:4px;align-items:center;gap:.3rem;padding:.22rem .44rem;font-size:.76rem;display:inline-flex}.resource-pill .symbol-icon{width:64px;height:64px}.top-shell-actions{gap:.4rem;display:flex}.top-shell-actions .action-icon-button.utility{width:64px;height:64px;font-size:1.45rem}.board-viewport{height:calc(100vh - var(--top-shell-height) - .7rem);justify-content:center;align-items:center;min-height:280px;display:flex}.action-bar-row{justify-content:space-between;align-items:flex-start;gap:.8rem;display:flex}.action-panel-shell{z-index:18;pointer-events:none;flex-direction:column;align-items:flex-end;gap:.4rem;display:flex;position:fixed;top:50%;right:.75rem;transform:translateY(-50%)}.action-panel-shell .actions-panel{pointer-events:auto;width:fit-content;max-width:100%}.action-hint-line{pointer-events:auto;max-width:min(320px,100%);color:var(--text);text-align:center;background:#081420eb;border:1px solid #ffdc7b8c;border-radius:999px;padding:.35rem .7rem;font-size:.85rem;font-weight:600;line-height:1.25;box-shadow:0 8px 22px #00000059}.ritual-action-panel{pointer-events:auto;background:#081420eb;border:1px solid #ffffff3d;border-radius:10px;gap:.5rem;width:240px;margin-top:.45rem;margin-left:auto;padding:.55rem .65rem;display:grid}.ritual-payment-row{align-items:center;gap:.5rem;font-size:1rem;font-weight:700;display:inline-flex}.ritual-payment-icon{width:64px;height:64px}.hand-peek-shell{z-index:22;will-change:transform;transition:transform .22s;position:fixed;bottom:0;left:.75rem;right:.75rem;transform:translateY(calc(100% - 2.6rem))}.hand-peek-shell:hover{transform:translateY(0)}.hand-peek-shell .hand{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border-bottom-right-radius:0;border-bottom-left-radius:0;margin:0;padding-top:.7rem;padding-bottom:.75rem}.action-bar-icons{flex-wrap:wrap;gap:.35rem;display:flex}.action-bar-controls{gap:.35rem;display:flex}.players-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.7rem;display:grid}.players-grid article{background:var(--panel);border:1px solid #0000;border-radius:10px;padding:.6rem}.players-grid article.me{border-color:var(--accent)}.cards{gap:.6rem;padding-bottom:.4rem;display:flex;overflow-x:auto}.card{--card-ratio:812 / 1280;width:clamp(160px,18vw,220px);min-width:clamp(160px,18vw,220px);aspect-ratio:var(--card-ratio);color:var(--text);cursor:pointer;background:#000;border:1px solid #ffffff40;border-radius:12px;flex-direction:column;gap:.55rem;padding:.55rem;display:flex;position:relative;overflow:hidden}.card.selected{border-color:var(--good);transform:translateY(-2px)}.card.source-starter{--card-ratio:747 / 1280}.card.source-library{--card-ratio:812 / 1280}.card-faceup,.card-facedown{background:#000}.card-title{z-index:1;width:100%;font-size:.86rem;font-weight:700;line-height:1.2}.card-faceup .card-title{text-shadow:0 1px 2px #0000008c;position:absolute;top:.45rem;left:.55rem;right:.55rem}.card-hint{color:#e9f0f8e6;background:#0000008c;border-radius:8px;margin-top:auto;padding:.35rem .45rem;font-size:.78rem;line-height:1.2}.card-zones{grid-template-rows:1fr 1fr;gap:.45rem;width:100%;height:100%;margin-top:0;display:grid}.card-zone{background:#ffffff0a;border:1px solid #ffffff2e;border-radius:8px;flex-direction:column;justify-content:flex-start;gap:.35rem;height:100%;min-height:0;padding:.32rem;display:flex;overflow:hidden}.card-faceup .card-zones{padding-top:1.55rem}.card-faceup .card-zone{min-height:calc(50% - .225rem)}.card-zone-label{text-transform:uppercase;letter-spacing:.04em;color:#e9f0f8d1;flex:none;font-size:.68rem}.card-zone-content{flex:auto;justify-content:center;align-items:center;min-height:0;display:flex}.symbol-list{grid-template-columns:repeat(3,minmax(0,1fr));place-content:center;place-items:center;gap:.32rem;width:100%;min-width:0;display:grid}.symbol-list.compact{vertical-align:middle;grid-template-columns:none;width:auto;display:inline-flex}.symbol-cell{justify-content:center;align-items:center;width:100%;min-width:0;display:inline-flex}.symbol-icon{object-fit:contain;background:#ffffff08;border-radius:4px;width:20px;height:20px}.card-zone .symbol-icon{aspect-ratio:1;width:min(100%,54px);height:auto}.card-zone .symbol-list.count-1 .symbol-icon{width:min(100%,74px)}.card-zone .symbol-list.count-2 .symbol-icon{width:min(100%,62px)}.card-zone .symbol-list.count-1{grid-template-columns:minmax(0,1fr)}.card-zone .symbol-list.count-2{grid-template-columns:repeat(2,minmax(0,1fr))}.symbol-empty{color:#e9f0f8b3;font-size:.78rem}.symbol-fallback{border:1px solid #fff3;border-radius:999px;align-items:center;padding:.1rem .3rem;font-size:.68rem;display:inline-flex}.board-image{object-fit:fill;border-radius:10px;width:100%;height:100%;display:block}.board{justify-content:center;align-items:center;width:100%;height:100%;margin:0;padding:.35rem;display:flex}.board-surface{aspect-ratio:1;width:auto;max-width:100%;height:100%;max-height:100%;margin:0 auto;position:relative}.board-overlay{pointer-events:none;position:absolute;inset:0}.board-location-zone,.board-sphere-zone{position:absolute}.board-location-zone{pointer-events:auto;color:var(--text);background:#091a2b47;border:1px dashed #ffffff8c;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:clamp(.1rem,.35vw,.3rem);padding:clamp(.14rem,.6vw,.36rem);display:flex}.board-region-pickable{cursor:pointer}.board-location-hovered{border-color:#ffe884f2;box-shadow:0 0 0 2px #ffe8844d,0 0 22px #ffe88459}.board-location-label{text-shadow:0 0 6px #0009;font-size:clamp(.4rem,.8vw,.7rem);font-weight:700}.board-stack{flex-wrap:wrap;place-content:center;gap:clamp(.08rem,.26vw,.2rem);display:flex}.board-follower-token,.board-stone-token,.board-follower-fallback{object-fit:contain}.board-piece-button{background:0 0;border:none;padding:0;line-height:0}.board-follower-token,.board-follower-fallback{width:64px;height:64px}.board-stone-token{width:32px;height:32px}.board-follower-fallback{color:#cbe3f8;background:#111f2ed9;border:1px solid #ffffff59;border-radius:999px;justify-content:center;align-items:center;font-size:clamp(.28rem,.65vw,.52rem);font-weight:700;display:inline-flex}.board-incarnation{justify-content:center;align-items:center;display:inline-flex;position:relative}.board-avatar-token{width:clamp(.48rem,1.2vw,.96rem);height:clamp(.48rem,1.2vw,.96rem)}.board-avatar-marker{color:#fff;text-shadow:0 0 6px #000000d9;justify-content:center;align-items:center;font-size:clamp(.34rem,.8vw,.6rem);font-weight:800;display:inline-flex;position:absolute;inset:0}.board-skull-target{filter:drop-shadow(0 0 8px #ff8c8cbf);cursor:pointer;animation:1.1s ease-in-out infinite board-skull-pulse}.board-round-cleanup-target{filter:drop-shadow(0 0 8px #ffe884cc);cursor:pointer;animation:1.1s ease-in-out infinite board-round-cleanup-pulse}.board-ritual-target{filter:drop-shadow(0 0 8px #ff8484cc);cursor:pointer;animation:1.1s ease-in-out infinite board-round-cleanup-pulse}.board-ritual-disabled{opacity:.78}.board-teleport-source-target{filter:drop-shadow(0 0 8px #84c8ffd9);cursor:pointer;animation:1.1s ease-in-out infinite board-round-cleanup-pulse}.board-teleport-source-selected{filter:drop-shadow(0 0 10px #84c8ff);outline-offset:2px;border-radius:999px;outline:2px solid #84c8fff2}.board-placement-target,.board-teleport-destination-target{cursor:pointer;background:#ffdc7b14;border:2px dashed #ffdc7bd9;border-radius:12px;animation:1.2s ease-in-out infinite board-location-target-pulse}.board-teleport-destination-target{background:#84c8ff14;border-color:#84c8ffd9}@keyframes board-location-target-pulse{0%,to{box-shadow:0 0 #ffdc7b00}50%{box-shadow:0 0 0 4px #ffdc7b59}}.board-sphere-zone{pointer-events:auto;background:radial-gradient(circle at 30% 28%,#ffffff4d,#ffffff14);border:1px solid #ffffff73;border-radius:999px;justify-content:center;align-items:center;padding:clamp(.1rem,.55vw,.3rem);display:flex}.board-stones{min-height:clamp(.5rem,1.6vw,1rem)}.board-sphere-zone.placement-choice-active{border-color:#ffdc7bf2;animation:1.1s ease-in-out infinite board-sphere-pulse;box-shadow:0 0 0 3px #ffdc7b47,0 0 22px #ffdc7b73}.board-stone-button{cursor:default;background:0 0;border:none;padding:0;line-height:0}.board-stone-button:disabled{opacity:1}.board-stone-button.placement-choice-stone{cursor:pointer;filter:drop-shadow(0 0 6px #fff0c68c)}.board-placement-hint{color:#1f1b11;background:#ffdc7beb;border-radius:999px;justify-content:center;align-items:center;padding:.2rem .45rem;font-size:.72rem;font-weight:700;display:inline-flex}.board-empty-slot{color:#e6f0fcd9;font-size:clamp(.3rem,.68vw,.56rem)}@keyframes board-skull-pulse{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes board-sphere-pulse{0%{transform:scale(1)}50%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes board-round-cleanup-pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.board-region-markers{pointer-events:none;flex-wrap:wrap;gap:.25rem;display:flex;position:absolute;transform:translateY(-50%)}.board-region-markers-right{justify-content:flex-start;right:-.8rem}.board-region-markers-left{justify-content:flex-end;left:-.8rem}.board-region-marker{text-shadow:0 0 8px #000000fa;font-size:clamp(1.05rem,1.6vw,1.35rem);font-weight:800;line-height:1}.board-ritual-drop{color:#ffd7d7;pointer-events:auto;background:#220808bf;border:1px dashed #ffa0a0f2;border-radius:10px;align-items:center;gap:.45rem;padding:.4rem .55rem;display:flex;position:absolute;bottom:.6rem;right:.6rem}.board-ritual-icon{object-fit:contain;width:38px;height:38px}.follower-token,.lobby button{background:var(--accent);color:#1f1f1f;border:none;border-radius:8px;padding:.5rem .8rem;font-weight:700}.region-row{margin-bottom:.8rem}.region-locations{grid-template-columns:minmax(0,1fr) minmax(100px,.6fr) minmax(0,1fr) minmax(100px,.6fr) minmax(0,1fr);align-items:stretch;gap:.5rem;display:grid}.location{text-align:left;background:var(--panel-strong);color:var(--text);border:1px dashed #ffffff4d;border-radius:10px;flex-direction:column;gap:.2rem;padding:.6rem;display:flex}.sphere{color:var(--text);text-align:center;background:radial-gradient(circle at 30% 30%,#ffffff47,#ffffff14);border:1px solid #ffffff59;border-radius:999px;flex-direction:column;justify-content:center;align-items:center;min-height:74px;padding:.4rem;font-size:.8rem;display:flex}.events ul{gap:.45rem;margin:0;padding:0;list-style:none;display:grid}.events li{background:var(--panel);border-radius:8px;justify-content:space-between;gap:.5rem;padding:.4rem .5rem;display:flex}.discard-card{cursor:default}.played-zone-columns{grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;display:grid}.played-zone-columns>article{background:var(--panel);border-radius:10px;padding:.6rem}.turn-banner{border:1px solid var(--accent);color:var(--text);z-index:20;background:#0f1e2ef2;border-radius:12px;padding:.8rem 1.2rem;font-weight:700;position:fixed;top:14%;left:50%;transform:translate(-50%);box-shadow:0 8px 30px #00000059}.turn-banner.own-turn{padding:1rem 1.6rem;font-size:clamp(2.2rem,7vw,4.8rem);line-height:1;top:50%;transform:translate(-50%,-50%)}.snake-wait-overlay{z-index:35;color:var(--text);text-align:center;background:#05101ca8;place-items:center;padding:1rem;font-size:clamp(1.1rem,2.3vw,1.6rem);font-weight:700;display:grid;position:fixed;inset:0}.burn-modal{z-index:30;background:#02080ed1;place-items:center;display:grid;position:fixed;inset:0}.burn-inline{display:block}.burn-modal-content{background:#102236;border:1px solid #ffffff52;border-radius:14px;width:min(720px,94vw);padding:1rem;box-shadow:0 18px 44px #0000008c}.burn-modal-content-inline{background:0 0;border:none;border-radius:0;width:100%;max-width:none;padding:0}.app-overlay-modal{z-index:40;background:#060e18b8;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.app-overlay-content{width:min(1200px,96vw);max-height:min(88vh,980px);overflow:auto}.app-overlay-header{justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.7rem;display:flex}.modal-stack{gap:.65rem;display:grid}.round-summary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:.75rem;display:grid}.round-summary-region{background:#08121eb3;border:1px solid #ffffff38;border-radius:10px;padding:.65rem}.round-summary-region h3{margin:0 0 .45rem}.round-summary-region table{border-collapse:collapse;width:100%;font-size:.84rem}.round-summary-region th,.round-summary-region td{text-align:left;border-bottom:1px solid #ffffff21;padding:.32rem .35rem}.round-summary-region tr:last-child td{border-bottom:none}.round-summary-reward{align-items:center;gap:.35rem;display:inline-flex}.round-summary-reward .symbol-icon{width:16px;height:16px}.action-flyout-modal{top:calc(var(--top-shell-height) + .9rem);z-index:32;pointer-events:auto;width:min(900px,92vw);transition:opacity .12s;position:fixed;left:50%;transform:translate(-50%)}.action-flyout-content{pointer-events:auto;background:#102236;border:1px solid #ffffff5c;max-height:min(72vh,760px);overflow:auto;box-shadow:0 20px 50px #0000008f}.floating-error{z-index:50;background:#28080ef2;border:1px solid #ff5c7473;border-radius:8px;padding:.45rem .7rem;position:fixed;bottom:5.5rem;left:50%;transform:translate(-50%)}.burn-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.5rem;margin-bottom:.7rem;display:grid}.burn-grid-horizontal{flex-wrap:nowrap;padding-bottom:.35rem;display:flex;overflow:auto hidden}.burn-grid-horizontal .burn-option-card{flex:0 0 190px;width:190px}.burn-option{color:var(--text);background:#0f2032;border:1px solid #ffffff40;border-radius:8px;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.45rem .55rem;display:flex}.burn-option.selected{border-color:var(--good)}.burn-option-card{justify-self:stretch;width:100%;min-width:0}.burn-actions{gap:.6rem;display:flex}.curse-targets-row{gap:.7rem;margin-bottom:.2rem;padding:.2rem .1rem .45rem;display:flex;overflow-x:auto}.curse-target-option{--curse-player-accent:#cfd8e3;min-width:86px;color:var(--text);background:#102338;border:1px solid #ffffff47;border-radius:10px;flex-direction:column;align-items:center;gap:.35rem;padding:.4rem .5rem;display:inline-flex}.curse-target-option.selected{border-color:var(--curse-player-accent);box-shadow:0 0 0 2px var(--curse-player-accent)}.curse-target-icon{object-fit:contain;width:46px;height:46px}.curse-target-name{text-align:center;color:var(--curse-player-accent);font-size:.78rem;font-weight:600;line-height:1.15;display:inline-block}.snake-panel{background:#07121ef7;border-color:#ffffff4d;margin:0}.actions-panel{margin:0;padding-top:.7rem;padding-bottom:.7rem}.actions-panel .action-icon-button,.actions-panel .action-symbol{width:64px;height:64px}.snake-response-prompt{margin:0 0 .6rem;font-weight:700}.action-chip{align-items:center;gap:.35rem;display:flex}.action-icon-button{width:56px;height:56px;color:var(--text);cursor:pointer;background:#0a1826e0;border:1px solid #ffffff3d;border-radius:10px;justify-content:center;align-items:center;display:inline-flex}.action-icon-button.active{border-color:var(--accent);box-shadow:0 0 0 2px #ff8b3d47}.action-icon-button.utility{font-size:1.2rem;line-height:1}.action-icon-button.shop-pulse{border-color:#ffc376f2;animation:1.1s ease-in-out infinite shop-button-pulse;box-shadow:0 0 0 2px #ffa44d40,0 0 18px #ffa44d66}.action-symbol{border-radius:8px;width:44px;height:44px}.snake-response-card{width:clamp(140px,15vw,180px);min-width:clamp(140px,15vw,180px)}.ghost{color:var(--text);background:0 0;border:1px solid #ffffff4d;border-radius:8px;padding:.4rem .55rem}.card.source-library.card-facedown{background-image:linear-gradient(#0000002e,#0000009e),url(/assets/card-back-library.png);background-position:50%;background-size:cover}.card.source-starter.card-facedown{background-image:linear-gradient(#0000002e,#0000009e),url(/assets/card-back-starters.png);background-position:50%;background-size:cover}.library-card.revealed{border-color:var(--good)}.library-primary-button{width:100%;min-height:0;color:inherit;text-align:left;cursor:inherit;background:0 0;border:none;flex-direction:column;flex:auto;gap:.55rem;padding:0;display:flex}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}select{color:var(--text);background:#0e1a2a;border:1px solid #fff3;border-radius:8px;padding:.45rem .55rem}.lobby-page{grid-template-columns:1fr;place-items:center;min-height:100vh;display:grid}.lobby{gap:.8rem;width:min(560px,95vw);display:grid}.lobby form{gap:.8rem;display:grid}.lobby label{gap:.3rem;display:grid}.lobby-list{background:#050e1659;border:1px solid #fff3;border-radius:10px;padding:.75rem}.lobby-list ul{gap:.5rem;margin:0;padding:0;list-style:none;display:grid}.lobby-list li{justify-content:space-between;align-items:center;gap:.8rem;display:flex}.lobby label.lobby-checkbox{align-items:center;gap:.5rem;display:flex}.lobby-checkbox input{width:auto}.lobby-actions{gap:.6rem;display:flex}input{width:100%;color:var(--text);background:#0e1a2a;border:1px solid #fff3;border-radius:8px;padding:.55rem .6rem}.error{color:var(--danger)}@media (width<=720px){.game-layout{--top-shell-height:96px;padding-left:.5rem;padding-right:.5rem}.top-shell,.hand-peek-shell{left:.5rem;right:.5rem}.top-shell{flex-direction:column;justify-content:center;align-items:flex-start;padding-top:.6rem;padding-bottom:.6rem}.top-shell-title h1{font-size:1rem}.top-shell-title p{font-size:.74rem}.resource-strip{gap:.35rem}.resource-pill{font-size:.78rem}.action-panel-shell{right:.5rem}.ritual-action-panel{width:196px}.ritual-payment-icon{width:48px;height:48px}.hand-peek-shell{transform:translateY(calc(100% - 2.1rem))}.played-zone-columns,.region-locations{grid-template-columns:1fr}.action-icon-button{width:48px;height:48px}.top-shell-actions .action-icon-button.utility{width:64px;height:64px;font-size:1.2rem}.action-symbol{width:38px;height:38px}.action-flyout-modal{top:calc(var(--top-shell-height) + .6rem);width:96vw}}@keyframes shop-button-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}
