*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg-0: #0c0a06;--bg-1: #15110b;--bg-2: #1d1810;--panel: rgba(13, 10, 6, .9);--panel-soft: rgba(16, 12, 8, .82);--border: rgba(110, 102, 80, .28);--border-strong: rgba(168, 158, 132, .44);--text-strong: #e8dfc8;--text: #cfc3a8;--text-soft: #a89e84;--text-dim: #6e6650;--accent-lime: #7df3a8;--accent-cyan: #ff8a1f;--accent-ember: #ff8a1f;--accent-ember-deep: #c25a10;--accent-gold: #f5c96b;--accent-magenta: #f18ac5;--accent-red: #ef7d7d;--font-ui: "Space Mono", monospace;--font-display: "VT323", monospace;--font-mono: "Space Mono", monospace}body{background:radial-gradient(ellipse at 10% -5%,rgba(255,138,31,.06),transparent 50%),radial-gradient(ellipse at 90% 110%,rgba(166,75,26,.05),transparent 55%),linear-gradient(180deg,var(--bg-1),var(--bg-0) 42%,#070503 100%);overflow:hidden;font-family:var(--font-ui);color:var(--text-strong);user-select:none;text-rendering:optimizeLegibility}button,input{font:inherit}#game{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;cursor:crosshair;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges}#scanlines{position:fixed;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.018) 0px,rgba(255,255,255,.018) 1px,transparent 1px,transparent 4px);opacity:.4;pointer-events:none;z-index:10}#vignette{position:fixed;inset:0;background:radial-gradient(ellipse at center,transparent 58%,rgba(0,0,0,.58) 100%);pointer-events:none;z-index:11}#ui{position:fixed;inset:0;pointer-events:none;z-index:20}:root{--toolbar-offset: 64px}#hud{position:fixed;top:0;left:0;right:0;width:100vw;display:block}#toolbar{position:fixed;top:0;left:0;right:0;width:100vw;background:linear-gradient(160deg,#18130cf7,#100c07f2);border-bottom:1px solid rgba(255,138,31,.22);border-top:3px solid rgba(255,138,31,.7);border-radius:0;padding:10px 16px;backdrop-filter:blur(14px);box-shadow:0 16px 48px #00000073,inset 0 1px #ffffff0a;display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:center;pointer-events:all;box-sizing:border-box;min-height:64px;z-index:30}.toolbar-brand{display:flex;align-items:center;gap:10px;min-width:0;padding-right:8px}.toolbar-readouts{display:flex;align-items:center;gap:14px;min-width:0;overflow:hidden;flex-wrap:wrap}.toolbar-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end;flex-wrap:nowrap}#toolbar-panel{position:fixed;top:var(--toolbar-offset);left:0;right:0;max-height:calc(100vh - var(--toolbar-offset));overflow-y:auto;background:linear-gradient(160deg,#18130cf7,#100c07f2);border-top:1px solid rgba(255,138,31,.16);border-bottom:1px solid rgba(255,138,31,.2);border-radius:0;padding:14px 16px;backdrop-filter:blur(14px);box-shadow:0 16px 48px #00000073,inset 0 1px #ffffff0a;pointer-events:all;z-index:29;box-sizing:border-box}#toolbar-panel::-webkit-scrollbar{width:3px}#toolbar-panel::-webkit-scrollbar-track{background:#ffffff0a}#toolbar-panel::-webkit-scrollbar-thumb{background:#ff8a1f80;border-radius:2px}.toolbar-panel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:12px;width:100%;align-items:start}.toolbar-section{padding:12px 14px;border:1px solid rgba(129,153,181,.12);background:#ffffff05;border-radius:5px}.toolbar-action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:8px}.hud-action-btn.hud-action-btn-primary{border-color:#ff8a1f85;color:var(--accent-ember);background:#ff8a1f12}.hud-action-btn.hud-action-btn-primary:hover{border-color:#ff8a1fcc;color:var(--text-strong);background:#ff8a1f24}#city-name{font-size:16px;font-family:var(--font-display);font-weight:400;color:var(--text-strong);letter-spacing:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.res-row{font-size:14px;font-family:var(--font-mono);color:var(--text-strong);letter-spacing:.3px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;min-width:0}.toolbar-resource{display:inline-flex;align-items:baseline;gap:8px;padding:5px 12px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(129,153,181,.2)}.toolbar-resource-pwr{background:#ffc8320f;border-color:#ffc83247}.toolbar-resource-label{font-size:11px;color:var(--text-soft);letter-spacing:.08em;white-space:nowrap}.toolbar-resource-sep{font-size:11px;color:#8199b599;line-height:1}.toolbar-resource-value{font-size:14px;color:var(--text-strong);letter-spacing:.02em;white-space:nowrap}.res-row+.res-row{margin-top:3px}.rate-row{font-size:11px;color:var(--text-soft);margin-top:6px;letter-spacing:.2px;border-top:1px solid rgba(255,255,255,.05);padding-top:6px}.toolbar-net{font-size:11px;color:var(--text-soft);font-family:var(--font-mono);white-space:nowrap;padding:4px 8px;border-radius:999px;background:#ff8a1f0f;border:1px solid rgba(255,138,31,.16)}.tile-count{color:var(--text-dim);font-size:10px}#build-menu{position:absolute;bottom:132px;right:14px;width:320px;max-height:70vh;overflow-y:auto;background:linear-gradient(180deg,#16120bf5,#0e0b07f5);border:1px solid rgba(255,138,31,.22);border-radius:4px;padding:14px;pointer-events:all;backdrop-filter:blur(12px);box-shadow:0 20px 46px #00000057,inset 0 1px #ffffff0a;display:none}#build-dock{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 16px);transform:translate(-50%);display:flex;align-items:stretch;gap:10px;padding:10px;border:1px solid rgba(255,138,31,.24);border-radius:999px;background:linear-gradient(180deg,#18140ef0,#0e0b07f5),radial-gradient(circle at top,rgba(255,138,31,.08),transparent 60%);box-shadow:0 22px 50px #00000059,inset 0 1px #ffffff0d;backdrop-filter:blur(14px);pointer-events:all;z-index:60}.build-dock-btn{min-width:108px;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff08;color:var(--text-strong);font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:transform .14s,border-color .14s,background .14s,color .14s}.build-dock-btn:hover{transform:translateY(-1px);border-color:#ff8a1f66;background:#ff8a1f14}.build-dock-btn.active{color:#08111d;border-color:#7df3a8e6;background:linear-gradient(180deg,#7df3a8f5,#4ddfd0eb);box-shadow:0 8px 20px #4ddfd02e}.build-dock-icon{font-size:15px;line-height:1}.build-dock-label{white-space:nowrap}#build-catalog-tray{--catalog-card-height: 368px;position:fixed;left:max(14px,env(safe-area-inset-left,0px) + 14px);right:max(14px,env(safe-area-inset-right,0px) + 14px);bottom:calc(env(safe-area-inset-bottom,0px) + 96px);display:none;flex-direction:column;gap:12px;padding:14px 16px;border:1px solid rgba(255,138,31,.22);border-radius:18px;background:linear-gradient(180deg,#14100af5,#0a0805fa),radial-gradient(circle at top left,rgba(194,90,16,.08),transparent 30%);box-shadow:0 28px 60px #0006,inset 0 1px #ffffff0a;backdrop-filter:blur(14px);pointer-events:all;z-index:55}.build-catalog-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px}.build-catalog-title-wrap{display:flex;flex-direction:column;gap:3px;min-width:132px}.build-catalog-kicker{color:var(--accent-ember);font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.build-catalog-title{color:var(--text-strong);font-family:var(--font-display);font-size:26px;letter-spacing:.08em;text-transform:uppercase}.build-catalog-filter-row{display:flex;align-items:center;gap:8px;overflow-x:auto;padding-bottom:2px}.build-catalog-filter-row::-webkit-scrollbar{height:3px}.build-catalog-filter-row::-webkit-scrollbar-thumb{background:#ff8a1f73}.catalog-filter-btn{flex:0 0 auto;padding:8px 12px;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff08;color:var(--text-soft);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.catalog-filter-btn.active{border-color:#f18ac573;background:#f18ac51f;color:var(--text-strong)}.build-catalog-close{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);border-radius:50%;background:#ffffff0a;color:var(--text-soft);font-size:16px;cursor:pointer}.build-catalog-content{display:flex;align-items:stretch;gap:10px;min-height:var(--catalog-card-height);overflow-x:auto;overflow-y:hidden;padding-bottom:6px}.build-catalog-content::-webkit-scrollbar{height:4px}.build-catalog-content::-webkit-scrollbar-thumb{background:#ff8a1f7a;border-radius:999px}.catalog-card{position:relative;flex:0 0 176px;min-height:var(--catalog-card-height);height:var(--catalog-card-height);display:flex;flex-direction:column;justify-content:space-between;gap:8px;padding:10px;border:1px solid rgba(255,255,255,.1);border-left-width:3px;border-radius:12px;background:#ffffff08;cursor:pointer;overflow:hidden;transition:transform .14s,border-color .14s,background .14s,opacity .14s}.catalog-card:hover:not(.locked):not(.cant-afford):not(.already-built){transform:translateY(-2px);border-color:#fff3;background:#ffffff0d}.catalog-card.selected{background:#ff8a1f1f;border-color:#ff8a1f8c;box-shadow:0 12px 24px #ff8a1f1f}.catalog-card.unbuildable{opacity:.52;filter:saturate(.65) brightness(.85)}.catalog-card.locked{opacity:.68;cursor:not-allowed}.catalog-card.cant-afford{opacity:.82}.catalog-card.already-built{opacity:.72;cursor:default}.catalog-card.locked,.catalog-card.cant-afford,.catalog-card.already-built{filter:saturate(.65) brightness(.85)}.catalog-card-top{display:flex;flex-direction:column;gap:8px}.catalog-card-thumb{position:relative;width:100%;height:96px;flex-shrink:0;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:#0006}.catalog-card-thumb:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,transparent 55%);pointer-events:none}.catalog-card-thumb img{width:100%;height:100%;object-fit:cover;object-position:center;image-rendering:pixelated}.catalog-card-thumb-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:30px}.catalog-card-thumb-overlay{position:absolute;bottom:5px;left:5px;right:5px;display:flex;gap:4px;flex-wrap:wrap;align-items:flex-end}.catalog-card-main{min-width:0;display:flex;flex-direction:column;gap:6px}.catalog-card-title{margin:0;font-family:var(--font-ui);font-size:13px;font-weight:700;line-height:1.2}.catalog-card-purpose{margin:0;min-height:32px;max-height:32px;color:var(--text-soft);font-family:var(--font-ui);font-size:11px;line-height:1.4;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.catalog-card-meta{display:flex;flex-wrap:wrap;gap:4px;padding-top:8px;border-top:1px solid rgba(255,255,255,.07)}.catalog-card-meta .bc-meta-chip,.catalog-card-meta .bc-stat-chip{flex:1 1 calc(50% - 2px);min-height:22px;padding:3px 6px;justify-content:space-between}.catalog-card-status{margin-top:2px;min-height:24px;max-height:24px;font-size:9px;line-height:1.25;color:var(--text-soft);overflow:hidden}#build-placement-bar{position:fixed;left:50%;bottom:calc(env(safe-area-inset-bottom,0px) + 164px);transform:translate(-50%);min-width:340px;max-width:calc(100vw - 28px);display:none;align-items:center;gap:12px;padding:12px 14px;border:1px solid rgba(125,243,168,.24);border-radius:16px;background:linear-gradient(180deg,#0c0a06f7,#080604fc);box-shadow:0 20px 44px #00000057;pointer-events:all;z-index:65}.build-placement-main{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}.build-placement-kicker{color:var(--accent-lime);font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase}.build-placement-name{color:var(--text-strong);font-family:var(--font-ui);font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.build-placement-hint{color:var(--text-soft);font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase}.build-placement-actions{display:flex;align-items:center;gap:8px}.build-placement-confirm,.build-placement-cancel{padding:8px 10px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff0a;color:var(--text-soft);font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer}.build-placement-confirm{border-color:#7df3a859;color:var(--accent-lime);background:#7df3a814}.build-placement-confirm:disabled{opacity:.45;cursor:default}#build-menu::-webkit-scrollbar{width:3px}#build-menu::-webkit-scrollbar-track{background:#ffffff0a}#build-menu::-webkit-scrollbar-thumb{background:#ff8a1f80;border-radius:2px}#menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:9px;border-bottom:1px solid rgba(255,138,31,.18)}#menu-header h2{font-size:12px;font-family:var(--font-mono);color:var(--text-strong);letter-spacing:2px;font-weight:700;text-transform:uppercase}#close-menu{color:var(--text-soft);font-size:16px;cursor:pointer;line-height:1;padding:0 2px;opacity:.85;transition:opacity .1s,color .1s}#close-menu:hover{opacity:1;color:#fff}#tile-info{font-size:12px;color:var(--text-soft);margin-bottom:10px;letter-spacing:1px;text-transform:uppercase;font-family:var(--font-mono)}.bcard{background:#ffffff05;border:1px solid rgba(129,153,181,.16);border-left-width:3px;border-radius:4px;padding:9px 11px;margin-bottom:8px;cursor:pointer;transition:border-color .12s,background .12s,transform .12s}.bcard:not(.locked):hover{background:#ffffff0d;border-color:#ffffff38;transform:translateY(-1px)}.bcard.locked{opacity:.72;cursor:not-allowed}.bcard.cant-afford{opacity:.82}.bcard.already-built{opacity:.7;cursor:default}.bcard-row{display:flex;gap:10px;align-items:flex-start}.bcard-sprite{width:68px;height:68px;object-fit:cover;object-position:top;flex-shrink:0;border-radius:7px;background:#00000073;border:1px solid rgba(255,255,255,.08);image-rendering:pixelated}.bcard-sprite-fallback{display:flex;align-items:center;justify-content:center;border:1px solid;font-family:var(--font-display);font-size:22px;background:#0009}.bcard-info{flex:1;min-width:0}.bcard h3{font-size:14px;font-weight:600;margin:0;letter-spacing:0px;font-family:var(--font-ui)}.bcard-title-row{display:flex;align-items:flex-start;gap:8px;justify-content:space-between;margin-bottom:4px}.bcard-tags{display:flex;gap:4px;align-items:center;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}.bc-desc{font-size:12px;color:var(--text-soft);margin-bottom:5px;line-height:1.45;font-family:var(--font-ui)}.tier-badge{color:var(--text-soft);font-size:9px;font-family:var(--font-mono);font-weight:600;text-transform:uppercase;letter-spacing:.8px;padding:2px 6px;border-radius:999px;border:1px solid rgba(129,153,181,.3);background:#0a0805bf;backdrop-filter:blur(4px)}.bc-focus-row{margin-bottom:2px}.role-tag{display:inline-flex;align-items:center;align-self:flex-start;font-size:10px;padding:3px 7px;border-radius:999px;font-weight:700;letter-spacing:.02em;font-family:var(--font-ui);line-height:1}.role-income{background:#ffd2002e;color:#ffd200}.role-housing{background:#68d4f524;color:#68d4f5}.role-data{background:#00ff4124;color:#00ff41}.role-mixed{background:#e91e8c24;color:#e91e8c}.role-aura{background:#7df3a824;color:#7df3a8}.role-utility{background:#6464962e;color:#99c}.owned-badge{font-size:9px;padding:2px 6px;border-radius:999px;background:#0a0805bf;border:1px solid rgba(255,255,255,.18);color:var(--text-soft);font-family:var(--font-mono);letter-spacing:.4px;backdrop-filter:blur(4px)}.unique-badge{background:#ffc80026;color:#ffc800;border-color:#ffc80059}.built-badge{background:#00ff4126;color:#00ff41;font-weight:700}.footprint-badge{font-size:9px;padding:2px 6px;border-radius:999px;background:#0a0805bf;border:1px solid rgba(255,150,0,.4);color:#f90;font-weight:700;font-family:var(--font-mono);letter-spacing:.4px;backdrop-filter:blur(4px)}.bc-meta-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.bc-meta-chip{display:inline-flex;align-items:baseline;gap:4px;padding:3px 6px;border-radius:5px;background:#f5c96b14;border:1px solid rgba(245,201,107,.15);font-family:var(--font-mono)}.bc-meta-label{font-size:9px;color:#f5c96bb8;text-transform:uppercase;letter-spacing:.7px}.bc-meta-value{font-size:11px;color:var(--accent-gold);font-variant-numeric:tabular-nums;white-space:nowrap}.bc-out{display:flex;flex-wrap:wrap;gap:6px}.bc-stat-chip{display:inline-flex;align-items:baseline;gap:4px;padding:3px 6px;border-radius:5px;background:#68d4f514;border:1px solid rgba(104,212,245,.16);font-family:var(--font-mono)}.bc-stat-chip-net-positive{background:#7df3a814;border-color:#7df3a82e}.bc-stat-chip-net-negative{background:#ef7d7d14;border-color:#ef7d7d2e}.bc-stat-label{font-size:9px;color:var(--text-dim);text-transform:uppercase;letter-spacing:.7px}.bc-stat-value{font-size:11px;color:var(--text-strong);font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap}.bc-stat-chip-net-positive .bc-stat-label,.bc-stat-chip-net-positive .bc-stat-value{color:var(--accent-lime)}.bc-stat-chip-net-negative .bc-stat-label,.bc-stat-chip-net-negative .bc-stat-value{color:var(--accent-red)}.bc-lock{font-size:11px;color:var(--text-soft);margin-top:4px;padding-top:4px;border-top:1px solid rgba(129,153,181,.16);font-family:var(--font-ui)}.bc-noafford{font-size:12px;color:var(--accent-red);margin-top:3px}.binfo-sprite{display:block;width:100%;height:110px;object-fit:contain;border-radius:9px;background:#0006;border:1px solid rgba(255,255,255,.07);margin-bottom:10px}.binfo{font-size:13px;font-family:var(--font-ui);color:var(--text);line-height:1.65;padding:4px 0}.binfo strong{color:var(--text-strong);font-size:15px}.status-complete{color:var(--accent-lime)}.status-constructing{color:var(--accent-gold)}.status-awaiting{color:#f2a25b}.flavour{color:var(--text-soft);font-style:italic;margin-top:7px;display:block;font-size:12px;line-height:1.5;font-family:var(--font-ui)}.quirk{font-style:normal;color:var(--text-dim);margin-top:3px}.muted{color:var(--text-soft)}#notifs{position:absolute;bottom:70px;left:14px;display:flex;flex-direction:column-reverse;gap:5px;max-width:340px;pointer-events:none}.toast{background:#0c0a06f0;border:1px solid rgba(125,243,168,.35);border-left:3px solid var(--accent-lime);padding:9px 14px;font-size:13px;font-family:var(--font-ui);font-weight:500;color:var(--text-strong);border-radius:4px;box-shadow:0 12px 30px #00000040;animation:toastIn .22s ease;line-height:1.4}.toast.pink{border-color:#f18ac561;border-left-color:var(--accent-magenta)}.toast.yellow{border-color:#f5c96b57;border-left-color:var(--accent-gold)}@keyframes toastIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}#speed-bar{display:flex;align-items:stretch;gap:6px;flex-wrap:wrap;pointer-events:all;width:100%}#speed-btn.speed-paused{color:var(--text-dim);border-color:#8199b51f;opacity:.65}#coords{position:absolute;bottom:14px;left:14px;font-size:12px;color:var(--text-soft);letter-spacing:1px;font-family:var(--font-mono)}#reset-btn{background:#0c0a06e0;border:1px dashed rgba(239,125,125,.42);color:#d5a6a6;padding:5px 11px;font-size:13px;font-family:var(--font-mono);cursor:pointer;border-radius:3px;letter-spacing:.6px;transition:border-color .1s,color .1s}#reset-btn:hover{border-color:var(--accent-red);color:#ffe5e5}#reset-confirm{position:fixed;inset:0;background:#000000e0;display:flex;align-items:center;justify-content:center;z-index:200}.reset-box{background:linear-gradient(180deg,#100b0ff5,#0a080bf5);border:1px solid rgba(239,125,125,.42);padding:28px 32px;max-width:380px;width:90%;border-radius:4px;box-shadow:0 24px 50px #00000057}.reset-title{color:#ffd3d3;font-size:17px;letter-spacing:3px;margin-bottom:12px}.reset-body{font-size:14px;color:var(--text);line-height:1.7;margin-bottom:20px}.reset-actions{display:flex;gap:10px}.reset-actions button{font-family:var(--font-mono);font-size:13px;padding:7px 16px;cursor:pointer;border-radius:3px;letter-spacing:1px}#reset-yes{background:transparent;border:1px solid #cc4444;color:#c44;transition:background .1s,box-shadow .1s}#reset-yes:hover{background:#cc44441a;box-shadow:0 0 10px #cc44444d}#reset-no{background:transparent;border:1px solid rgba(129,153,181,.32);color:var(--text-soft);transition:border-color .1s,color .1s}#reset-no:hover{border-color:var(--border-strong);color:var(--text-strong)}.hud-action-btn{display:inline-flex;align-items:center;justify-content:center;height:32px;padding:0 12px;box-sizing:border-box;background:#0c0a06e0;border:1px solid var(--border);color:var(--text-soft);font-size:12px;line-height:1;font-family:var(--font-mono);cursor:pointer;border-radius:3px;letter-spacing:.6px;transition:border-color .1s,color .1s}.hud-action-btn:hover{border-color:var(--border-strong);color:var(--text-strong)}.hud-icon-btn{width:32px;min-width:32px;padding:0;font-size:15px;letter-spacing:0}.side-panel{position:absolute;top:calc(var(--toolbar-offset) + 18px);left:14px;width:280px;max-height:calc(100vh - var(--toolbar-offset) - 32px);overflow-y:auto;background:linear-gradient(180deg,#16120bf5,#0e0b07f5);border:1px solid rgba(255,138,31,.28);border-radius:4px;padding:14px;pointer-events:all;backdrop-filter:blur(12px);box-shadow:0 20px 46px #00000057}#stats-btn,#budget-btn,#obj-btn{flex:0 0 auto;justify-content:center}#road-btn{min-width:60px}.side-panel::-webkit-scrollbar{width:3px}.side-panel::-webkit-scrollbar-track{background:#ffffff0a}.side-panel::-webkit-scrollbar-thumb{background:#ff8a1f80;border-radius:2px}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,138,31,.18)}.panel-title{font-size:14px;color:var(--text-strong);letter-spacing:2.4px;font-family:var(--font-mono);font-weight:700}.panel-close{color:var(--text-soft);font-size:16px;cursor:pointer;line-height:1;padding:0 2px;opacity:.85;transition:opacity .1s,color .1s}.panel-close:hover{opacity:1;color:#fff}.stats-section{margin-bottom:14px}.stats-label{font-size:11px;color:var(--accent-ember);letter-spacing:2px;font-family:var(--font-mono);margin-bottom:6px;padding-bottom:4px;border-bottom:1px solid rgba(255,138,31,.1)}.stats-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:var(--text);padding:2px 0;gap:8px}.stats-row span:last-child{color:var(--text-strong);text-align:right;font-family:var(--font-mono);font-size:13px}.stat-green{color:var(--accent-lime)!important}.stat-red{color:var(--accent-red)!important}.stat-yellow{color:var(--accent-gold)!important}.budget-net{border-top:1px solid var(--border);margin-top:6px;padding-top:6px;font-weight:600}.budget-header-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim);letter-spacing:1px;margin-bottom:4px;padding-bottom:3px;border-bottom:1px solid rgba(255,255,255,.04)}.demolish-btn{background:transparent;border:1px solid rgba(239,125,125,.42);color:#d5a6a6;padding:6px 10px;font-size:13px;font-family:var(--font-mono);cursor:pointer;border-radius:3px;letter-spacing:.8px;transition:border-color .1s,color .1s,background .1s;width:100%}.demolish-btn:hover{border-color:var(--accent-red);color:#ffe5e5;background:#cc444414}#hack-btn{background:#0c0a06e0;border:1px dashed rgba(125,243,168,.52);color:var(--accent-lime);padding:5px 11px;font-size:13px;font-family:var(--font-mono);cursor:pointer;border-radius:3px;letter-spacing:.6px;transition:border-color .1s,color .1s,box-shadow .1s}#hack-btn:hover{border-color:var(--accent-lime);color:#e2ffe9;box-shadow:0 8px 20px #7df3a824}.toast.red{border-color:#ef7d7d73;border-left-color:var(--accent-red)}#biome-modal{position:fixed;inset:0;background:#000000f7;display:flex;align-items:center;justify-content:center;z-index:300}.biome-box{background:linear-gradient(180deg,#120f09f5,#0c0a06f5);border:1px solid rgba(241,138,197,.28);padding:28px 28px 22px;max-width:680px;width:95%;border-radius:4px;box-shadow:0 24px 56px #0000005c}.biome-header{margin-bottom:20px;text-align:center}.biome-header h2{font-family:var(--font-mono);font-weight:400;color:#f9ecf4;font-size:19px;letter-spacing:4px;margin-bottom:4px}.biome-subtitle{font-family:var(--font-mono);font-size:12px;color:var(--text-soft);letter-spacing:3px}.biome-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.biome-card{border:1px solid color-mix(in srgb,var(--accent, #334455) 38%,rgba(255,255,255,.05));border-radius:4px;cursor:pointer;padding:10px;transition:background .12s,box-shadow .12s;background:#ffffff05}.biome-card:hover{background:#ffffff0a;box-shadow:0 0 16px color-mix(in srgb,var(--accent, #334455) 40%,transparent)}.biome-canvas-wrap{position:relative;margin-bottom:8px}.biome-canvas{display:block;width:100%;height:auto;border:1px solid rgba(255,255,255,.08);image-rendering:pixelated;border-radius:4px}.biome-beaten-badge{position:absolute;top:6px;right:6px;background:#000000c7;border:1px solid var(--accent);color:var(--accent);font-family:var(--font-mono);font-size:9px;letter-spacing:2px;padding:2px 6px;border-radius:2px;pointer-events:none}.biome-card--beaten{border-color:color-mix(in srgb,var(--accent, #334455) 60%,rgba(255,255,255,.1))}.biome-label{font-size:12px;color:var(--accent, #9fb7d0);letter-spacing:2px;margin-bottom:2px;font-family:var(--font-mono)}.biome-desc{font-family:var(--font-mono);font-size:9px;color:#4a5a6a;letter-spacing:.08em;margin-bottom:4px;line-height:1.4}.biome-name{font-family:var(--font-mono);font-size:15px;color:var(--text-strong);letter-spacing:.5px}.biome-seed{font-family:var(--font-mono);font-size:10px;color:#3a4a5a;letter-spacing:.18em;margin-top:2px}.biome-footer{text-align:center}.biome-random-btn{background:transparent;border:1px solid rgba(129,153,181,.32);color:var(--text-soft);padding:7px 22px;font-family:var(--font-mono);font-size:13px;cursor:pointer;letter-spacing:2px;border-radius:3px;transition:border-color .1s,color .1s}.biome-random-btn:hover{border-color:var(--accent-magenta);color:var(--text-strong)}#api-modal{position:fixed;inset:0;background:#000000f7;display:flex;align-items:center;justify-content:center;z-index:100}.modal-box{background:linear-gradient(180deg,#120f09f7,#0c0a06f5);border:1px solid rgba(241,138,197,.28);padding:32px 36px;max-width:420px;width:92%;border-radius:4px;box-shadow:0 24px 56px #0000005c}.modal-box h2{color:#f9ecf4;font-size:19px;letter-spacing:3px;margin-bottom:5px}.modal-box .subtitle{font-size:12px;color:var(--text-soft);letter-spacing:2px;margin-bottom:18px;font-family:var(--font-mono)}.modal-box p{font-size:14px;color:var(--text);line-height:1.75;margin-bottom:18px}.modal-box p em{color:#ffe0ef;font-style:normal}.modal-box input[type=password]{width:100%;background:#080604f0;border:1px solid rgba(129,153,181,.28);color:var(--text-strong);padding:9px 10px;font-family:var(--font-mono);font-size:16px;margin-bottom:14px;border-radius:4px;outline:none;transition:border-color .1s,box-shadow .1s}.modal-box input:focus{border-color:#68d4f58f;box-shadow:0 0 0 3px #68d4f524}.modal-btn{background:linear-gradient(180deg,#f3a7d4,#e07fbc);border:none;color:#180d17;padding:9px 22px;font-family:var(--font-mono);font-size:14px;font-weight:700;cursor:pointer;letter-spacing:1px;border-radius:3px;margin-right:10px;transition:box-shadow .1s}.modal-btn:hover{box-shadow:0 12px 24px #e07fbc47}.modal-skip{background:transparent;border:1px solid rgba(129,153,181,.28);color:var(--text-soft);padding:9px 16px;font-family:var(--font-mono);font-size:14px;cursor:pointer;border-radius:3px;letter-spacing:1px;transition:border-color .1s,color .1s}.modal-skip:hover{border-color:var(--border-strong);color:var(--text-strong)}.hud-save-btn{border-color:#ff8a1f59!important;color:var(--accent-ember)!important}.hud-save-btn:hover{border-color:var(--accent-ember)!important;color:var(--text-strong)!important;box-shadow:0 0 10px #ff8a1f2e}.hud-save-btn.saved{color:var(--accent-lime)!important;border-color:#7df3a880!important}#last-saved-row{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.5px;margin-top:5px;min-height:14px}#hover-info-row{font-size:11px;color:var(--accent-ember);font-family:var(--font-mono);letter-spacing:.5px;margin-top:3px;opacity:.8}#road-btn{border-color:var(--border);color:var(--text-soft);background:#0c0a06e0}#road-btn:hover{border-color:var(--border-strong);color:var(--text-strong)}#road-btn.active{background:#f5c96b24;border-color:var(--accent-gold);color:#fff2ce;box-shadow:0 0 14px #f5c96b40}#coords.road-hint{color:var(--accent-gold)}.hud-icon-btn:hover{border-color:#ff8a1f6b;color:var(--accent-ember);box-shadow:0 0 10px #ff8a1f1f}#settings-modal{position:fixed;inset:0;z-index:160;display:flex;align-items:center;justify-content:center;pointer-events:all}#settings-overlay{position:absolute;inset:0;background:#000c;backdrop-filter:blur(2px)}.settings-box{position:relative;z-index:1;background:linear-gradient(180deg,#16120bfa,#0e0b07fa);border:1px solid rgba(255,138,31,.22);border-radius:4px;padding:0;width:min(500px,96vw);max-width:96vw;max-height:92vh;display:flex;flex-direction:column;box-shadow:0 28px 60px #0000006b,0 0 0 1px #ff8a1f0f;overflow:hidden}.settings-scroll{overflow-y:auto;flex:1;padding:14px 16px 10px;scrollbar-width:thin;scrollbar-color:rgba(255,138,31,.25) transparent}.settings-tabs{display:flex;padding:0 16px;border-bottom:1px solid rgba(255,138,31,.14);background:#ff8a1f05;overflow-x:auto;scrollbar-width:none}.settings-tabs::-webkit-scrollbar{display:none}.settings-tab{background:none;border:none;border-bottom:2px solid transparent;color:var(--text-soft);font-family:var(--font-mono);font-size:11px;letter-spacing:2px;padding:11px 16px 10px;cursor:pointer;transition:color .15s,border-color .15s;white-space:nowrap;flex-shrink:0}.settings-tab:hover{color:var(--text)}.settings-tab.active{color:var(--accent-ember);border-bottom-color:var(--accent-ember)}.settings-tab-panel{display:flex;flex-direction:column;gap:20px}.settings-tab-panel[hidden]{display:none}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px 12px;border-bottom:1px solid rgba(255,138,31,.14);background:#ff8a1f0a}.settings-title{font-size:15px;letter-spacing:3px;color:var(--accent-ember);font-family:var(--font-mono)}.settings-close{cursor:pointer;color:var(--text-soft);font-size:15px;line-height:1;padding:2px 4px;border-radius:2px;transition:color .1s}.settings-close:hover{color:var(--text-strong)}.settings-group{display:flex;flex-direction:column;gap:8px}.settings-group-label{font-size:10px;letter-spacing:3px;color:var(--text-dim);font-family:var(--font-mono);display:flex;align-items:center;gap:10px;padding-bottom:2px}.settings-group-label:after{content:"";flex:1;height:1px;background:#8199b524}.settings-label{font-size:11px;letter-spacing:2.5px;color:var(--text-soft);font-family:var(--font-mono);margin-bottom:6px}.settings-action-btn{display:flex;align-items:center;gap:8px;background:#ffffff08;border:1px solid rgba(129,153,181,.2);color:var(--text);padding:9px 12px;font-size:13px;font-family:var(--font-mono);cursor:pointer;border-radius:3px;letter-spacing:.8px;text-align:left;transition:background .1s,border-color .1s,color .1s,box-shadow .1s;width:100%;box-sizing:border-box;text-decoration:none}.settings-action-btn:hover{background:#ffffff0f;border-color:var(--border-strong);color:var(--text-strong)}.weather-row{display:flex;gap:6px;flex-wrap:wrap}.weather-row .weather-btn{width:auto;flex:1;text-align:center;justify-content:center}.weather-row .time-btn{flex:1 1 calc(50% - 3px);justify-content:center}.weather-btn.active{border-color:#ff8a1fa6;color:var(--accent-ember);background:#ff8a1f14}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;font-family:var(--font-mono);font-size:13px;color:var(--text);letter-spacing:.5px}.settings-toggle-row .settings-action-btn{width:auto;padding:5px 16px;font-size:11px;letter-spacing:1.5px;flex-shrink:0;min-width:52px;text-align:center;justify-content:center}.settings-pair-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.settings-action-btn.active{border-color:#ff8a1fa6;color:var(--accent-ember);background:#ff8a1f14;box-shadow:0 0 14px #ff8a1f1f}.settings-action-cyan{border-color:#ff8a1f47;color:var(--accent-ember)}.settings-action-cyan:hover{border-color:#ff8a1f99;background:#ff8a1f12;color:var(--text-strong);box-shadow:0 0 14px #ff8a1f1f}.settings-action-hero{padding:11px 12px;font-size:14px;letter-spacing:1px}.settings-action-gold{border-color:#f5c96b3d;color:var(--accent-gold)}.settings-action-gold:hover{border-color:#f5c96b8c;background:#f5c96b0f;color:#fff2ce;box-shadow:0 0 12px #f5c96b1a}.settings-action-danger{border-color:#ef7d7d3d;color:#d5a6a6}.settings-action-danger:hover{border-color:#ef7d7d8c;background:#ef7d7d0f;color:#ffe5e5;box-shadow:0 0 12px #ef7d7d1a}.settings-note{font-size:10px;letter-spacing:.5px;opacity:.6;font-family:var(--font-mono)}.controls-list{display:flex;flex-direction:column;gap:4px}.controls-row{display:grid;grid-template-columns:110px 1fr;align-items:baseline;gap:8px;font-family:var(--font-mono);font-size:11px;line-height:1.5}.controls-key{color:var(--accent-ember);letter-spacing:1px;opacity:.9;white-space:nowrap}.controls-desc{color:var(--text-soft);letter-spacing:.4px}.controls-divider{height:1px;background:#8199b51a;margin:3px 0}.settings-footer{padding:9px 16px;font-size:10px;letter-spacing:2px;color:var(--text-dim);font-family:var(--font-mono);text-align:center;border-top:1px solid rgba(129,153,181,.09)}#credits-modal{position:fixed;inset:0;z-index:170;display:flex;align-items:center;justify-content:center;pointer-events:all}#credits-overlay{position:absolute;inset:0;background:#000000d1;backdrop-filter:blur(3px)}#credits-box{position:relative;z-index:1;width:min(640px,94vw);max-height:88vh;overflow:auto;background:linear-gradient(180deg,#16120bfa,#0e0b07fa);border:1px solid rgba(255,138,31,.22);border-radius:6px;box-shadow:0 28px 60px #0000006b,0 0 0 1px #ff8a1f0f}#credits-content{padding:16px;display:flex;flex-direction:column;gap:14px}.credits-section{padding:14px 16px;border:1px solid rgba(129,153,181,.12);background:#ffffff05}.credits-section p,.credits-section li{font-size:13px;color:var(--text);line-height:1.7}.credits-section ul{margin:8px 0 0;padding-left:18px}.credits-link{color:var(--accent-ember);text-decoration:none}.credits-link:hover{color:var(--text-strong)}@media (max-width: 560px),(max-height: 560px){.settings-scroll{padding:10px 12px 8px}.settings-tab-panel{gap:14px}.settings-group{gap:6px}.settings-header{padding:10px 14px}}.tier-filter-row{display:flex;gap:4px;margin-bottom:10px}.tier-filter-row{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:8px}.tier-filter-btn{background:transparent;border:1px solid rgba(129,153,181,.22);color:var(--text-soft);padding:4px 10px;font-size:11px;font-family:var(--font-ui);font-weight:600;cursor:pointer;border-radius:4px;letter-spacing:.3px;text-transform:uppercase;transition:background .1s,border-color .1s,color .1s}.tier-filter-btn:hover{border-color:var(--border-strong);color:var(--text-strong)}.tier-filter-btn.active{background:#ff8a1f1f;border-color:#ff8a1f80;color:var(--accent-ember)}.tier-filter-btn[data-category=decoration].active{background:#7df3a81f;border-color:#7df3a880;color:var(--accent-lime)}.building-search-input{width:100%;box-sizing:border-box;background:#ffffff0a;border:1px solid rgba(129,153,181,.18);border-radius:4px;color:var(--text);font-family:var(--font-ui);font-size:12px;padding:7px 10px;margin:0 0 8px;outline:none}.building-search-input:focus{border-color:#ff8a1f66;background:#ff8a1f0a}.building-search-input::placeholder{color:var(--text-dim)}.hud-clock{font-family:var(--font-mono);font-size:11px;color:var(--text-dim);letter-spacing:.5px;white-space:nowrap;margin-left:auto;flex-shrink:0}.build-progress-wrap{margin:7px 0 4px}.build-progress-label{font-size:11px;color:var(--text-soft);font-family:var(--font-mono);margin-bottom:3px;display:flex;justify-content:space-between}.build-progress-track{height:6px;background:#ffffff0f;border:1px solid rgba(129,153,181,.18);border-radius:2px;overflow:hidden}.build-progress-fill{height:100%;background:linear-gradient(90deg,#f5c96b,#f18ac5);border-radius:2px;transition:width 1s linear}.term-divider{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:2px;margin:10px 0 6px;border-top:1px solid rgba(129,153,181,.12);padding-top:7px}.upgrade-dots{display:inline-flex;gap:4px;vertical-align:middle;margin-left:8px}.upgrade-dot{width:9px;height:9px;border-radius:2px;border:1px solid rgba(129,153,181,.28);background:#8199b50f;transition:background .2s,border-color .2s,box-shadow .2s}.upgrade-dot.filled{background:var(--accent-gold);border-color:var(--accent-gold);box-shadow:0 0 5px #f5c96b8c}.upgrade-panel{margin-top:12px;padding:10px 12px;border-radius:4px;background:#f5c96b0d;border:1px solid rgba(245,201,107,.2)}.upgrade-panel .upgrade-level-label{font-size:11px;font-family:var(--font-mono);color:var(--accent-gold);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px}.upgrade-panel .upgrade-mult{font-size:13px;color:var(--accent-cyan);margin-bottom:6px}.upgrade-panel .bc-noafford{font-size:12px;margin-top:4px}#net-display{font-size:13px;font-family:var(--font-mono);letter-spacing:.04em}.stat-eff{color:var(--text-soft)!important}.stats-row.budget-3{gap:4px}.stats-row.budget-3 span:first-child{flex:1}.stats-row.budget-3 span:nth-child(2),.stats-row.budget-3 span:nth-child(3){min-width:52px;text-align:right}.stats-row.bld-4{gap:0}.stats-row.bld-4 span:first-child{flex:1;min-width:0}.stats-row.bld-4 span:nth-child(2),.stats-row.bld-4 span:nth-child(3),.stats-row.bld-4 span:nth-child(4){width:54px;flex-shrink:0;text-align:right}.stats-row.bld-total{border-top:1px solid rgba(255,255,255,.08);margin-top:2px;padding-top:4px}.stat-dim{color:var(--text-dim)!important}#event-badge{display:flex;align-items:center;justify-content:space-between;margin:6px 0 4px;padding:5px 9px;border-radius:3px;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.04em;border:1px solid currentColor;animation:eventPulse 2s ease-in-out infinite}.ev-name{flex:1}.ev-timer{margin-left:10px;opacity:.8;font-size:10px}.event-gold{color:var(--accent-gold);border-color:#f5c96b66;background:#f5c96b14}.event-cyan{color:var(--accent-ember);border-color:#ff8a1f66;background:#ff8a1f14}.event-pink{color:var(--accent-magenta);border-color:#f18ac566;background:#f18ac514}.event-green{color:var(--accent-lime);border-color:#7df3a866;background:#7df3a814}.event-red{color:var(--accent-red);border-color:#ef7d7d66;background:#ef7d7d14}@keyframes eventPulse{0%,to{opacity:1}50%{opacity:.75}}.income-float{position:fixed;font-family:var(--font-display);font-size:15px;pointer-events:none;z-index:25;transform:translate(-50%);animation:incomeFloat 1.6s ease-out forwards;white-space:nowrap}.if-cr{color:var(--accent-gold);text-shadow:0 0 8px rgba(245,201,107,.7)}.if-pop{color:var(--accent-lime);text-shadow:0 0 8px rgba(125,243,168,.7)}.if-data{color:var(--accent-ember);text-shadow:0 0 8px rgba(255,138,31,.7)}@keyframes incomeFloat{0%{opacity:0;transform:translate(-50%) translateY(0)}15%{opacity:1}to{opacity:0;transform:translate(-50%) translateY(-52px)}}.obj-card{padding:10px 12px;margin-bottom:8px;background:#ffffff08;border:1px solid var(--border);border-radius:3px}.obj-label{font-size:12px;color:var(--text-strong);margin-bottom:6px;font-family:var(--font-mono)}.obj-bar-wrap{height:3px;background:#ffffff14;border-radius:2px;overflow:hidden;margin-bottom:5px}.obj-bar{height:100%;background:linear-gradient(90deg,var(--accent-ember),var(--accent-lime));border-radius:2px;transition:width .4s ease;min-width:2px}.obj-meta{display:flex;justify-content:space-between;font-size:10px;font-family:var(--font-mono)}.obj-pct{color:var(--text-dim)}#mayor-label{font-family:var(--font-mono);font-size:9px;color:#607090;letter-spacing:.15em;margin-bottom:1px}#factions-row{margin-top:5px;display:flex;flex-direction:column;gap:3px;pointer-events:all}.faction-bar-row{display:flex;align-items:center;gap:6px;padding:2px 4px;border-radius:2px;transition:background .3s ease}.faction-bar-row.faction-warning{background:#ef7d7d1a;animation:faction-pulse 1.2s ease-in-out infinite}@keyframes faction-pulse{0%,to{background:#ef7d7d14}50%{background:#ef7d7d33}}.faction-label{font-family:var(--font-mono);font-size:11px;color:var(--text-soft);min-width:34px;letter-spacing:.08em}.faction-bar-wrap{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.faction-bar-fill{height:100%;width:50%;border-radius:2px;transition:width 1s ease,background .5s ease}.faction-val{font-family:var(--font-mono);font-size:11px;color:var(--text-soft);min-width:22px;text-align:right}#enforcer-btn{font-family:var(--font-mono);font-size:10px;padding:2px 7px;margin-top:2px;background:#ff3c3c26;border:1px solid rgba(255,80,80,.5);color:#ff8080;border-radius:2px;cursor:pointer;white-space:nowrap}#enforcer-btn:hover{background:#ff3c3c4d;color:#fff}#enforcer-btn:disabled{background:#ff3c3c14;border-color:#ff505038;color:#ff808080;cursor:not-allowed}#toolbar-factions{display:flex;flex-direction:row;align-items:center;gap:8px;border-left:1px solid rgba(255,138,31,.14);padding-left:10px;flex-shrink:0;flex-wrap:wrap}.tb-faction{display:flex;align-items:center;gap:4px;padding:2px 6px;border-radius:3px;transition:background .3s ease;background:#ffffff06}.tb-faction.faction-warning{background:#ef7d7d1f;animation:faction-pulse 1.2s ease-in-out infinite}.tb-faction-dot{font-size:11px;line-height:1;transition:color .5s ease}.tb-faction-label{font-family:var(--font-mono);font-size:10px;color:var(--text-soft);letter-spacing:.08em}.tb-faction-val{font-family:var(--font-mono);font-size:12px;color:var(--text-strong);min-width:18px;text-align:right}@media (max-width: 1400px) and (min-width: 761px){:root{--toolbar-offset: 112px}#toolbar{grid-template-columns:1fr auto;grid-template-areas:"brand actions" "readouts readouts";gap:10px 14px;padding:10px 16px 12px}.toolbar-brand{grid-area:brand}.toolbar-readouts{grid-area:readouts;justify-content:flex-start;row-gap:8px}.toolbar-actions{grid-area:actions;justify-content:flex-end;flex-wrap:wrap}}#faction-loss-screen{position:fixed;inset:0;background:#000000e0;backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9000;pointer-events:all}#faction-loss-modal{background:#080c14;border:1px solid rgba(239,125,125,.35);border-radius:4px;padding:36px 40px;max-width:420px;width:90vw;text-align:center;font-family:var(--font-mono)}#faction-loss-art{width:100%;max-height:240px;object-fit:cover;border-radius:3px;margin-bottom:20px;display:block}#faction-loss-tag{font-size:10px;color:var(--accent-red);letter-spacing:.2em;margin-bottom:16px}#faction-loss-faction{font-size:13px;color:#607090;letter-spacing:.12em;margin-bottom:8px}#faction-loss-title{font-family:var(--font-display);font-size:clamp(1.4rem,5vw,2rem);color:var(--accent-red);letter-spacing:.08em;margin-bottom:18px;line-height:1.2}#faction-loss-body{font-size:12px;color:#8090a8;line-height:1.75;margin-bottom:28px}#faction-loss-restart{font-family:var(--font-mono);font-size:13px;padding:10px 28px;background:#ef7d7d1f;border:1px solid rgba(239,125,125,.45);color:var(--accent-red);border-radius:3px;cursor:pointer;letter-spacing:.12em}#faction-loss-restart:hover{background:#ef7d7d40;color:#fff}#win-share,#share-prompt-action,#share-prompt-dismiss{font-family:var(--font-mono);font-size:13px;padding:10px 16px;border-radius:3px;cursor:pointer;letter-spacing:.08em}#win-share,#share-prompt-action{background:#ff8a1f14;border:1px solid rgba(255,138,31,.45);color:var(--accent-ember)}#win-share:hover,#share-prompt-action:hover{background:#ff8a1f2e;color:var(--text-strong)}#share-prompt-dismiss{background:transparent;border:1px solid rgba(129,153,181,.32);color:var(--text-soft)}#share-prompt-dismiss:hover{border-color:var(--border-strong);color:var(--text-strong)}#share-prompt-modal{position:fixed;inset:0;z-index:9050;background:#000000c2;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;pointer-events:all}#share-prompt-box{width:min(460px,92vw);padding:28px 30px;border-radius:6px;background:linear-gradient(180deg,#16120bfc,#0e0b07fc);border:1px solid rgba(255,138,31,.28);box-shadow:0 0 60px #ff8a1f24,0 28px 58px #00000075}#share-prompt-tag{font-size:10px;letter-spacing:.22em;color:var(--accent-ember);margin-bottom:12px}#share-prompt-title{font-family:var(--font-display);font-size:clamp(1.5rem,5vw,2.2rem);color:#fff;letter-spacing:.06em;margin-bottom:10px}#share-prompt-body{font-size:13px;color:var(--text-soft);line-height:1.75;margin-bottom:18px}#share-prompt-actions{display:flex;gap:10px;flex-wrap:wrap}#event-card-overlay{position:fixed;inset:0;background:#000000c2;backdrop-filter:blur(3px);z-index:900;display:flex;align-items:center;justify-content:center;pointer-events:all}#event-card-modal{background:linear-gradient(180deg,#16120bfc,#0e0b07fc);border:1px solid rgba(255,138,31,.3);border-top:3px solid var(--accent-ember);border-radius:6px;padding:0;max-width:560px;width:92%;box-shadow:0 0 60px #ff8a1f26,0 32px 64px #0000008c;font-family:var(--font-mono);overflow:hidden;display:flex;flex-direction:row;align-items:stretch}#event-card-content{flex:1;display:flex;flex-direction:column;min-width:0;padding-bottom:20px}#event-card-title{font-size:14px;color:var(--accent-ember);font-weight:700;margin:18px 20px 12px;letter-spacing:.05em;border-bottom:1px solid rgba(255,138,31,.18);padding-bottom:10px}#event-card-body{font-size:13px;color:var(--text-strong);line-height:1.65;margin:0 20px 20px;white-space:pre-line;flex:1}#event-card-outcome{margin:0 20px 18px;padding:14px 16px;border:1px solid rgba(125,243,168,.24);background:#7df3a814;border-radius:6px}#event-card-outcome-label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-lime);margin-bottom:8px}#event-card-outcome-text{font-size:12px;line-height:1.55;color:var(--text-strong)}#event-card-outcome-summary{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.event-outcome-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:var(--text-strong);font-size:10px;letter-spacing:.04em;text-transform:uppercase}#event-card-choices{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 20px}#event-card-actions{margin:0 20px}.event-choice-intent{font-size:10px;opacity:.82;line-height:1.35}.event-choice-btn{font-family:var(--font-mono);font-size:12px;padding:10px 12px;border-radius:3px;cursor:pointer;text-align:left;line-height:1.4;transition:background .15s;display:flex;flex-direction:column;gap:5px}.event-choice-btn:first-child{background:#ff8a1f0f;border:1px solid rgba(255,138,31,.35);color:var(--accent-ember)}.event-choice-btn:first-child:hover{background:#ff8a1f2e;border-color:var(--accent-ember);color:var(--text-strong)}.event-choice-btn:last-child{background:#f5c96b0f;border:1px solid rgba(245,201,107,.35);color:var(--accent-gold)}.event-choice-btn:last-child:hover{background:#f5c96b2e;border-color:var(--accent-gold);color:#fff}.choice-label{font-size:12px;font-weight:600;letter-spacing:.04em}.choice-flavor{font-size:10px;opacity:.7;line-height:1.3}.obj-reward{color:var(--accent-gold)}@media (max-width: 480px){:root{--toolbar-offset: 156px}#hud{left:0;right:0;top:0;width:100vw}#toolbar{grid-template-columns:1fr;align-items:start;gap:8px;padding:10px 12px 12px;min-height:0;border-radius:0}.toolbar-brand,.toolbar-readouts,.toolbar-actions{justify-content:flex-start}.toolbar-readouts{gap:8px}.toolbar-actions{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.toolbar-actions::-webkit-scrollbar{display:none}.toolbar-actions .hud-action-btn{flex:0 0 auto}.toolbar-panel-grid,.toolbar-action-grid{grid-template-columns:1fr}#build-menu{left:0;right:0;width:100%;bottom:14px;border-radius:0;max-height:55vh}#build-dock{left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom,0px) + 10px);transform:none;justify-content:stretch;gap:8px;padding:8px;border-radius:18px}.build-dock-btn{min-width:0;flex:1 1 0;padding:10px 8px;gap:6px}.build-dock-label{font-size:10px}#build-catalog-tray{--catalog-card-height: 336px;left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom,0px) + 76px);padding:12px;border-radius:14px}.build-catalog-header{grid-template-columns:1fr auto;gap:10px}.build-catalog-filter-row{grid-column:1 / -1}.catalog-card{flex-basis:216px;min-height:164px}#build-placement-bar{left:10px;right:10px;bottom:calc(env(safe-area-inset-bottom,0px) + 138px);transform:none;min-width:0;max-width:none;padding:10px 12px;align-items:flex-start;flex-direction:column}.build-placement-actions{width:100%;justify-content:flex-end}.side-panel{left:0;right:0;width:100%;top:unset;bottom:14px;max-height:55vh;border-radius:0}#event-card-modal{flex-direction:column;max-width:96vw}#event-card-character{width:100%;border-right:none;border-bottom:1px solid rgba(255,138,31,.15)}#event-char-portrait{min-height:160px;height:160px}#event-card-choices{grid-template-columns:1fr;margin:0 16px}#event-card-title{margin:14px 16px 10px}#event-card-body{margin:0 16px 16px}#coords{left:10px;bottom:10px}}@media (max-width: 1100px) and (min-width: 481px){:root{--toolbar-offset: 108px}#toolbar{grid-template-columns:1fr auto;grid-template-areas:"brand actions" "readouts readouts";gap:10px 14px;padding:10px 14px 12px}.toolbar-brand{grid-area:brand}.toolbar-readouts{grid-area:readouts;justify-content:flex-start}.toolbar-actions{grid-area:actions;justify-content:flex-end;flex-wrap:wrap}}@media (max-width: 760px) and (min-width: 481px){:root{--toolbar-offset: 132px}#toolbar{grid-template-columns:1fr;grid-template-areas:"brand" "readouts" "actions";gap:8px}.toolbar-readouts{justify-content:flex-start;gap:8px}.toolbar-actions{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;scrollbar-width:none}.toolbar-actions::-webkit-scrollbar{display:none}.toolbar-actions .hud-action-btn{flex:0 0 auto}}#loading-screen{position:fixed;inset:0;z-index:9999;background:#0c0a06;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease}#loading-screen.fade-out{opacity:0;pointer-events:none}.loading-inner{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center;user-select:none}.loading-logo{font-family:var(--font-display);font-size:clamp(2.4rem,8vw,4.8rem);color:#ff8a1f;letter-spacing:.18em;text-shadow:0 0 24px rgba(255,138,31,.7),0 0 60px rgba(255,138,31,.3);animation:logo-pulse 2s ease-in-out infinite}@keyframes logo-pulse{0%,to{text-shadow:0 0 24px rgba(255,138,31,.7),0 0 60px rgba(255,138,31,.3)}50%{text-shadow:0 0 40px rgba(255,138,31,1),0 0 80px rgba(255,138,31,.5)}}.loading-sub{font-family:var(--font-mono);font-size:.75rem;color:#607090;letter-spacing:.22em}.loading-bar-track{width:clamp(200px,40vw,360px);height:3px;background:#2a2418;border-radius:2px;overflow:hidden}#loading-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,#c25a10,#ff8a1f);border-radius:2px;transition:width .2s ease}#loading-status{font-family:var(--font-mono);font-size:.65rem;color:#405060;letter-spacing:.15em}#event-card-character{position:relative;width:190px;flex-shrink:0;border-right:1px solid rgba(255,138,31,.15)}#event-char-portrait{width:100%;height:100%;min-height:340px;display:flex;align-items:center;justify-content:center;font-size:52px;background-color:#1d1810;background-size:cover;background-position:center top;border-radius:0;border:none;box-shadow:none}#event-card-character:after{content:"";position:absolute;bottom:0;left:0;right:0;height:100px;background:linear-gradient(transparent,#16120bf7);pointer-events:none}#event-char-info{position:absolute;bottom:12px;left:14px;right:14px;z-index:1;display:flex;flex-direction:column;gap:3px}#event-char-name{font-family:var(--font-mono);font-size:15px;font-weight:700;color:#edf3fb;letter-spacing:.06em;text-shadow:0 1px 8px rgba(0,0,0,.9)}#event-char-role{font-family:var(--font-mono);font-size:10px;color:var(--accent-ember);letter-spacing:.16em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.9)}#win-screen{position:fixed;inset:0;background:#000000e0;z-index:9000;display:flex;align-items:center;justify-content:center;pointer-events:all}#win-modal{background:var(--bg-1);border:1px solid #ff8a1f;border-radius:4px;padding:32px 36px 28px;max-width:460px;width:92%;box-shadow:0 0 60px #ff8a1f38,0 0 120px #ff8a1f14;font-family:var(--font-mono);display:flex;flex-direction:column;gap:12px}#win-header{font-size:11px;color:var(--accent-ember);letter-spacing:.22em;text-transform:uppercase}#win-city-name{font-family:var(--font-display);font-size:clamp(1.6rem,5vw,2.4rem);color:#fff;letter-spacing:.1em;line-height:1.1}#win-subtitle{font-size:11px;color:var(--text-soft);letter-spacing:.12em;margin-bottom:4px}#win-goals-list{display:flex;flex-direction:column;gap:6px}.win-goal{font-size:12px;color:var(--accent-lime, #00ff41);letter-spacing:.04em;padding:6px 8px;background:#00ff410f;border-left:2px solid currentColor;border-radius:2px}#win-stats{display:flex;flex-direction:column;gap:4px;margin-top:4px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.win-stat-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-soft)}.win-stat-row span:last-child{color:var(--text-strong)}#win-continue{margin-top:8px;background:var(--accent-ember);color:#0c0a06;border:none;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:.1em;padding:10px 16px;border-radius:3px;cursor:pointer;transition:opacity .15s}#win-continue:hover{opacity:.85}#tutorial-modal{position:fixed;inset:0;background:#000000f5;display:flex;align-items:center;justify-content:center;z-index:310}.tutorial-box{background:linear-gradient(180deg,#16120bfa,#0e0b07fa);border:1px solid rgba(255,138,31,.22);padding:32px 32px 26px;max-width:520px;width:92%;border-radius:4px;box-shadow:0 24px 64px #00000080,0 0 40px #ff8a1f0f}.tutorial-header{text-align:center;margin-bottom:26px}.tutorial-tag{font-family:var(--font-mono);font-size:11px;color:var(--accent-ember);letter-spacing:.2em;margin-bottom:10px}.tutorial-header h2{font-size:26px;letter-spacing:.18em;color:#f0f6ff;margin-bottom:4px}.tutorial-city{font-family:var(--font-mono);font-size:13px;color:var(--accent-magenta);letter-spacing:.1em}.tutorial-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}.tutorial-step{display:flex;gap:14px;align-items:flex-start}.tutorial-num{font-family:var(--font-mono);font-size:22px;color:var(--accent-ember);opacity:.5;line-height:1;min-width:28px;padding-top:2px}.tutorial-step-body{display:flex;flex-direction:column;gap:2px}.tutorial-step-body strong{font-family:var(--font-mono);font-size:12px;color:var(--text-strong);letter-spacing:.06em}.tutorial-step-body span{font-size:12px;color:var(--text-soft);line-height:1.55}.tutorial-begin-btn{width:100%;background:var(--accent-ember);color:#0c0a06;border:none;font-family:var(--font-mono);font-size:14px;font-weight:700;letter-spacing:.16em;padding:12px 0;border-radius:3px;cursor:pointer;transition:opacity .15s}.tutorial-begin-btn:hover{opacity:.85}.rotate-row{display:flex;align-items:center;gap:10px;padding:7px 10px;margin-bottom:6px;background:#ff8a1f0a;border:1px solid rgba(255,138,31,.12);border-radius:3px}.rotate-label{font-family:var(--font-mono);font-size:11px;color:var(--text-soft);letter-spacing:.1em;white-space:nowrap}.rotate-key{color:var(--accent-ember);opacity:.7}.rotate-btns{display:flex;gap:4px;flex:1}.rotate-btn{flex:1;background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--text-soft);font-family:var(--font-mono);font-size:11px;padding:3px 4px;border-radius:2px;cursor:pointer;letter-spacing:.04em;transition:border-color .1s,color .1s,background .1s}.rotate-btn:hover{border-color:var(--accent-ember);color:var(--text-strong)}.rotate-btn.active{background:#ff8a1f26;border-color:var(--accent-ember);color:var(--accent-ember)}.rotate-arrow{font-size:14px;color:var(--accent-ember);transition:transform .15s;display:inline-block}#build-confirm-bar{position:sticky;bottom:0;margin:8px -14px -14px;padding:10px 14px;background:linear-gradient(180deg,#0e0b07f7,#080604fc);border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:7px;z-index:2}.bcbar-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.bcbar-name{font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}.bcbar-facing{font-family:var(--font-mono);font-size:11px;color:var(--accent-ember);letter-spacing:1px;opacity:.85}.bcbar-rot{display:flex;gap:4px}.bcbar-rot-btn{flex:1}.bcbar-place-btn{width:100%;padding:8px 0;background:transparent;border:1px solid;border-radius:3px;font-family:var(--font-mono);font-size:12px;font-weight:700;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:background .12s,box-shadow .12s}.bcbar-place-btn:hover{background:#ffffff12;box-shadow:0 0 10px #ff8a1f33}.bcard.bcard-selected{background:#ffffff0f;border-color:#ffffff59!important;box-shadow:0 0 8px #0006}
