@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500&family=Space+Grotesk:wght@400;500;700&display=swap";:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg:#f6fbf7;--surface:#fff;--surface-soft:#eaf6ec;--text:#123224;--text-muted:#3d5f4e;--brand-strong:#0f5f36;--border:#d6e7db;--border-strong:#aecdb9;font-family:IBM Plex Mono,Segoe UI,sans-serif;font-weight:400;line-height:1.5}:root[data-theme=dark]{--bg:#0c1c14;--surface:#12271d;--surface-soft:#1a3527;--text:#edf8f0;--text-muted:#b6d4c0;--brand-strong:#8ed8ac;--border:#294436;--border-strong:#3f6650}*{box-sizing:border-box}body{background-color:var(--bg);min-width:320px;min-height:100vh;color:var(--text);margin:0}#root{min-height:100vh}.app-shell{background:radial-gradient(circle at top right, var(--surface-soft), transparent 30%), var(--bg);min-height:100vh;color:var(--text);flex-direction:column;display:flex}.app-header{border-bottom:1px solid var(--border);background:color-mix(in srgb, var(--bg) 92%, transparent);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);grid-template-columns:1fr auto 1fr;align-items:center;height:72px;padding:0 1.25rem;display:grid}.brand{color:var(--brand-strong);font-size:1.05rem;font-weight:700}.header-right{justify-self:end;align-items:center;display:flex}.nav-links{align-items:center;gap:.3rem;display:flex}.nav-link{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;padding:.32rem .65rem;font-size:.86rem;font-weight:600}.nav-link.active{color:var(--brand-strong);border-color:var(--border);background:var(--surface-soft)}.manage-link{letter-spacing:-.01em;font-family:Space Grotesk,sans-serif;font-size:.98rem;font-weight:700}.theme-toggle{border:1px solid var(--border-strong);background:var(--surface);color:var(--text);cursor:pointer;border-radius:10px;padding:.5rem .8rem;font-weight:600;transition:background-color .2s}.theme-toggle:hover{background:var(--surface-soft)}.app-main{flex:1;align-items:center;padding:1.25rem 2rem;display:flex}.app-main-top{align-items:flex-start}.hero-content{width:min(1100px,100%)}.terminal-line{text-align:left;letter-spacing:-.015em;color:var(--brand-strong);margin:0 0 .2rem;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,5vw,4.8rem);line-height:1.12}.thinking-cursor{vertical-align:text-bottom;background:var(--brand-strong);width:clamp(.9rem,1.3vw,1.35rem);height:clamp(2.2rem,5.5vw,4.8rem);box-shadow:0 0 20px color-mix(in srgb, var(--brand-strong) 45%, transparent);border-radius:3px;margin-left:.35rem;animation:.95s step-end infinite blink-cursor;display:inline-block}.add-sensor-btn{border:1px solid var(--border-strong);background:var(--brand-strong);color:#fff;cursor:pointer;border-radius:12px;margin-top:1.6rem;padding:.85rem 1.2rem;font-size:.95rem;font-weight:700}.add-sensor-btn:disabled{opacity:.75;cursor:wait}.add-sensor-btn.compact{border-radius:10px;margin-top:0;padding:.55rem .85rem}.status-text{color:var(--text-muted);margin-top:.75rem;font-size:.9rem}.home-shell{grid-template-columns:minmax(0,1fr) 280px;align-items:start;gap:1rem;width:min(1300px,100%);display:grid}.nerds-page{flex-direction:column;align-self:flex-start;gap:.9rem;width:min(1200px,100%);display:flex}.nerds-header h2{color:var(--brand-strong);margin:0;font-family:Space Grotesk,sans-serif}.nerds-header p{color:var(--text-muted);margin:.25rem 0 0;font-size:.9rem}.nerds-refresh-row{align-items:center;gap:.6rem;margin-bottom:.75rem;display:flex}.nerds-scope-toggle{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 92%, transparent);border-radius:999px;align-items:center;gap:.35rem;width:fit-content;padding:.25rem;display:inline-flex}.scope-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:999px;padding:.32rem .7rem;font-size:.8rem;font-weight:600}.scope-btn.active{color:var(--brand-strong);border-color:var(--border);background:var(--surface-soft)}.scope-btn.refresh-btn{color:var(--text-muted);border-color:var(--border)}.scope-btn.refresh-btn:hover{color:var(--brand-strong);background:var(--surface-soft)}.polling-dot-note{color:var(--text-muted);white-space:nowrap;align-items:center;gap:.35rem;margin-left:.5rem;font-size:.72rem;display:inline-flex}.polling-dot{background:var(--brand-strong);border-radius:50%;width:6px;height:6px;animation:2s ease-in-out infinite polling-pulse}@keyframes polling-pulse{0%,to{opacity:.4}50%{opacity:1}}.nerds-grid{grid-template-columns:repeat(3,minmax(220px,1fr));gap:.8rem;display:grid}.nerd-row{color:var(--text-muted);margin:.25rem 0;font-size:.87rem}.nerd-row strong{color:var(--text);font-weight:700}.metric-help{-webkit-text-decoration:underline dotted color-mix(in srgb, var(--brand-strong) 45%, transparent);text-decoration:underline dotted color-mix(in srgb, var(--brand-strong) 45%, transparent);text-underline-offset:.16rem;cursor:help;position:relative}.metric-help:after{content:attr(data-tooltip);border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 96%, transparent);width:min(300px,70vw);color:var(--text);opacity:0;pointer-events:none;z-index:20;border-radius:8px;padding:.45rem .55rem;font-size:.76rem;line-height:1.3;transition:opacity .14s,transform .14s;position:absolute;bottom:calc(100% + 8px);left:0;transform:translateY(4px);box-shadow:0 8px 20px #00000024}.metric-help:hover:after,.metric-help:focus-visible:after{opacity:1;transform:translateY(0)}.home-main{grid-template-columns:1.35fr .85fr;gap:1rem;display:grid}.home-sidebar{position:sticky;top:.9rem}.summary-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 92%, transparent);border-radius:16px;padding:1rem 1.1rem}.summary-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .8rem;font-size:.85rem;font-weight:600}.avg-grid{grid-template-columns:repeat(2,minmax(160px,1fr));gap:.7rem;display:grid}.avg-item{border:1px solid var(--border);background:var(--surface-soft);border-radius:10px;flex-direction:column;gap:.2rem;padding:.65rem .75rem;display:flex}.avg-item span{color:var(--text-muted);font-size:.8rem}.avg-item strong{color:var(--brand-strong);font-family:Space Grotesk,sans-serif;font-size:1.2rem}.summary-total{flex-direction:column;justify-content:center;display:flex}.summary-total h2{color:var(--brand-strong);margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(2.4rem,4vw,3.2rem);line-height:1}.summary-meta{color:var(--text-muted);margin:.5rem 0 0;font-size:.95rem}.chart-filter-row{flex-wrap:wrap;gap:.65rem;margin-top:.9rem;display:flex}.metric-checkbox{color:var(--text-muted);border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 85%, transparent);border-radius:999px;align-items:center;gap:.35rem;padding:.22rem .55rem;font-size:.8rem;display:inline-flex}.metric-checkbox input{margin:0}.zoom-controls{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 85%, transparent);color:var(--text-muted);border-radius:999px;align-items:center;gap:.35rem;margin-left:auto;padding:.2rem .35rem .2rem .55rem;font-size:.78rem;display:inline-flex}.zoom-controls button{border:1px solid var(--border);background:var(--surface-soft);color:var(--text);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;width:1.35rem;height:1.35rem;font-weight:700;line-height:1;display:inline-flex}.zoom-controls button:disabled{opacity:.45;cursor:not-allowed}.zoom-value{text-align:center;min-width:2.5rem;color:var(--text);font-weight:700}.metric-dot{border-radius:50%;width:.45rem;height:.45rem}.chart-meta-row{justify-content:space-between;align-items:center;gap:.7rem;margin-top:.55rem;display:flex}.window-label{color:var(--text-muted);letter-spacing:.02em;margin:0;font-size:.78rem}.latest-legend{flex-wrap:wrap;justify-content:flex-end;gap:.55rem;display:flex}.latest-item{color:var(--text-muted);align-items:center;gap:.3rem;font-size:.78rem;display:inline-flex}.latest-item strong{color:var(--text);font-weight:700}.live-metric-chart{border:1px solid var(--border);background:color-mix(in srgb, var(--surface-soft) 45%, transparent);border-radius:12px;margin-top:.75rem;overflow:hidden}.live-metric-chart svg{width:100%;height:260px;display:block}.axis-label{fill:color-mix(in srgb, var(--text-muted) 72%, transparent);letter-spacing:.03em;pointer-events:none;font-size:11px;font-weight:500}.home-chart-panel{grid-column:1/-1}.home-controls-panel{padding:.75rem}.home-map-panel{grid-column:1/-1}.map-panel-header{justify-content:space-between;align-items:center;gap:.7rem;display:flex}.home-map{border:1px solid var(--border);border-radius:12px;width:100%;height:320px;margin-top:.6rem}.global-map-card,.pipeline-card{margin-top:.2rem}.pipeline-card-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.pipeline-card-header .summary-label{margin:0}.global-map-legend{flex-wrap:wrap;gap:.55rem;margin-top:.2rem;display:flex}.nerd-global-map{height:360px}.manage-city{flex-direction:column;gap:.9rem;width:min(1100px,100%);display:flex}.manage-toolbar{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.manage-toolbar h2{color:var(--brand-strong);margin:0;font-family:Space Grotesk,sans-serif;font-size:clamp(.95rem,1.4vw,1.1rem)}.radius-control{flex-direction:column;gap:.25rem;width:100%;min-width:0;display:flex}.radius-control label{color:var(--text-muted);font-size:.82rem;font-weight:600}.radius-control input[type=range]{width:100%;max-width:100%}.home-controls-panel .manage-toolbar{flex-direction:column;align-items:stretch}.gm-style .gm-style-iw-c button.gm-ui-hover-effect{display:none!important}.sensor-type-grid{grid-template-columns:1fr;gap:.45rem;display:grid}.sensor-type-card{border:1px solid var(--border);background:color-mix(in srgb, var(--surface) 92%, transparent);border-radius:14px;flex-direction:column;gap:.35rem;padding:.45rem .55rem;display:flex}.sensor-type-card-temperature{border-color:color-mix(in srgb, #f97316 28%, var(--border));background:color-mix(in srgb, #f97316 4%, var(--surface))}.sensor-type-card-humidity{border-color:color-mix(in srgb, #0ea5e9 28%, var(--border));background:color-mix(in srgb, #0ea5e9 4%, var(--surface))}.sensor-type-card-pollution{border-color:color-mix(in srgb, #ef4444 24%, var(--border));background:color-mix(in srgb, #ef4444 3%, var(--surface))}.sensor-type-card-noise{border-color:color-mix(in srgb, #a855f7 24%, var(--border));background:color-mix(in srgb, #a855f7 3%, var(--surface))}.sensor-type-title{color:var(--brand-strong);margin:0;font-family:Space Grotesk,sans-serif;font-size:.8rem;font-weight:700}.sensor-type-title-temperature{color:#d5682d}.sensor-type-title-humidity{color:#0b84b8}.sensor-type-title-pollution{color:#c03a3a}.sensor-type-title-noise{color:#7f42c4}.sensor-type-controls{align-items:center;gap:.35rem;min-height:1.55rem;display:inline-flex}.sensor-arrow-btn{appearance:none;border:1px solid var(--border-strong);background:var(--surface-soft);width:1.45rem;height:1.45rem;color:var(--text);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;padding:0;font-size:.72rem;font-weight:700;line-height:1;transition:background-color .15s,border-color .15s,opacity .15s;display:inline-flex;transform:none}.sensor-arrow-btn:disabled{opacity:.45;cursor:not-allowed}.sensor-arrow-btn:active{transform:none}.sensor-type-count{text-align:center;font-variant-numeric:tabular-nums;width:2ch;color:var(--brand-strong);margin:0;font-family:Space Grotesk,sans-serif;font-size:1.05rem;font-weight:700;line-height:1}@keyframes blink-cursor{0%,49%{opacity:1}50%,to{opacity:.1}}@media (width<=720px){.app-header{grid-template-columns:1fr;justify-items:start;gap:.7rem;height:auto;padding-top:.8rem;padding-bottom:.8rem}.app-main{padding:1rem}.header-right{justify-self:start}.home-shell,.nerds-grid,.home-main{grid-template-columns:1fr}.home-sidebar{position:static}.avg-grid{grid-template-columns:1fr}.manage-toolbar{flex-direction:column;align-items:flex-start}.radius-control{width:100%;min-width:0}.sensor-type-grid{grid-template-columns:1fr}.chart-meta-row{flex-direction:column;align-items:flex-start}.latest-legend{justify-content:flex-start}.zoom-controls{margin-left:0}}.scenario-banners{flex-direction:column;gap:.5rem;padding:.5rem 1.25rem;display:flex}.scenario-banner{background:color-mix(in srgb, var(--accent) 12%, var(--surface));border:1px solid color-mix(in srgb, var(--accent) 30%, var(--border));border-radius:8px;align-items:center;gap:.75rem;padding:.625rem 1rem;font-size:.82rem;animation:.3s ease-out banner-in;display:flex}.scenario-banner-industrial_incident{--accent:#ef4444}.scenario-banner-heatwave{--accent:#f59e0b}.scenario-banner-rush_hour{--accent:#6366f1}.scenario-banner strong{letter-spacing:.04em;background:var(--accent);color:#fff;white-space:nowrap;border-radius:4px;padding:.15rem .5rem;font-size:.72rem}.scenario-zone{white-space:nowrap;font-weight:600}.scenario-desc{opacity:.8}@keyframes banner-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.anomaly-feed-panel{max-height:320px;overflow-y:auto}.anomaly-feed-list{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.anomaly-feed-item{background:color-mix(in srgb, var(--text) 4%, var(--surface));border-radius:6px;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.78rem;animation:.25s ease-out banner-in;display:flex}.anomaly-type{text-transform:capitalize;min-width:5rem;font-weight:600}.anomaly-value{opacity:.85;font-family:SF Mono,Fira Code,monospace}.anomaly-time{opacity:.55;white-space:nowrap;margin-left:auto;font-size:.72rem}.pipeline-throughput{color:var(--brand-strong,#16a34a);font-variant-numeric:tabular-nums;font-size:1rem;font-weight:700}.pipeline-error{color:#ef4444;margin-bottom:.5rem;font-size:.85rem}.pipeline-svg-wrapper{overflow-x:auto}.pipeline-svg{width:100%;height:auto;min-height:200px}.pipeline-node-shape{fill:var(--surface-soft,#f8fafc);stroke:var(--border,#d1d5db);stroke-width:1.5px;transition:fill .2s}.pipeline-node-label{fill:var(--text);text-anchor:middle;pointer-events:none;font-size:13px;font-weight:600}.pipeline-node-stat{fill:var(--brand-strong,#16a34a);text-anchor:middle;font-variant-numeric:tabular-nums;pointer-events:none;font-size:11px;font-weight:700}.pipeline-edge{fill:none;stroke:var(--border,#d1d5db);stroke-width:2px;stroke-dasharray:6 4}.pipeline-particle{fill:var(--brand-strong,#16a34a);filter:url(#pipeline-glow);opacity:.9}@media (width<=720px){.pipeline-svg-wrapper{padding:.75rem}.pipeline-page{padding:1rem .75rem}}
