:root{--bg:#f4f6f8;--bg-soft:#eaedf1;--card:#ffffff;--card-2:#f7f9fb;--text:#101728;--text-2:#586275;--text-3:#8b95a6;--border:#e6e9ef;--border-strong:#d6dbe3;--track:#e9edf2;--primary:#0d9488;--primary-ink:#0f766e;--primary-soft:#d4f4ee;--accent:#14b8a6;--ok:#16a34a;--ok-soft:#dcfce7;--warn:#c2710c;--warn-soft:#fdf0d5;--crit:#dc2626;--crit-soft:#fde6e6;--shadow-sm:0 1px 2px rgba(16,23,40,.04),0 1px 3px rgba(16,23,40,.05);--shadow-md:0 2px 6px rgba(16,23,40,.05),0 8px 24px rgba(16,23,40,.06);--shadow-lg:0 12px 40px rgba(16,23,40,.12);--radius:16px;--radius-sm:10px;--sans:"Geist",system-ui,-apple-system,sans-serif;--mono:"Geist Mono",ui-monospace,monospace}[data-theme=dark]{--bg:#080b12;--bg-soft:#0e131d;--card:#121826;--card-2:#19212f;--text:#e8edf4;--text-2:#9aa5b7;--text-3:#5f6a7d;--border:#222c3c;--border-strong:#2e3a4d;--track:#222c3c;--primary:#2dd4bf;--primary-ink:#5eead4;--primary-soft:#0c352f;--accent:#2dd4bf;--ok:#34d399;--ok-soft:#0d2e22;--warn:#fbbf24;--warn-soft:#332408;--crit:#f87171;--crit-soft:#341414;--shadow-sm:0 1px 2px rgba(0,0,0,.3);--shadow-md:0 2px 8px rgba(0,0,0,.35),0 12px 32px rgba(0,0,0,.4);--shadow-lg:0 16px 48px rgba(0,0,0,.55)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;font-feature-settings:"cv01","ss01";transition:background .25s ease,color .25s ease}.mono{font-family:var(--mono);font-feature-settings:"zero"}h1,h2,h3{font-weight:600;letter-spacing:-.01em}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:8px;border:2px solid var(--bg)}.app{display:flex;height:100vh;overflow:hidden}.main{flex:1;display:flex;flex-direction:column;min-width:0}.content{flex:1;overflow-y:auto;padding:28px 32px 80px}.sidebar{width:252px;flex-shrink:0;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 14px;gap:6px;z-index:40;transition:transform .25s ease}.brand{display:flex;align-items:center;gap:11px;padding:8px 10px 18px}.brand-mark{width:38px;height:38px;border-radius:11px;background:linear-gradient(140deg,var(--primary),var(--accent));color:#fff;display:grid;place-items:center;font-weight:700;font-size:20px;box-shadow:0 4px 12px var(--primary-soft)}[data-theme=dark] .brand-mark{color:#04201c}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-name{font-weight:700;font-size:17px;letter-spacing:.02em}.brand-tag{font-size:11px;color:var(--text-3);font-weight:500}.nav-group{display:flex;flex-direction:column;gap:2px;margin-top:6px}.nav-heading{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.09em;color:var(--text-3);padding:12px 12px 6px}.nav-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;color:var(--text-2);font-size:14.5px;font-weight:500;text-align:left;width:100%;transition:background .15s,color .15s;position:relative}.nav-item:hover{background:var(--bg-soft);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary-ink)}[data-theme=dark] .nav-item.active{color:var(--primary-ink)}.nav-item.active .nav-ico{color:var(--primary)}.nav-ico{display:grid;place-items:center;color:var(--text-3)}.nav-item:hover .nav-ico,.nav-item.active .nav-ico{color:currentColor}.nav-text{flex:1}.nav-item.soon{opacity:.55;cursor:default}.nav-item.soon:hover{background:transparent;color:var(--text-2)}.nav-soon-tag{font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border:1px solid var(--border-strong);border-radius:5px;padding:2px 5px}.sidebar-foot{margin-top:auto;padding-top:14px}.fleet-mini{display:flex;align-items:center;gap:10px;padding:11px 12px;border:1px solid var(--border);border-radius:12px;background:var(--card-2)}.fleet-mini-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.fleet-mini-dot.ok{background:var(--ok);box-shadow:0 0 0 4px var(--ok-soft)}.fleet-mini-dot.warn{background:var(--warn);box-shadow:0 0 0 4px var(--warn-soft)}.fleet-mini-dot.crit{background:var(--crit);box-shadow:0 0 0 4px var(--crit-soft)}.fleet-mini-text{display:flex;flex-direction:column;font-size:13px;font-weight:600}.fleet-mini-sub{font-size:11.5px;font-weight:500;color:var(--text-3)}.sidebar-scrim{display:none}.topbar{height:66px;flex-shrink:0;display:flex;align-items:center;gap:14px;padding:0 28px;background:color-mix(in srgb,var(--card) 86%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}.topbar-title{display:flex;flex-direction:column;line-height:1.2;margin-right:auto}.topbar-title h1{font-size:19px}.topbar-sub{font-size:12.5px;color:var(--text-3);font-weight:500}.topbar-right{display:flex;align-items:center;gap:9px}.env-badge{font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--warn);background:var(--warn-soft);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);padding:4px 9px;border-radius:7px}.region-chip{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500;color:var(--text-2);white-space:nowrap;font-family:var(--mono);background:var(--card-2);border:1px solid var(--border);padding:5px 10px;border-radius:8px}.region-flag{width:7px;height:7px;border-radius:2px;background:var(--text-3)}.live-chip{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--text-2);white-space:nowrap;background:var(--card-2);border:1px solid var(--border);padding:5px 11px;border-radius:8px}.live-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);position:relative}.live-dot:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:var(--ok);opacity:.35;animation:pulse 2s infinite}.live-chip.loading .live-dot{background:var(--warn)}.live-chip.loading .live-dot:after{background:var(--warn)}@keyframes pulse{0%{transform:scale(.7);opacity:.5}70%{transform:scale(1.6);opacity:0}to{opacity:0}}.live-sep{color:var(--text-3)}.live-refresh{color:var(--text-3);font-weight:500}.icon-btn{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;color:var(--text-2);border:1px solid var(--border);background:var(--card);transition:all .15s}.icon-btn:hover{background:var(--bg-soft);color:var(--text)}.menu-btn{display:none}.user-menu{display:flex;align-items:center;gap:9px;padding:4px 10px 4px 4px;border-radius:10px;border:1px solid var(--border);background:var(--card);transition:background .15s}.user-menu:hover{background:var(--bg-soft)}.avatar{width:32px;height:32px;border-radius:8px;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:700}[data-theme=dark] .avatar{color:#04201c}.user-meta{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:13px;font-weight:600}.user-role{font-size:11px;color:var(--text-3)}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap}.pill-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.pill-ok{color:var(--ok);background:var(--ok-soft)}.pill-warn{color:var(--warn);background:var(--warn-soft)}.pill-crit{color:var(--crit);background:var(--crit-soft)}.tone-ok{color:var(--ok)}.tone-warn{color:var(--warn)}.tone-crit{color:var(--crit)}.tone-neutral{color:var(--text)}.screen{max-width:1480px;margin:0 auto}@media(prefers-reduced-motion:no-preference){.screen{animation:fadeUp .35s ease}}@keyframes fadeUp{0%{transform:translateY(10px)}to{transform:none}}.section-head{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.section-head h2{font-size:15.5px}.section-sub{font-size:13px;color:var(--text-3);font-weight:500}.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}.kpi-tile{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}.kpi-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.kpi-label{font-size:13px;font-weight:500;color:var(--text-2)}.kpi-icon{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;background:var(--card-2);border:1px solid var(--border)}.kpi-icon.tone-ok{color:var(--ok);background:var(--ok-soft);border-color:transparent}.kpi-icon.tone-warn{color:var(--warn);background:var(--warn-soft);border-color:transparent}.kpi-icon.tone-crit{color:var(--crit);background:var(--crit-soft);border-color:transparent}.kpi-value-row{display:flex;align-items:baseline;gap:6px;white-space:nowrap}.kpi-value{font-size:30px;font-weight:700;letter-spacing:-.02em}.kpi-suffix{font-size:14px;color:var(--text-3);font-weight:500}.kpi-sub{font-size:12px;color:var(--text-3);margin-top:6px;font-weight:500}.spark{display:block}.spark-empty{background:var(--card-2);border-radius:6px}.gauge{display:flex;flex-direction:column;gap:5px}.gauge-head{display:flex;align-items:baseline;justify-content:space-between}.gauge-label{font-size:11.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}.gauge-val{font-size:17px;font-weight:700;font-family:var(--mono)}.gauge-unit{font-size:11px;color:var(--text-3);font-weight:500;margin-left:3px;font-family:var(--sans)}.batt-ring{position:relative;display:grid;place-items:center;flex-shrink:0}.batt-ring-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1}.batt-pct{font-size:16px;font-weight:700;font-family:var(--mono)}.batt-sub{font-size:8.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em;margin-top:1px;display:flex;align-items:center;gap:2px}.batt-sub.charging{color:var(--ok)}.gw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:18px}.gw-card{padding:20px 22px;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}.gw-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.gw-accent{position:absolute;left:0;top:0;bottom:0;width:4px}.edge-healthy .gw-accent{background:var(--ok)}.edge-warning .gw-accent{background:var(--warn)}.edge-offline .gw-accent{background:var(--crit)}.gw-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.gw-title-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.gw-title-row h3{font-size:17px;white-space:nowrap}.gw-meta{display:flex;flex-direction:column;gap:3px}.eui{font-size:12.5px;color:var(--text-2);letter-spacing:.02em}.gw-loc{font-size:12.5px;color:var(--text-3);font-weight:500}.health-chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:8px}.health-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.health-healthy{color:var(--ok);background:var(--ok-soft)}.health-warning{color:var(--warn);background:var(--warn-soft)}.health-offline{color:var(--crit);background:var(--crit-soft)}.gw-lastseen{font-size:12.5px;color:var(--text-3);margin:12px 0 16px}.gw-lastseen strong{color:var(--text-2);font-weight:600}.stale-flag{margin-left:8px;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--warn);background:var(--warn-soft);padding:1px 6px;border-radius:5px;letter-spacing:.04em}.gw-body{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.gw-power{display:flex;align-items:center;gap:14px}.gw-power-meta{display:flex;flex-direction:column;gap:3px}.gw-power-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.gw-power-state{font-size:13.5px;font-weight:600;white-space:nowrap}.gw-power-state.charging{color:var(--ok)}.gw-power-sleep{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-3);font-weight:500;margin-top:2px}.sleep-led{width:7px;height:7px;border-radius:50%;background:var(--text-3);opacity:.4}.sleep-led.on{background:var(--warn);opacity:1}.gw-signals{display:flex;flex-direction:column;gap:14px}.gw-foot{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:16px}.gw-foot-item{display:flex;flex-direction:column;gap:3px}.gw-foot-label{font-size:11px;color:var(--text-3);font-weight:500}.gw-foot-val{font-size:14px;font-weight:600}.table-card{padding:6px;overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:780px}.data-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);padding:14px 16px;border-bottom:1px solid var(--border)}.data-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{transition:background .12s}.data-table tbody tr:hover{background:var(--card-2)}.row-name{display:flex;align-items:center;gap:11px}.health-dot-lg{width:10px;height:10px;border-radius:50%;flex-shrink:0}.health-dot-lg.health-healthy{background:var(--ok)}.health-dot-lg.health-warning{background:var(--warn)}.health-dot-lg.health-offline{background:var(--crit)}.row-title{font-weight:600;font-size:14px}.row-loc{font-size:12px;color:var(--text-3)}.cell-eui{color:var(--text-2);font-size:12.5px}.cell-rel{color:var(--text-2)}.cell-batt{display:flex;align-items:center;gap:8px}.batt-bar{width:54px;height:7px;border-radius:4px;background:var(--track);overflow:hidden}.batt-bar-fill{height:100%;border-radius:4px}.bs-ok{background:var(--ok)}.bs-warning{background:var(--warn)}.bs-critical{background:var(--crit)}.charge-mini{color:var(--ok);display:inline-flex}.sensor-card{padding:20px 22px}.sensor-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:18px}.sensor-title-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}.sensor-title-row h3{font-size:17px}.sensor-meta{display:flex;flex-direction:column;gap:2px}.sensor-model{font-size:12.5px;color:var(--text-2);font-weight:500}.sensor-lastseen{display:flex;flex-direction:column;align-items:flex-end;gap:2px;text-align:right}.sensor-ls-label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;font-weight:600;white-space:nowrap}.sensor-ls-val{font-size:13.5px;font-weight:600;color:var(--text-2)}.sensor-ls-val.warn{color:var(--warn)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(108px,1fr));gap:12px}.stat-tile{background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:13px 14px}.stat-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:7px}.stat-label{font-size:11.5px;font-weight:600;color:var(--text-2)}.stat-unit{font-size:10.5px;color:var(--text-3);font-weight:500}.stat-value{font-size:23px;font-weight:700;letter-spacing:-.02em;font-family:var(--mono)}.stat-spark{margin-top:8px}.stat-spark .spark{width:100%}.batt-sub.charging{color:var(--ok);margin-top:1px}.segmented{display:inline-flex;background:var(--card-2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}.seg-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:7px;font-size:13px;font-weight:600;color:var(--text-2);transition:all .15s}.seg-btn:hover{color:var(--text)}.seg-btn.active{background:var(--card);color:var(--text);box-shadow:var(--shadow-sm)}[data-theme=dark] .seg-btn.active{background:var(--border-strong)}.seg-sm .seg-btn{padding:6px 11px;font-size:12.5px}.ov-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px}.ov-col{min-width:0}.gw-mini-row{display:flex;flex-direction:column;gap:14px}.gw-mini{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 18px;position:relative;overflow:hidden}.gw-mini:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.gw-mini.edge-healthy:before{background:var(--ok)}.gw-mini.edge-warning:before{background:var(--warn)}.gw-mini.edge-offline:before{background:var(--crit)}.gw-mini-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.gw-mini-name{font-size:15px;font-weight:600;white-space:nowrap}.gw-mini-stats{display:flex;gap:26px;margin-bottom:10px}.gw-mini-stat{display:flex;flex-direction:column;gap:2px}.gw-mini-stat span{font-size:11px;color:var(--text-3);font-weight:500;white-space:nowrap}.gw-mini-stat strong{font-size:15px;font-weight:700;white-space:nowrap}.gw-mini-spark{opacity:.9}.ov-sensor-compact{padding:18px 20px}.ov-sensor-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.ov-sensor-temp{font-size:38px;font-weight:700;letter-spacing:-.03em;font-family:var(--mono);line-height:1}.ov-sensor-temp span{font-size:18px;color:var(--text-3);margin-left:2px}.ov-sensor-head .eui{display:block;margin-top:8px}.ov-sensor-mini{display:flex;gap:24px;padding-top:16px;border-top:1px solid var(--border)}.ov-mini-stat{display:flex;flex-direction:column;gap:3px}.ov-mini-label{font-size:11px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.ov-mini-val{font-size:15px;font-weight:600;font-family:var(--mono)}.alert-list{display:flex;flex-direction:column;gap:10px}.alert-item{display:flex;gap:12px;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm)}.alert-bar{width:3px;align-self:stretch;border-radius:3px}.alert-crit .alert-bar{background:var(--crit)}.alert-warn .alert-bar{background:var(--warn)}.alert-title{font-size:13.5px;font-weight:600}.alert-sub{font-size:12px;color:var(--text-3);margin-top:2px}.empty-inline{display:flex;align-items:center;gap:14px;padding:18px 20px}.ok-check{width:36px;height:36px;border-radius:50%;background:var(--ok-soft);color:var(--ok);display:grid;place-items:center;font-weight:700;font-size:18px;flex-shrink:0}.empty-inline strong{font-size:14px;display:block}.empty-inline span{font-size:12.5px;color:var(--text-3)}.screen-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.fleet-summary{display:flex;align-items:center;gap:10px;font-size:14px}.fleet-count{font-weight:600}.fleet-dot{color:var(--text-3)}.fleet-ok{color:var(--text-2)}.toolbar-controls{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.sort-control{display:flex;align-items:center;gap:8px}.ctrl-label{font-size:11.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}.sensors-layout{display:grid;grid-template-columns:minmax(380px,420px) 1fr;gap:24px;align-items:start}.sensors-cards{display:flex;flex-direction:column;gap:16px}.add-sensor-ghost{display:flex;align-items:center;gap:12px;padding:18px 20px;border:1.5px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-3);font-size:13px;font-weight:500;background:transparent;text-align:left}.add-sensor-ghost:hover{border-color:var(--primary);color:var(--primary)}.add-plus{width:30px;height:30px;border-radius:8px;background:var(--card-2);display:grid;place-items:center;font-size:18px;font-weight:600;flex-shrink:0}.chart-card{padding:22px 24px}.chart-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;flex-wrap:wrap}.chart-card-head h2{font-size:16px;margin-bottom:2px}.chart-controls{display:flex;align-items:center;gap:14px}.dual-toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-2);cursor:pointer;-webkit-user-select:none;user-select:none}.dual-toggle input{display:none}.dual-track{width:36px;height:20px;border-radius:999px;background:var(--track);position:relative;transition:background .2s}.dual-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:var(--shadow-sm);transition:transform .2s}.dual-toggle input:checked+.dual-track{background:var(--primary)}.dual-toggle input:checked+.dual-track .dual-thumb{transform:translate(16px)}.dual-toggle input:disabled+.dual-track{opacity:.4}.chart-selectors{display:flex;gap:24px;margin-bottom:18px;flex-wrap:wrap}.selector-grp{display:flex;align-items:center;gap:10px}.chart-legend{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:7px;font-size:12.5px;font-weight:500;color:var(--text-2)}.legend-swatch{width:11px;height:11px;border-radius:3px}.legend-axis{color:var(--text-3);font-style:italic}.chart-wrap{position:relative;width:100%}.linechart{display:block;overflow:visible}.grid-line{stroke:var(--border);stroke-width:1;stroke-dasharray:3 4;opacity:.7}.axis-label{fill:var(--text-3);font-size:11px;font-family:var(--sans);font-weight:500}.axis-right{fill:var(--text-3)}.hover-line{stroke:var(--text-3);stroke-width:1;stroke-dasharray:3 3;opacity:.6}.chart-tip{position:absolute;top:14px;background:var(--card);border:1px solid var(--border-strong);border-radius:10px;box-shadow:var(--shadow-lg);padding:10px 12px;pointer-events:none;z-index:5;min-width:150px}.tip-time{font-size:11px;color:var(--text-3);font-weight:600;margin-bottom:7px;font-family:var(--mono)}.tip-row{display:flex;align-items:center;gap:7px;font-size:12.5px;margin-top:4px}.tip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tip-label{color:var(--text-2);font-weight:500}.tip-val{margin-left:auto;font-weight:700;font-family:var(--mono)}.chart-state{height:340px;display:grid;place-items:center;border:1px dashed var(--border-strong);border-radius:12px;background:var(--card-2)}.chart-skel,.chart-empty{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-3)}.skel-line{width:280px;height:80px;border-radius:8px;background:linear-gradient(90deg,var(--card-2),var(--border),var(--card-2));background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{width:26px;height:26px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chart-state-text{font-size:14px;font-weight:600;color:var(--text-2)}.chart-state-sub{font-size:12.5px;color:var(--text-3);margin-top:-6px}.placeholder{max-width:920px;margin:8px auto;padding:40px 44px;text-align:center}.ph-badge{width:64px;height:64px;border-radius:16px;margin:0 auto 18px;display:grid;place-items:center;color:var(--primary);background:var(--primary-soft)}.ph-chip{display:inline-block;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);border:1px solid var(--border-strong);border-radius:999px;padding:4px 12px;margin-bottom:14px}.ph-title{font-size:26px;margin-bottom:10px}.ph-blurb{font-size:14.5px;color:var(--text-2);max-width:620px;margin:0 auto 30px;line-height:1.6;text-wrap:pretty}.ph-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;text-align:left;margin-bottom:28px}.ph-tile{background:var(--card-2);border:1px solid var(--border);border-radius:12px;padding:16px;position:relative;overflow:hidden}.ph-tile-bar{height:3px;width:34px;border-radius:3px;background:var(--primary);opacity:.5;margin-bottom:12px}.ph-tile-title{font-size:13.5px;font-weight:600;margin-bottom:3px}.ph-tile-sub{font-size:11.5px;color:var(--text-3);margin-bottom:14px}.ph-skel-rows{display:flex;flex-direction:column;gap:6px}.ph-skel-rows span{height:7px;border-radius:4px;background:var(--border)}.ph-skel-rows span:nth-child(1){width:90%}.ph-skel-rows span:nth-child(2){width:70%}.ph-skel-rows span:nth-child(3){width:80%}.ph-note{font-size:12.5px;color:var(--text-3);font-style:italic}.scenario-fab{position:fixed;right:24px;bottom:24px;z-index:60;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.scenario-trigger{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--border-strong);border-radius:12px;padding:9px 14px;box-shadow:var(--shadow-md)}.scenario-trigger:hover{box-shadow:var(--shadow-lg)}.scenario-trigger-text{display:flex;flex-direction:column;line-height:1.2;text-align:left}.scenario-trigger-label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600}.scenario-trigger-val{font-size:13.5px;font-weight:600}.scenario-fab.open .scenario-trigger svg{transform:rotate(90deg)}.scenario-trigger svg{color:var(--text-3);transition:transform .2s}.scenario-led{width:10px;height:10px;border-radius:50%;flex-shrink:0}.led-nominal{background:var(--ok)}.led-degraded{background:var(--crit)}.led-stale{background:var(--warn)}.led-loading{background:var(--primary)}.led-empty{background:var(--text-3)}.scenario-panel{background:var(--card);border:1px solid var(--border-strong);border-radius:14px;box-shadow:var(--shadow-lg);padding:8px;width:280px;animation:fadeUp .2s ease both}.scenario-panel-head{padding:10px 12px 8px;display:flex;flex-direction:column;gap:2px}.scenario-panel-head span:first-child{font-size:13px;font-weight:700}.scenario-panel-sub{font-size:11.5px;color:var(--text-3);font-weight:500}.scenario-opt{display:flex;align-items:center;gap:11px;width:100%;padding:10px 12px;border-radius:10px;text-align:left;transition:background .12s}.scenario-opt:hover{background:var(--bg-soft)}.scenario-opt.active{background:var(--primary-soft)}.scenario-opt-text{display:flex;flex-direction:column;line-height:1.25;flex:1}.scenario-opt-label{font-size:13.5px;font-weight:600}.scenario-opt-sub{font-size:11.5px;color:var(--text-3)}.scenario-check{color:var(--primary);font-weight:700}.ts-control{display:flex;align-items:flex-end;gap:1px;background:var(--card-2);border:1px solid var(--border);border-radius:9px;padding:3px}.ts-btn{display:grid;place-items:center;min-width:26px;height:30px;border-radius:6px;color:var(--text-2);font-weight:700;line-height:1;transition:all .15s}.ts-btn:hover{color:var(--text)}.ts-btn.active{background:var(--card);color:var(--primary-ink);box-shadow:var(--shadow-sm)}[data-theme=dark] .ts-btn.active{background:var(--border-strong);color:var(--primary-ink)}.ts-sm{font-size:12px}.ts-md{font-size:15px}.ts-lg{font-size:18px}.lang-toggle{display:flex;align-items:center;gap:5px;height:38px;padding:0 11px;border-radius:10px;border:1px solid var(--border);background:var(--card);font-size:12.5px;font-weight:600;color:var(--text-3)}.lang-toggle:hover{background:var(--bg-soft)}.lang-toggle .lang-on{color:var(--primary-ink)}.lang-div{color:var(--border-strong);font-weight:400}.loc-btn{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;padding:2px 0;color:var(--text-3);font-size:12.5px;font-weight:500;text-align:left;border-radius:6px;transition:color .15s}.loc-btn:hover{color:var(--primary)}.loc-btn svg{color:var(--primary);flex-shrink:0}.loc-name{color:var(--text-2);font-weight:500}.loc-btn:hover .loc-name{color:var(--primary)}.loc-coords{font-size:11px;color:var(--text-3);border-left:1px solid var(--border);margin-left:2px;padding-left:8px}.modal-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#080b128c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:80;display:grid;place-items:center;padding:20px;opacity:1}@media(prefers-reduced-motion:no-preference){.modal{animation:popIn .16s ease}}@keyframes popIn{0%{transform:translateY(8px) scale(.99)}to{transform:none}}.modal{background:var(--card);border:1px solid var(--border-strong);border-radius:18px;box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:92vh;overflow-y:auto}.loc-modal{padding:22px}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px}.modal-head h2{font-size:18px}.modal-sub{font-size:12.5px;color:var(--text-3);display:block;margin-top:3px}.modal-close{width:34px;height:34px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-ghost{padding:10px 18px;border-radius:10px;border:1px solid var(--border-strong);background:var(--card);font-size:14px;font-weight:600;color:var(--text-2)}.btn-ghost:hover{background:var(--bg-soft)}.btn-primary{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:10px;background:var(--primary);color:#fff;font-size:14px;font-weight:600}[data-theme=dark] .btn-primary{color:#04201c}.btn-primary:hover{background:var(--primary-ink)}.map-picker{position:relative;height:220px;border-radius:14px;overflow:hidden;cursor:crosshair;border:1px solid var(--border);background:linear-gradient(135deg,#e8eef0,#dde6e6)}[data-theme=dark] .map-picker{background:linear-gradient(135deg,#16202e,#10212a)}.map-tiles{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:34px 34px;opacity:.45}.map-road{position:absolute;background:var(--card);opacity:.9}[data-theme=dark] .map-road{background:#243244;opacity:.8}.map-road-h{left:0;right:0;height:10px}.map-road-v{top:0;bottom:0;width:10px}.map-road-diag{width:160%;height:12px;top:50%;left:-30%;transform:rotate(28deg);transform-origin:center}.map-park{position:absolute;width:90px;height:64px;border-radius:10px;background:#bfe3c8;opacity:.7}[data-theme=dark] .map-park{background:#1c3a2a}.map-pin{position:absolute;transform:translate(-50%,-100%);color:var(--crit);filter:drop-shadow(0 3px 4px rgba(0,0,0,.35));transition:left .15s ease,top .15s ease;pointer-events:none}.map-pin svg{stroke-width:2}.map-readout{position:absolute;left:10px;bottom:10px;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:5px 10px;font-size:12px;font-weight:600;color:var(--text);box-shadow:var(--shadow-sm)}.map-attr{position:absolute;right:8px;top:8px;background:color-mix(in srgb,var(--card) 80%,transparent);border-radius:6px;padding:3px 8px;font-size:10px;color:var(--text-3);font-weight:500}.loc-method{margin:16px 0 14px}.loc-body{min-height:60px}.loc-hint{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-3);background:var(--card-2);border:1px dashed var(--border-strong);border-radius:10px;padding:14px 16px}.loc-hint svg{color:var(--primary)}.coord-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field{display:flex;flex-direction:column;gap:6px}.field-label{font-size:11.5px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}.field-input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid var(--border-strong);background:var(--card-2);color:var(--text);font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s}.field-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.addr-search{display:flex;gap:8px}.addr-search .field-input{flex:1}.btn-search{display:inline-flex;align-items:center;gap:6px;padding:0 16px;border-radius:10px;background:var(--primary);color:#fff;font-size:13.5px;font-weight:600;white-space:nowrap}[data-theme=dark] .btn-search{color:#04201c}.btn-search:hover{background:var(--primary-ink)}.addr-results{display:flex;flex-direction:column;gap:6px;margin-top:10px}.addr-result{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:10px;border:1px solid var(--border);background:var(--card-2);text-align:left;transition:all .12s}.addr-result:hover{border-color:var(--primary);background:var(--primary-soft)}.addr-result svg{color:var(--primary);flex-shrink:0}.addr-result-label{flex:1;font-size:13px;font-weight:500;color:var(--text)}.addr-result-coords{font-size:11px;color:var(--text-3)}.loc-label-field{margin-top:16px}@media(max-width:1180px){.sensors-layout,.ov-grid{grid-template-columns:1fr}}@media(max-width:1024px){.sidebar{position:fixed;left:0;top:0;bottom:0;transform:translate(-100%);box-shadow:var(--shadow-lg)}.sidebar.open{transform:none}.sidebar-scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:35}.menu-btn{display:grid}.kpi-strip,.ph-tiles{grid-template-columns:repeat(2,1fr)}.region-chip,.live-sep,.live-refresh,.user-meta{display:none}}@media(max-width:680px){.content{padding:18px 16px 80px}.topbar{padding:0 16px;gap:8px}.kpi-strip{grid-template-columns:1fr 1fr;gap:12px}.kpi-value{font-size:24px}.gw-grid{grid-template-columns:1fr}.gw-body{grid-template-columns:1fr;gap:18px}.stat-grid{grid-template-columns:repeat(2,1fr)}.env-badge{display:none}.gw-mini-stats{gap:18px}.ph-tiles{grid-template-columns:1fr}.scenario-fab{right:14px;bottom:14px}.scenario-panel{width:min(280px,calc(100vw - 28px))}.chart-tip{display:none}}
