:root{--bg:#0f1117;--surface:#1a1d27;--surface-hover:#222633;--border:#2a2e3d;--text:#e1e4ed;--text-dim:#8b8fa3;--green:#22c55e;--green-bg:#22c55e1a;--yellow:#eab308;--yellow-bg:#eab3081a;--red:#ef4444;--red-bg:#ef44441a;--blue:#3b82f6;--purple:#a855f7;--grey:#6b7280}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}#root{min-height:100vh}.dashboard{max-width:1600px;min-height:100vh;margin:0 auto;padding:24px}.header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:16px;display:flex}.header h1{letter-spacing:.5px;text-transform:uppercase;color:var(--text);align-items:center;gap:10px;font-size:22px;font-weight:700;display:flex}.header-icon{flex-shrink:0}.header-right{align-items:center;gap:16px;display:flex}.health-summary{gap:8px;font-size:14px;display:flex}.health-pill{background:var(--surface);border:1px solid var(--border);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-family:ui-monospace,monospace;font-weight:600;display:flex}.pill-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.health-pill.healthy .pill-dot{background:var(--green);box-shadow:0 0 6px var(--green)}.health-pill.degraded .pill-dot{background:var(--yellow);box-shadow:0 0 6px var(--yellow)}.health-pill.unhealthy .pill-dot{background:var(--red);box-shadow:0 0 6px var(--red)}.refresh-btn{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s}.refresh-btn:hover{background:var(--surface-hover);border-color:var(--green);color:var(--green)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.last-updated{color:var(--text-dim);align-items:center;gap:6px;font-family:ui-monospace,monospace;font-size:11px;display:flex}.ws-indicator{background:var(--grey);border-radius:50%;flex-shrink:0;width:6px;height:6px;transition:background .3s;display:inline-block}.ws-indicator.connected{background:var(--green);box-shadow:0 0 6px #22c55e99}.error-banner{background:var(--red-bg);border:1px solid var(--red);color:var(--red);border-radius:6px;margin-bottom:24px;padding:12px 16px;font-family:ui-monospace,monospace;font-size:14px}.loading{height:60vh;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;flex-direction:column;justify-content:center;align-items:center;gap:24px;font-size:16px;display:flex}.loading-city{align-items:flex-end;gap:8px;display:flex}.loading-building{background:var(--surface);border:1px solid var(--border);border-radius:2px;animation:1.5s ease-in-out infinite build-up}.loading-building.b1{width:20px;animation-delay:0s}.loading-building.b2{width:24px;animation-delay:.3s}.loading-building.b3{width:18px;animation-delay:.6s}@keyframes build-up{0%,to{opacity:.4;height:20px}50%{opacity:1;height:50px}}.cities-container{flex-direction:column;gap:40px;display:flex}.city{border:1px solid var(--border);background:linear-gradient(#0f111700 0%,#0f111799 100%);border-radius:12px;overflow:hidden}.city-header{background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.city-nameplate{align-items:center;gap:12px;display:flex}.city-env-badge{text-transform:uppercase;letter-spacing:1px;border-radius:4px;padding:3px 10px;font-size:11px;font-weight:700}.city-env-badge.prod{background:var(--red-bg);color:var(--red);border:1px solid #ef44444d}.city-env-badge.dev{color:var(--blue);background:#3b82f626;border:1px solid #3b82f64d}.city-name{letter-spacing:.5px;font-size:18px;font-weight:700}.city-stack-count{color:var(--text-dim);font-family:ui-monospace,monospace;font-size:12px}.city-resources{align-items:flex-end;gap:16px;display:flex}.resource-meter{flex-direction:column;align-items:center;gap:4px;display:flex}.meter-bar{background:var(--border);border-radius:4px;width:8px;height:32px;position:relative;overflow:hidden}.meter-fill{border-radius:4px;width:100%;transition:height .6s;position:absolute;bottom:0;left:0}.meter-fill.cpu{background:var(--yellow);box-shadow:0 0 6px #eab30866}.meter-fill.ram{background:var(--blue);box-shadow:0 0 6px #3b82f666}.meter-fill.disk{background:var(--purple);box-shadow:0 0 6px #a855f766}.meter-fill.net{background:var(--green);box-shadow:0 0 6px #22c55e66}.meter-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;font-family:ui-monospace,monospace;font-size:9px}.city-ground{background:repeating-linear-gradient(0deg,#0000,#0000 79px,#2a2e3d4d 79px 80px),repeating-linear-gradient(90deg,#0000,#0000 79px,#2a2e3d4d 79px 80px);padding:24px;position:relative}.city-blocks{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.city-block-wrapper{position:relative}.city-block{background:var(--surface);border:2px solid var(--border);border-radius:8px;transition:all .3s;position:relative;overflow:hidden}.city-block:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.city-block.health-healthy{border-color:#22c55e40}.city-block.health-healthy:before{background:var(--green);box-shadow:0 0 10px #22c55e4d}.city-block.health-degraded{border-color:#eab30840}.city-block.health-degraded:before{background:var(--yellow);box-shadow:0 0 10px #eab3084d}.city-block.health-unhealthy{border-color:#ef444440}.city-block.health-unhealthy:before{background:var(--red);animation:2s ease-in-out infinite pulse-glow;box-shadow:0 0 10px #ef44444d}.city-block.health-error{border-color:#6b728040}.city-block.health-error:before{background:var(--grey)}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.5}}.city-block:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0006}.block-header{border-bottom:1px solid var(--border);background:#0003;align-items:center;gap:8px;padding:12px 16px;display:flex}.block-health-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.block-name{text-transform:uppercase;letter-spacing:.5px;flex:1;font-size:14px;font-weight:700}.block-stats{color:var(--text-dim);background:var(--surface);border-radius:4px;padding:2px 8px;font-family:ui-monospace,monospace;font-size:12px}.block-ground{background:linear-gradient(#0000 0%,#0f11174d 100%);min-height:120px;padding:16px}.buildings-row{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:8px;display:flex}.infra-row{border-bottom:1px dashed var(--border);justify-content:center;gap:16px;margin-bottom:12px;padding-bottom:12px;display:flex}.building{cursor:pointer;border-radius:4px;flex-direction:column;align-items:center;padding:4px;transition:all .2s;display:flex}.building:hover{background:#ffffff08;transform:translateY(-3px)}.building.status-ripple{animation:1.5s ease-out status-ripple}@keyframes status-ripple{0%{box-shadow:0 0 #fff6}40%{box-shadow:0 0 0 12px #fff0}to{box-shadow:none}}.building.stopped{opacity:.55}.building.stopped:hover{opacity:.8}.building svg{filter:drop-shadow(0 2px 4px #0000004d)}.building svg rect{transition:fill .6s,opacity .6s}.building-label{color:var(--text-dim);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:60px;margin-top:4px;font-family:ui-monospace,monospace;font-size:9px;overflow:hidden}.infra-building{flex-direction:column;align-items:center;gap:4px;display:flex}.infra-building svg{filter:drop-shadow(0 2px 4px #0000004d)}.smoke-puff{animation:3s ease-in-out infinite smoke}@keyframes smoke{0%{opacity:.5;transform:translateY(0)}50%{opacity:.2;transform:translateY(-6px)}to{opacity:0;transform:translateY(-12px)}}.conveyor-belt{border-top:1px solid var(--border);margin-top:12px;padding-top:8px}.belt-track{background:var(--surface-hover);border:1px solid var(--border);border-radius:6px;height:12px;position:relative;overflow:hidden}.belt-items{gap:24px;animation:4s linear infinite belt-scroll;display:flex;position:absolute;top:2px;left:0}.belt-item{background:var(--blue);opacity:.7;border-radius:2px;width:8px;height:8px;box-shadow:0 0 4px #3b82f680}.belt-item:nth-child(2){background:var(--green);box-shadow:0 0 4px #22c55e80}.belt-item:nth-child(3){background:var(--purple);box-shadow:0 0 4px #a855f780}@keyframes belt-scroll{0%{transform:translate(-40px)}to{transform:translate(calc(100% + 40px))}}.conveyor-belt.left .belt-items{animation-direction:reverse}.road{display:none}.road.horizontal{height:4px;margin:4px 0;display:block}.road-surface{background:var(--border);border-radius:2px;height:100%;position:relative;overflow:hidden}.road-marking{background:repeating-linear-gradient(90deg, var(--yellow) 0px, var(--yellow) 8px, transparent 8px, transparent 16px);opacity:.4;height:1px;position:absolute;top:50%;left:0;right:0;transform:translateY(-50%)}.service-detail-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.service-detail-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:400px;max-width:90vw;overflow:hidden;box-shadow:0 20px 40px #00000080}.detail-header{border-bottom:1px solid var(--border);background:#0003;align-items:center;gap:10px;padding:16px 20px;display:flex}.detail-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.detail-header h3{flex:1;font-size:16px;font-weight:700}.detail-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:24px;line-height:1;transition:color .2s}.detail-close:hover{color:var(--text)}.detail-body{padding:16px 20px}.detail-row{border-bottom:1px solid #2a2e3d80;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.detail-row:last-child{border-bottom:none}.detail-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.detail-value{text-overflow:ellipsis;white-space:nowrap;max-width:250px;font-family:ui-monospace,monospace;font-size:13px;overflow:hidden}.replicas{border-radius:4px;padding:2px 8px;font-family:ui-monospace,monospace;font-size:12px;font-weight:600}.replicas.ok{background:var(--green-bg);color:var(--green)}.replicas.warn{background:var(--yellow-bg);color:var(--yellow)}.replicas.bad{background:var(--red-bg);color:var(--red)}.stack-action-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex}.stack-action-btn:hover{background:var(--surface-hover);color:var(--blue);border-color:var(--blue)}.stack-action-btn:disabled{opacity:.5;cursor:not-allowed}.stack-action-btn.spinning svg{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.detail-actions{border-top:1px solid var(--border);padding:12px 20px 16px}.action-btn{border:1px solid var(--border);cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border-radius:6px;justify-content:center;align-items:center;gap:8px;width:100%;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.update-btn{color:var(--blue);background:#3b82f61a;border-color:#3b82f64d}.update-btn:hover{border-color:var(--blue);background:#3b82f633}.update-btn:disabled{opacity:.6;cursor:not-allowed}.update-btn.updating{background:#3b82f626}.action-spinner{border:2px solid #3b82f64d;border-top-color:var(--blue);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin;display:inline-block}.toast-container{z-index:200;flex-direction:column;gap:8px;max-width:400px;display:flex;position:fixed;bottom:24px;right:24px}.toast{border-radius:8px;padding:12px 16px;font-family:ui-monospace,monospace;font-size:13px;font-weight:500;animation:.3s ease-out toast-in;box-shadow:0 8px 24px #0006}.toast-success{background:var(--green-bg);color:var(--green);border:1px solid #22c55e4d}.toast-error{background:var(--red-bg);color:var(--red);border:1px solid #ef44444d}.toast-warning{background:var(--yellow-bg);color:var(--yellow);border:1px solid #eab3084d}.toast-info{color:var(--blue);background:#3b82f61a;border:1px solid #3b82f64d}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.confirm-overlay{z-index:150;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.confirm-dialog{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:400px;max-width:90vw;padding:24px;box-shadow:0 20px 40px #00000080}.confirm-message{color:var(--text);margin-bottom:20px;font-size:14px;line-height:1.5}.confirm-actions{justify-content:flex-end;gap:12px;display:flex}.confirm-btn{cursor:pointer;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--border);border-radius:6px;padding:8px 20px;font-size:13px;font-weight:600;transition:all .2s}.confirm-btn.cancel{background:var(--surface);color:var(--text-dim)}.confirm-btn.cancel:hover{background:var(--surface-hover);color:var(--text)}.confirm-btn.proceed{color:var(--blue);background:#3b82f626;border-color:#3b82f64d}.confirm-btn.proceed:hover{border-color:var(--blue);background:#3b82f640}@media (width<=768px){.dashboard{padding:12px}.city-blocks{grid-template-columns:1fr}.header,.city-header{flex-direction:column;align-items:flex-start;gap:12px}.city-resources{flex-wrap:wrap}.buildings-row{gap:4px}}
