:root{--ui-bg: #12161f;--ui-panel: #1b2230e6;--ui-panel-solid: #1b2230;--ui-border: #2c3650;--ui-accent: #ffcf4d;--ui-text: #e7ecf3;--ui-dim: #9fb0c8;font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;width:100%;overflow:hidden;background:#0c0f16}canvas{display:block}.app{position:fixed;inset:0}#world-canvas{image-rendering:pixelated}.overlay{position:absolute;pointer-events:none}.overlay>*{pointer-events:auto}.hud{top:12px;left:12px;background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:10px;padding:9px 13px;color:var(--ui-text);min-width:190px;box-shadow:0 8px 30px #0008}.hud .title{font-weight:800;letter-spacing:.4px;font-size:13px}.hud .title .gold{color:var(--ui-accent)}.hud .sub{color:var(--ui-dim);font-size:10px;margin-top:1px}.hud .stats{display:flex;gap:16px;margin-top:7px}.hud .stat .num{font-size:17px;font-weight:800;font-variant-numeric:tabular-nums}.hud .stat .lbl{font-size:9px;color:var(--ui-dim);text-transform:uppercase;letter-spacing:.8px}.hud .era{display:inline-block;margin-top:7px;font-size:9px;text-transform:uppercase;letter-spacing:1px;color:#0c0f16;background:var(--ui-accent);padding:2px 8px;border-radius:99px;font-weight:700}.timeline{left:50%;transform:translate(-50%);bottom:14px;width:min(880px,calc(100% - 20px));background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:10px 14px 12px;color:var(--ui-text);box-shadow:0 8px 30px #0008}.timeline .controls{display:flex;align-items:center;gap:8px;margin-bottom:10px}.timeline .controls .spacer{flex:1}.timeline button{background:#232c40;color:var(--ui-text);border:1px solid var(--ui-border);border-radius:8px;padding:6px 11px;cursor:pointer;font-weight:700;font-size:12px;min-width:34px}.timeline button:hover{background:#2c3650}.timeline button.active{background:var(--ui-accent);color:#0c0f16;border-color:var(--ui-accent)}.timeline .yearbig{font-size:18px;font-weight:800;min-width:60px;text-align:center;font-variant-numeric:tabular-nums;color:var(--ui-accent)}.timeline .live-tag{font-size:11px;font-weight:700;color:#6fcf97;letter-spacing:.4px}.timeline input[type=range]:disabled{opacity:.8}.timeline .track{position:relative;width:100%;height:26px}.timeline input[type=range]{width:100%;accent-color:var(--ui-accent);margin:0}.timeline .ticks{position:absolute;inset:0;pointer-events:none}.timeline .tick{position:absolute;top:16px;transform:translate(-50%);font-size:9px;color:var(--ui-dim);white-space:nowrap}.timeline .ev-dot{position:absolute;top:0;width:9px;height:9px;border-radius:99px;background:var(--ui-accent);transform:translate(-50%);cursor:pointer;border:1px solid #0c0f16;pointer-events:auto}.timeline .ev-dot:hover{transform:translate(-50%) scale(1.5)}.inspector{top:14px;right:14px;width:min(290px,calc(100vw - 28px));background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:14px 16px;color:var(--ui-text);box-shadow:0 8px 30px #0008}.inspector h3{margin:0 0 2px;font-size:15px}.inspector .kind{font-size:11px;color:var(--ui-accent);text-transform:uppercase;letter-spacing:1px}.inspector .note{font-size:12px;color:var(--ui-text);line-height:1.45;margin-top:8px}.inspector .meta{font-size:11px;color:var(--ui-dim);margin-top:10px;line-height:1.5}.inspector .src{font-size:10px;color:var(--ui-dim);margin-top:8px;font-style:italic}.inspector .close{float:right;cursor:pointer;color:var(--ui-dim);border:none;background:none;font-size:16px}.dz-btn{background:#3a1f1f;color:#ff9b9b;border:1px solid #6b2c2c;border-radius:7px;padding:5px 12px;cursor:pointer;font-weight:700;font-size:12px}.dz-btn:hover{background:#4a2626}.badge-modeled{display:inline-block;font-size:9px;background:#3a2c12;color:#ffcf4d;padding:1px 6px;border-radius:4px;margin-left:6px}.badge-sourced{display:inline-block;font-size:9px;background:#12302a;color:#7fe0c0;padding:1px 6px;border-radius:4px;margin-left:6px}.toast{left:50%;transform:translate(-50%);top:16px;background:linear-gradient(180deg,#232c40,#1b2230);border:1px solid var(--ui-accent);border-radius:12px;padding:12px 20px;color:var(--ui-text);max-width:460px;text-align:center;box-shadow:0 10px 40px #000a;animation:pop .4s ease}.toast .yr{color:var(--ui-accent);font-weight:800;font-size:12px;letter-spacing:1px}.toast .t{font-weight:800;font-size:17px;margin:2px 0 4px}.toast .b{font-size:12px;color:var(--ui-dim);line-height:1.4}@keyframes pop{0%{transform:translate(-50%,-12px);opacity:0}to{transform:translate(-50%);opacity:1}}.presence{bottom:132px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:99px;padding:6px 14px;color:var(--ui-text);font-size:12px;box-shadow:0 6px 20px #0007}.presence .live{color:#6fcf97;font-weight:800;letter-spacing:.5px}.presence .live.off{color:var(--ui-dim)}.presence .dot{width:8px;height:8px;border-radius:99px;background:#6fcf97;box-shadow:0 0 8px #6fcf97}.presence .dot.off{background:#6b7689;box-shadow:none}.presence input{background:#0c0f16;border:1px solid var(--ui-border);border-radius:6px;color:var(--ui-text);font-size:12px;padding:3px 7px;width:110px}.buildbar{left:12px;bottom:96px;background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:10px 12px;color:var(--ui-text);box-shadow:0 8px 30px #0008;max-width:210px}.buildbar .head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.buildbar .head b{font-size:12px}.buildbar .toggle{background:#232c40;border:1px solid var(--ui-border);color:var(--ui-text);border-radius:7px;padding:4px 9px;cursor:pointer;font-weight:700;font-size:11px}.buildbar .toggle.on{background:var(--ui-accent);color:#0c0f16;border-color:var(--ui-accent)}.buildbar .kinds{display:flex;gap:6px;flex-wrap:wrap}.buildbar .kind{background:#232c40;border:1px solid var(--ui-border);color:var(--ui-text);border-radius:7px;padding:5px 8px;cursor:pointer;font-size:11px;font-weight:600}.buildbar .kind.sel{background:var(--ui-accent);color:#0c0f16;border-color:var(--ui-accent)}.buildbar .hint{font-size:10px;color:var(--ui-dim);margin-top:8px;line-height:1.4}.buildbar .admin{margin-top:8px;border-top:1px solid var(--ui-border);padding-top:8px}.buildbar .admin .row2{display:flex;gap:6px}.citystats{top:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:8px 16px;color:var(--ui-text);box-shadow:0 6px 20px #0007;max-width:calc(100vw - 24px);flex-wrap:wrap}.citystats .stat{text-align:center}.citystats .stat .num{font-size:15px;font-weight:800;font-variant-numeric:tabular-nums}.citystats .stat .num.neg{color:#ff6b6b}.citystats .stat .lbl{font-size:9px;color:var(--ui-dim);text-transform:uppercase;letter-spacing:.6px}.citystats .rci{display:flex;gap:6px;align-items:flex-end;height:34px}.citystats .rci .col{display:flex;flex-direction:column;align-items:center;width:22px}.citystats .rci .bararea{height:24px;width:12px;position:relative;display:flex;align-items:center}.citystats .rci .bar{position:absolute;left:0;width:12px;border-radius:2px}.citystats .rci .tick{position:absolute;left:0;right:0;top:50%;height:1px;background:var(--ui-border)}.citystats .rci .lbl{font-size:9px;font-weight:800;margin-top:1px}.citystats .tax input{width:90px;accent-color:var(--ui-accent);vertical-align:middle}.citytools{left:50%;bottom:14px;transform:translate(-50%);background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:10px 12px;color:var(--ui-text);box-shadow:0 8px 30px #0008;width:min(980px,calc(100vw - 24px));z-index:32}.build-fab{display:none}.hotbar-top{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.hotbar-top b{display:block;font-size:18px;line-height:1;color:var(--ui-text)}.hotbar-top span{display:block;margin-top:3px;font-size:11px;color:var(--ui-accent);text-transform:uppercase;letter-spacing:.7px;font-weight:800}.hotbar-actions{display:flex;gap:6px;flex:none}.hotbar-groups{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;margin-bottom:7px}.tool-strip{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;align-items:stretch}.tool-strip.utilities{flex-wrap:nowrap}.citytools button{background:#232c40;border:1px solid var(--ui-border);color:var(--ui-text);border-radius:8px;padding:8px 10px;cursor:pointer;font-size:12px;font-weight:800;min-height:38px;white-space:nowrap}.citytools button:disabled{opacity:.45;cursor:default}.citytools button.locked{opacity:1;border-color:#40506f;background:#202a3e}.citytools button.locked small{display:block;color:var(--ui-accent);font-size:9px;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.citytools button.sel{background:var(--ui-accent);color:#0c0f16;border-color:var(--ui-accent)}.citytools .hint{font-size:11px;color:var(--ui-dim);line-height:1.4}.build-card{width:92px;min-width:92px;height:78px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}.build-icon{width:34px;height:28px;display:block;position:relative;border:2px solid #704a34;border-radius:3px 3px 2px 2px;background:#d8b47c;box-shadow:inset -8px -6px #0002}.build-icon i{position:absolute;left:-5px;right:-5px;top:-9px;height:11px;border-radius:3px 3px 0 0;clip-path:polygon(50% 0,100% 100%,0 100%)}.build-icon.shop i,.build-icon.civic i,.build-icon.industrial i,.build-icon.future i{clip-path:none;top:-5px;height:7px}.build-icon.park{border-radius:99px;border-color:#3f8539;box-shadow:inset 0 -6px #0002}.build-icon.park i{width:12px;left:11px;right:auto;top:-7px;border-radius:99px;clip-path:none}.build-label{display:block;max-width:78px;overflow:hidden;text-overflow:ellipsis}.compact{min-width:74px}.admin-drawer{margin-top:7px;border-top:1px solid var(--ui-border);padding-top:7px;color:var(--ui-dim);font-size:11px}.admin-drawer summary{cursor:pointer;color:var(--ui-accent);font-weight:800;margin-bottom:7px}.build-goals{right:14px;top:118px;width:230px;background:var(--ui-panel);backdrop-filter:blur(6px);border:1px solid var(--ui-border);border-radius:12px;padding:10px 12px;color:var(--ui-text);box-shadow:0 8px 30px #0008}.goals-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.goals-head b{font-size:13px;color:var(--ui-accent)}.goals-head span{color:var(--ui-dim);font-size:11px;font-weight:800}.goal{display:flex;gap:8px;align-items:center;padding:7px 0;border-top:1px solid #ffffff12}.goal:first-of-type{border-top:none}.goal .check{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:#232c40;border:1px solid var(--ui-border);color:var(--ui-accent);font-size:9px;font-weight:900}.goal.done .check{background:var(--ui-accent);color:#0c0f16;border-color:var(--ui-accent)}.goal b{display:block;font-size:12px}.goal small{display:block;color:var(--ui-dim);font-size:10px;margin-top:2px}.placement-fx{left:50%;top:190px;transform:translate(-50%);background:#111a2aee;border:1px solid var(--ui-accent);color:var(--ui-text);border-radius:99px;padding:10px 18px;box-shadow:0 12px 40px #000a;animation:fx-pop 1.9s ease forwards;pointer-events:none}.placement-fx b{position:relative;z-index:1;font-size:14px;color:var(--ui-accent)}.sparkle{position:absolute;width:7px;height:7px;border-radius:99px;background:var(--ui-accent);animation:sparkle 1.1s ease-out forwards}.sparkle.s1{left:12px;top:9px}.sparkle.s2{right:18px;top:7px;animation-delay:.1s}.sparkle.s3{left:50%;bottom:6px;animation-delay:.18s}@keyframes fx-pop{0%{opacity:0;transform:translate(-50%,12px) scale(.94)}14%{opacity:1;transform:translate(-50%) scale(1)}82%{opacity:1;transform:translate(-50%,-5px) scale(1)}to{opacity:0;transform:translate(-50%,-12px) scale(.98)}}@keyframes sparkle{0%{opacity:0;transform:translateY(7px) scale(.5)}25%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-18px) scale(.2)}}.charselect-backdrop{inset:0;background:#000a;backdrop-filter:blur(5px);display:grid;place-items:center;z-index:50}.charselect{background:var(--ui-panel-solid);border:1px solid var(--ui-border);border-radius:14px;padding:16px 18px;width:min(760px,94vw);max-height:92vh;overflow:auto;box-shadow:0 20px 60px #000}.cs-title{text-align:center;font-weight:800;letter-spacing:2px;color:var(--ui-accent);margin-bottom:14px}.cs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px}.cs-card{background:#0c0f16;border:2px solid var(--ui-border);border-radius:10px;padding:5px;cursor:pointer;display:flex;flex-direction:column;align-items:center;color:var(--ui-border);transition:transform .1s}.cs-card:hover{transform:translateY(-2px)}.cs-card.sel{box-shadow:0 0 0 2px currentColor}.cs-card img{width:100%;aspect-ratio:.84;object-fit:cover;object-position:top center;border-radius:6px;image-rendering:pixelated;display:block}.cs-name{font-size:11px;font-weight:800;margin-top:5px;letter-spacing:.4px;text-align:center}.cs-footer{margin-top:14px}.cs-pickinfo{font-size:12px;display:flex;align-items:center;gap:8px;color:var(--ui-text)}.cs-pickinfo .dot{width:10px;height:10px;border-radius:99px;flex:none}.cs-blurb{color:var(--ui-dim)}.cs-rename{display:flex;gap:8px;margin-top:10px}.cs-rename input{flex:1;background:#0c0f16;border:1px solid var(--ui-border);border-radius:8px;color:var(--ui-text);padding:8px 10px;font-size:13px}.cs-go{border:none;border-radius:8px;color:#0c0f16;font-weight:800;padding:8px 14px;cursor:pointer;font-size:13px;white-space:nowrap}.presence .avatar{width:22px;height:22px;border-radius:6px;object-fit:cover;image-rendering:pixelated;object-position:50% 22%;border:1px solid var(--ui-border)}.presence .change{cursor:pointer;color:var(--ui-dim);font-size:11px}.presence .change:hover{color:var(--ui-text)}.account{position:relative;background:var(--ui-panel-solid);border:1px solid var(--ui-border);border-radius:14px;padding:18px 20px;width:min(360px,92vw);box-shadow:0 20px 60px #000;display:flex;flex-direction:column;gap:10px}.account .close{position:absolute;top:8px;right:12px;background:none;border:none;color:var(--ui-dim);font-size:18px;cursor:pointer}.acc-sub{font-size:12px;color:var(--ui-dim);margin:0;line-height:1.4}.account input{background:#0c0f16;border:1px solid var(--ui-border);border-radius:8px;color:var(--ui-text);padding:9px 11px;font-size:14px}.acc-err{color:#ff6b6b;font-size:12px}.acc-go{background:var(--ui-accent);color:#0c0f16;border:none;border-radius:8px;padding:10px;font-weight:800;cursor:pointer;font-size:14px}.acc-go:disabled{opacity:.6;cursor:default}.acc-toggle{font-size:12px;color:var(--ui-dim);text-align:center}.acc-toggle span{color:var(--ui-accent);cursor:pointer}.attrib{left:12px;bottom:8px;font-size:9px;color:#6b7689;pointer-events:none}.loading{position:fixed;inset:0;display:grid;place-items:center;color:var(--ui-text);font-size:18px;background:#0c0f16}.loading .gold{color:var(--ui-accent)}@media (max-width: 700px){.hud{top:8px;left:8px;right:auto;min-width:0;width:150px;padding:8px 9px;border-radius:8px}.hud .sub,.hud .era{display:none}.hud .stats{gap:8px;flex-wrap:wrap;margin-top:5px}.hud .stat .num{font-size:14px}.hud .stat .lbl{font-size:8px;letter-spacing:.4px}.citystats{top:8px;left:166px;right:8px;transform:none;max-width:none;gap:9px;padding:7px 8px;border-radius:8px;justify-content:flex-start}.citystats .stat .num{font-size:13px}.citystats .stat .lbl{font-size:8px}.citystats .mini-stat,.citystats .rci{display:none}.citystats .tax input{width:70px}.presence{left:8px;right:8px;bottom:8px;transform:none;justify-content:center;max-width:calc(100vw - 16px);overflow:hidden;border-radius:10px;padding:6px 8px}.presence span{white-space:nowrap}.citytools{left:8px;right:8px;bottom:54px;transform:none;width:auto;max-width:none;overflow:hidden;border-radius:12px;padding:9px}.hotbar-top{margin-bottom:6px;align-items:flex-start}.hotbar-top b{font-size:15px}.hotbar-top span{font-size:9px;max-width:150px}.hotbar-actions button{padding:6px 8px;min-height:30px}.hotbar-groups{margin-bottom:5px}.citytools button{min-height:34px;font-size:11px;padding:7px 9px}.build-card{width:78px;min-width:78px;height:68px}.build-icon{width:30px;height:24px}.build-label{max-width:66px}.citytools .hint{display:none}.build-goals{inset:auto 8px 202px;width:auto;display:grid;grid-template-columns:auto 1fr;gap:6px 8px;padding:8px 9px}.goals-head{grid-column:1 / -1;margin-bottom:0}.goal{padding:4px 0;border-top:none}.goal b{font-size:11px}.goal small{display:none}.placement-fx{top:166px;max-width:calc(100vw - 24px);text-align:center}.attrib{display:none}.inspector{top:112px;left:8px;right:8px;width:auto;max-height:34vh;overflow:auto}}
