:root{--nightfall:#0c141c;--frost-steel:#1b2a38;--cold-cell:#42627a;--ember:#e8a24c;--lamp-bone:#f4ecd8;--hazard-rust:#b8412e;--font-display:"Barlow Condensed","IBM Plex Sans",system-ui,sans-serif;--font-body:"IBM Plex Sans",system-ui,-apple-system,sans-serif;--panel:rgba(27,42,56,0.82);--panel-solid:#16222e;--edge:rgba(244,236,216,0.12);--radius:10px}*{box-sizing:border-box}body,html{margin:0;padding:0;height:100%;background:var(--nightfall);color:var(--lamp-bone);font-family:var(--font-body);font-feature-settings:"tnum" 1;overscroll-behavior:none;-webkit-font-smoothing:antialiased}.display,h1,h2,h3{font-family:var(--font-display);letter-spacing:.02em;text-transform:uppercase;margin:0}button{font-family:var(--font-body);cursor:pointer}:focus-visible{outline:2px solid var(--ember);outline-offset:2px;border-radius:4px}.app{position:fixed;top:var(--app-top,0);left:0;right:0;height:100svh;height:var(--app-h,100svh);display:grid;grid-template-rows:auto minmax(0,1fr) auto}.hide-sm{display:inline}.zoomctl{position:absolute;top:10px;right:10px;z-index:4;display:flex;flex-direction:column;gap:6px}.zbtn{width:38px;height:38px;border-radius:9px;border:1px solid var(--edge);background:rgba(12,20,28,.7);color:var(--lamp-bone);font-size:18px;line-height:1;display:grid;place-items:center}.zbtn:hover{background:rgba(33,52,74,.92)}.scene{position:relative;min-height:0;overflow:hidden}.backdrop{position:absolute;inset:0;background-size:cover;background-position:50%;filter:saturate(.7) brightness(.42);z-index:0}.backdrop:after{content:"";position:absolute;inset:0;background:radial-gradient(110% 85% at 50% 42%,rgba(12,20,28,.45),rgba(12,20,28,.92))}.canvas{width:100%;height:100%;display:block;z-index:1}.canvas,.overlay{position:absolute;inset:0;touch-action:none}.overlay{z-index:2}.hud{display:flex;align-items:center;gap:14px;padding:max(10px,env(safe-area-inset-top)) max(14px,env(safe-area-inset-right)) 10px max(14px,env(safe-area-inset-left));background:linear-gradient(var(--frost-steel),var(--panel-solid));border-bottom:1px solid var(--edge);z-index:5;flex-wrap:wrap}.hud .night{font-family:var(--font-display);font-size:26px;line-height:1;color:var(--lamp-bone)}.hud .night small{color:var(--cold-cell);font-size:15px}.stat{display:flex;align-items:center;gap:6px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:15px;padding:4px 9px;background:rgba(12,20,28,.5);border:1px solid var(--edge);border-radius:999px}.stat .glyph{width:16px;text-align:center;color:var(--ember)}.stat.low{color:var(--hazard-rust);border-color:rgba(184,65,46,.5)}.hud .spacer{flex:1 1}.survivors{display:flex;gap:8px;flex-wrap:wrap}.survivor{min-width:116px;background:var(--panel);border:1px solid var(--edge);border-radius:var(--radius);padding:6px 8px}.survivor .name{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}.survivor .tag{font-size:10px;text-transform:uppercase;letter-spacing:.05em}.survivor .tag,.survivor .tag.cold{color:var(--cold-cell)}.survivor .tag.injured,.survivor .tag.lost,.survivor .tag.starving{color:var(--hazard-rust)}.meter{height:6px;border-radius:3px;background:rgba(12,20,28,.6);overflow:hidden;margin:3px 0}.meter>span{display:block;height:100%;transition:width .42s ease}.meter.warmth>span{background:linear-gradient(90deg,var(--cold-cell),var(--ember))}.meter.health>span{background:var(--lamp-bone)}.meter.hunger>span{background:var(--cold-cell)}.dock{background:linear-gradient(var(--panel-solid),var(--frost-steel));border-top:1px solid var(--edge);padding:10px max(14px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(14px,env(safe-area-inset-left));flex-direction:column;gap:10px;z-index:5}.dock,.tray{display:flex}.tray{gap:8px;overflow-x:auto;padding-bottom:4px;min-height:64px}.tray:empty:before{content:"The tray is empty — the haul is packed.";color:var(--cold-cell);font-size:13px;align-self:center}.tile{flex:0 0 auto;width:56px;height:56px;border-radius:var(--radius);border:1px solid var(--edge);background:var(--frost-steel);color:var(--lamp-bone);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;padding:2px}.tile .ic{font-size:20px;line-height:1}.tile .lbl{font-size:9px;text-align:center;line-height:1.05;color:var(--lamp-bone);opacity:.85}.tile.kind-heat{border-color:rgba(232,162,76,.5)}.tile.kind-med{border-color:rgba(184,65,46,.5)}.tile.selected{outline:2px solid var(--ember);outline-offset:1px}.tile .badge{position:absolute;top:2px;right:3px;font-size:9px;color:var(--ember);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.btn{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.04em;font-size:15px;padding:9px 14px;border-radius:var(--radius);border:1px solid var(--edge);background:var(--frost-steel);color:var(--lamp-bone);transition:background .16s ease,transform .12s ease}.btn:hover{background:#21344a}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn.primary{background:var(--ember);color:var(--nightfall);border-color:var(--ember);font-weight:700}.btn.primary:hover{background:#f0b061}.btn.danger{border-color:rgba(184,65,46,.6);color:#e9967f}.btn.ghost{background:transparent}.toast{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);background:rgba(12,20,28,.92);border:1px solid var(--edge);color:var(--lamp-bone);padding:8px 16px;border-radius:999px;font-size:14px;z-index:6;pointer-events:none;max-width:90%;text-align:center}.scrim{position:fixed;inset:0;top:var(--app-top,0);height:var(--app-h,100svh);background:rgba(6,11,16,.72);display:grid;place-items:center;z-index:20;padding:18px}.modal{width:min(520px,96vw);max-height:calc(var(--app-h, 100svh) - 36px);overflow:auto;background:var(--panel-solid);border:1px solid var(--edge);border-radius:16px;padding:22px;box-shadow:0 24px 60px rgba(0,0,0,.5)}.modal h2{font-size:28px;color:var(--lamp-bone);margin-bottom:4px}.modal .sub{color:var(--cold-cell);font-size:14px;margin-bottom:16px}.modal .row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--edge);font-size:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.modal .actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}.raid{position:absolute;inset:0;z-index:8;display:grid;place-items:center;background:rgba(6,11,16,.55);padding:16px}.raid-card{width:min(560px,96vw);background:var(--panel-solid);border:1px solid var(--edge);border-radius:16px;padding:18px}.raid-head{justify-content:space-between;margin-bottom:12px}.light,.raid-head{display:flex;align-items:center}.light{gap:6px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.light .pip{width:9px;height:18px;border-radius:2px;background:var(--ember)}.light .pip.off{background:rgba(66,98,122,.4)}.raid-grid{display:grid;grid-gap:6px;gap:6px;margin:12px 0}.raid-cell{aspect-ratio:1;border-radius:8px;border:1px solid var(--edge);background:var(--frost-steel);display:grid;place-items:center;font-size:20px}.raid-cell.next{outline:2px solid var(--ember)}.raid-cell.loot{background:rgba(232,162,76,.18)}.raid-cell.hazard{background:rgba(184,65,46,.22)}.raid-cell.exit{background:rgba(66,98,122,.3)}.sack{display:grid;grid-gap:4px;gap:4px;margin:10px auto;width:max-content}.sack-cell{width:34px;height:34px;border-radius:6px;border:1px solid var(--edge);background:rgba(12,20,28,.5);display:grid;place-items:center;font-size:16px}.sack-cell.filled{background:rgba(232,162,76,.16)}.splash{position:fixed;inset:0;display:grid;place-items:center;text-align:center;background:radial-gradient(80% 60% at 50% 35%,#15212d,var(--nightfall));z-index:30;padding:24px}.splash .title{font-size:clamp(48px,12vw,96px);color:var(--lamp-bone);text-shadow:0 0 40px rgba(232,162,76,.25)}.splash .tag{max-width:30ch;margin:8px auto 22px;font-size:16px}.muted,.splash .tag{color:var(--cold-cell)}.ember-text{color:var(--ember)}.rust-text{color:var(--hazard-rust)}@media (max-width:560px){.hud{gap:6px 8px;padding:max(8px,env(safe-area-inset-top)) 10px 8px}.hud .night{font-size:20px}.hud .spacer{display:none}.survivors{flex:1 1 100%;flex-wrap:nowrap;overflow-x:auto;min-width:0;gap:6px}.survivor{min-width:92px;padding:4px 6px}.hide-sm{display:none!important}.controls{gap:6px}.btn{padding:8px 11px;font-size:13px}.tile{width:50px;height:50px}.zbtn{width:34px;height:34px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;transition-duration:.001ms!important}}