:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#eef2f3;color:#17212b;font-synthesis:none;text-rendering:optimizeLegibility;--bg: #eef2f3;--panel: #ffffff;--panel-soft: #f8faf9;--text: #17212b;--muted: #64717d;--border: #dbe2e5;--line: #e9eef0;--ok: #14845f;--ok-soft: #e7f6ef;--warn: #b76211;--warn-soft: #fff3df;--danger: #c5332e;--danger-soft: #fdeceb;--blue: #2563a8;--blue-soft: #e8f1fb;--shadow: 0 14px 36px rgba(25, 39, 52, .08)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}button,input,select,textarea{font:inherit}button{cursor:pointer}.boot,.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px}.boot{font-size:22px;font-weight:800}.login-panel{width:min(420px,100%);background:var(--panel);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px;padding:28px;display:grid;gap:18px}.brand-lockup,.side-brand{display:flex;align-items:center;gap:12px}.brand-mark{width:42px;height:42px;display:grid;place-items:center;border-radius:8px;background:#0f766e;color:#fff;flex:0 0 auto}.brand-lockup h1,.topbar h1,.section-head h2{margin:0;letter-spacing:0}.brand-lockup h1{font-size:24px;line-height:1.1}.brand-lockup p,.topbar p,.section-head p{margin:4px 0 0;color:var(--muted);font-size:14px;line-height:1.4}label{display:grid;gap:7px;color:#2b3a45;font-size:13px;font-weight:700}input,select,textarea{width:100%;border:1px solid var(--border);background:#fff;color:var(--text);border-radius:6px;padding:11px 12px;outline:none}input:focus,select:focus,textarea:focus{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e1f}.primary-button,.secondary-button,.icon-button,.text-button,.logout-button,.nav-button{border:0;border-radius:6px;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;font-size:14px;font-weight:800}.primary-button{background:#0f766e;color:#fff}.secondary-button{background:#17313f;color:#fff;padding:0 14px}.primary-button:disabled,.secondary-button:disabled{opacity:.48;cursor:default}.icon-button{width:40px;background:var(--panel);color:var(--text);border:1px solid var(--border)}.text-button{background:transparent;color:#0f766e;padding:0}.form-error{color:var(--danger);margin:0;font-weight:700}.success-message{margin:10px 0 0;color:var(--ok);font-weight:700}.app-shell{min-height:100vh;display:grid;grid-template-columns:248px 1fr}.sidebar{background:#17212b;color:#e7edf0;padding:20px 14px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.side-brand{padding:2px 6px 12px;font-weight:900;font-size:18px}.sidebar nav{display:grid;gap:6px}.nav-button,.logout-button{width:100%;justify-content:flex-start;background:transparent;color:#b9c5cc;padding:10px 12px}.nav-button svg,.logout-button svg{width:19px}.nav-button.active{background:#263644;color:#fff}.nav-button b{margin-left:auto;min-width:24px;height:22px;border-radius:999px;display:grid;place-items:center;color:#fff;background:var(--danger);font-size:12px}.logout-button{margin-top:auto}.workspace{padding:22px;display:grid;align-content:start;gap:18px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px}.topbar h1{font-size:28px;line-height:1.05}.top-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.health-pill{height:38px;display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:0 12px;font-size:13px;font-weight:800;border:1px solid transparent}.health-pill.ok{background:var(--ok-soft);color:var(--ok)}.health-pill.warn{background:var(--warn-soft);color:var(--warn)}.health-pill.danger{background:var(--danger-soft);color:var(--danger)}.health-pill.muted{background:#eef2f3;color:var(--muted)}.error-banner{background:var(--danger-soft);color:var(--danger);border:1px solid #f3c4c1;padding:12px 14px;border-radius:8px;font-weight:800}.data-banner{display:flex;align-items:center;gap:10px;border-radius:8px;padding:12px 14px;border:1px solid var(--border)}.data-banner strong{flex:0 0 auto;font-size:14px}.data-banner span{color:inherit;font-size:14px;font-weight:700;line-height:1.35}.data-banner.warn{background:var(--warn-soft);color:var(--warn);border-color:#f0c98f}.data-banner.danger{background:var(--danger-soft);color:var(--danger);border-color:#f3c4c1}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px}.dashboard-grid>.main-panel:not(.full),.dashboard-grid>.alert-panel{align-self:start}.history-panel{overflow:hidden}.metric-row,.health-band{grid-column:1 / -1;display:grid;gap:12px}.metric-row{grid-template-columns:repeat(6,minmax(0,1fr))}.metric,.main-panel,.alert-panel,.health-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;box-shadow:0 1px 1px #10182808}.metric{padding:16px;display:grid;grid-template-columns:42px 1fr;grid-template-rows:auto auto;gap:3px 12px}.metric div{grid-row:1 / 3;width:42px;height:42px;border-radius:8px;display:grid;place-items:center}.metric.ok div{background:var(--ok-soft);color:var(--ok)}.metric.warn div{background:var(--warn-soft);color:var(--warn)}.metric.danger div{background:var(--danger-soft);color:var(--danger)}.metric.neutral div{background:var(--blue-soft);color:var(--blue)}.metric span{color:var(--muted);font-weight:800;font-size:13px}.metric strong{font-size:28px;line-height:1}.range-control{display:inline-flex;align-items:center;gap:4px;padding:4px;background:#eef2f3;border:1px solid var(--border);border-radius:8px;flex:0 0 auto}.range-control button{border:0;min-width:48px;height:32px;border-radius:6px;background:transparent;color:#42505c;font-size:13px;font-weight:900}.range-control button.active{background:var(--panel);color:#0f766e;box-shadow:0 1px 3px #1018281a}.history-layout{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(220px,.7fr);gap:18px;align-items:stretch}.trend-chart{min-width:0;display:grid;gap:10px}.chart-legend{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:12px;font-weight:900}.chart-legend span{display:inline-flex;align-items:center;gap:6px}.legend-dot{width:10px;height:10px;border-radius:999px;display:inline-block}.legend-dot.temp{background:#0f766e}.legend-dot.humidity{background:#b76211}.legend-band{width:18px;height:8px;display:inline-block;border-radius:3px;background:#14845f1c}.trend-chart svg{width:100%;height:clamp(230px,30vw,320px);display:block}.comfort-band{fill:#14845f1a}.grid-line{stroke:#e2e8ea;stroke-width:1}.axis-label{fill:#6a7782;font-size:12px;font-weight:800}.humidity-axis{fill:#9a5a13}.history-line{fill:none;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round}.history-line.temp{stroke:#0f766e}.history-line.humidity{stroke:#b76211;stroke-dasharray:7 7}.history-point.temp{fill:#fff;stroke:#0f766e;stroke-width:2.5}.history-summary{display:grid;align-content:stretch;gap:10px}.history-stat{min-height:88px;display:grid;align-content:center;gap:4px;padding:13px 14px;border-left:4px solid var(--border);background:var(--panel-soft);border-radius:6px}.history-stat.ok{border-color:var(--ok)}.history-stat.warn{border-color:var(--warn)}.history-stat.danger{border-color:var(--danger)}.history-stat.muted{border-color:#98a5ae}.history-stat span{color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:900}.history-stat strong{font-size:24px;line-height:1}.history-stat p{margin:0;color:var(--muted);font-size:12px;font-weight:800}.main-panel,.alert-panel{padding:18px;min-width:0}.alert-panel{grid-column:2;grid-row:3 / span 2;display:grid;grid-template-rows:auto minmax(0,1fr);max-height:min(560px,calc(100vh - 180px));overflow:hidden}.main-panel.full,.health-band,.admin-grid .full{grid-column:1 / -1}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.section-head.tight{align-items:center}.section-head h2{font-size:18px}.table-wrap{overflow-x:auto}.equipment-table{width:100%;border-collapse:collapse;min-width:720px}.equipment-table th{text-align:left;color:var(--muted);font-size:12px;text-transform:uppercase;padding:10px 8px;border-bottom:1px solid var(--line)}.sort-header{display:inline-flex;align-items:center;gap:5px;min-height:30px;max-width:100%;padding:0;border:0;background:transparent;color:inherit;font:inherit;text-align:left;text-transform:inherit}.sort-header span{min-width:0}.sort-header svg{flex:0 0 auto;color:#7b8791}.sort-header.active{color:#17352e}.sort-header.active svg{color:#0f766e}.sort-header:hover,.sort-header:focus-visible{color:#0f766e;outline:none}.equipment-table td{padding:13px 8px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}.equipment-table td strong,.wide-row strong,.alert-item strong{display:block;font-size:14px}.equipment-table td span{display:block;color:var(--muted);font-size:12px;margin-top:2px}.number{font-weight:900;font-variant-numeric:tabular-nums}.state{display:inline-flex;align-items:center;min-height:24px;border-radius:999px;padding:0 9px;font-size:12px;font-weight:900}.state.ok{background:var(--ok-soft);color:var(--ok)}.state.warn{background:var(--warn-soft);color:var(--warn)}.state.danger{background:var(--danger-soft);color:var(--danger)}.state.muted{background:#eef2f3;color:var(--muted)}.value-cell.danger{color:var(--danger)}.value-cell.warn{color:var(--warn)}.mode-code{display:inline-flex;align-items:center;min-height:24px;border-radius:6px;padding:0 8px;background:#eef2f3;color:#42505c;font-size:12px;font-weight:900}.alert-list,.stack-list{display:grid;gap:10px}.alert-panel .alert-list{min-height:0;overflow-y:auto;overscroll-behavior:contain;padding-right:4px;scrollbar-gutter:stable}.alert-item,.wide-row{display:grid;grid-template-columns:10px 1fr auto;gap:12px;align-items:start;border:1px solid var(--line);border-radius:8px;padding:12px;background:var(--panel-soft)}.alert-item{grid-template-columns:10px 1fr}.alert-item p,.wide-row p,.health-card p{margin:4px 0 0;color:var(--muted);font-size:13px;line-height:1.4}.alert-item small,.wide-row small{display:block;color:var(--muted);font-weight:700;line-height:1.35}.alarm-actions{display:grid;justify-items:end;gap:8px;min-width:132px}.alarm-actions span{color:var(--muted);font-size:12px;font-weight:800;white-space:nowrap}.clear-alarm-button{display:inline-flex;align-items:center;justify-content:center;min-height:30px;border:1px solid #f0c98f;border-radius:6px;background:#fff9ee;color:var(--warn);padding:0 10px;font-size:12px;font-weight:900}.alert-item .clear-alarm-button{margin-top:9px}.status-dot{width:10px;height:10px;border-radius:999px;margin-top:5px;background:var(--muted)}.status-dot.warn{background:var(--warn)}.status-dot.danger{background:var(--danger)}.health-band{grid-column:1;grid-row:4;grid-template-columns:repeat(2,minmax(0,1fr))}.history-insights{grid-row:5}.health-card{padding:16px}.health-card span{color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:900}.health-card strong{display:block;margin-top:8px;font-size:20px}.history-insights{grid-column:1 / -1;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.insight-panel{min-width:0}.insight-list{display:grid;gap:8px}.insight-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;min-height:76px;padding:10px 0;border-bottom:1px solid var(--line)}.insight-row:last-child{border-bottom:0}.insight-row strong{display:block;font-size:14px}.insight-row span,.insight-row p{display:block;margin:2px 0 0;color:var(--muted);font-size:12px;line-height:1.35}.insight-row b{color:#17313f;font-size:22px;font-variant-numeric:tabular-nums}.empty-state{border:1px dashed var(--border);border-radius:8px;padding:20px;color:var(--muted);text-align:center;font-weight:800}.search-input{max-width:300px}.equipment-actions .search-input{width:100%;max-width:none}.equipment-actions{display:grid;grid-template-columns:minmax(360px,1fr) minmax(240px,270px) minmax(200px,220px);align-items:center;justify-items:stretch;gap:10px;width:100%;min-width:0;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}.sort-controls{display:inline-grid;grid-template-columns:auto minmax(150px,1fr) 34px;align-items:center;gap:7px;width:100%;max-width:none;color:var(--muted);font-size:12px;font-weight:900}.sort-controls select{height:34px;min-width:0;border:1px solid var(--border);border-radius:6px;background:var(--panel);color:#1d2a33;font:inherit;text-transform:none;padding:0 9px}.sort-direction-button{width:34px;height:34px;display:inline-grid;place-items:center;border:1px solid var(--border);border-radius:6px;background:var(--panel);color:#0f766e}.sort-direction-button:hover,.sort-direction-button:focus-visible{border-color:#0f766e;background:var(--ok-soft);outline:none}.equipment-page{display:grid;gap:16px}.equipment-page .section-head{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:0}.compare-toolbar{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}.compare-toolbar>div:first-child,.compare-actions{display:flex;align-items:center;gap:10px;min-width:0}.compare-toolbar strong{white-space:nowrap}.compare-toolbar span{color:var(--muted);font-size:13px;font-weight:800;line-height:1.35}.compare-actions .text-button:disabled{opacity:.45;cursor:default}.equipment-workspace{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,380px);gap:18px;align-items:start}.equipment-table-panel{min-width:0}.filter-chips{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:6px}.filter-chip{border:1px solid var(--border);background:var(--panel);color:#42505c;border-radius:999px;min-height:30px;padding:0 10px;font-size:12px;font-weight:900}.filter-chip.active{border-color:#0f766e;background:#e7f6ef;color:#0f766e}.equipment-table.selectable tbody tr{cursor:pointer}.equipment-table.selectable tbody tr:hover,.equipment-table tbody tr.focused{background:#f6fbf9}.equipment-table tbody tr.selected{background:#fbfdfc}.equipment-table tbody tr.focused{box-shadow:inset 3px 0 #0f766e}.select-col{width:72px;text-align:center}.select-button{width:34px;height:34px;display:inline-grid;place-items:center;border:0;border-radius:6px;background:transparent;color:#0f766e}.select-button:hover,.select-button:focus-visible{background:var(--ok-soft);outline:none}.equipment-detail{min-width:0;display:grid;gap:14px;padding-left:18px;border-left:1px solid var(--line)}.detail-title{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.detail-title h3,.detail-section h4,.chart-head h3{margin:0;letter-spacing:0}.detail-title h3{font-size:18px;line-height:1.15}.detail-title p{margin:4px 0 0;color:var(--muted);font-size:13px;font-weight:800;line-height:1.35}.detail-warning{display:grid;grid-template-columns:18px 1fr;gap:8px;align-items:start;padding:10px;border:1px solid #f0c98f;border-radius:8px;background:var(--warn-soft);color:var(--warn);font-size:12px;font-weight:900;line-height:1.35}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.device-chart-stack{display:grid;gap:14px}.detail-stat{min-height:68px;display:grid;align-content:center;gap:4px;padding:10px;border-radius:8px;background:var(--panel-soft);border:1px solid var(--line)}.detail-stat span,.info-list dt,.chart-head span,.notes-actions small{color:var(--muted);font-size:12px;font-weight:900}.detail-stat span,.info-list dt{text-transform:uppercase}.detail-stat strong{font-size:19px;font-variant-numeric:tabular-nums}.detail-section{display:grid;gap:8px}.detail-section h4{font-size:13px}.info-list{display:grid;gap:7px;margin:0}.info-list div{display:grid;grid-template-columns:86px minmax(0,1fr);gap:8px}.info-list dd{margin:0;color:#2b3a45;font-size:13px;font-weight:800;line-height:1.35}.point-list{display:grid;gap:6px}.point-list div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}.point-list div:last-child{border-bottom:0}.point-list span{overflow:hidden;color:var(--muted);font-size:12px;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.point-list strong{font-size:12px;font-variant-numeric:tabular-nums}.muted-copy{margin:0;color:var(--muted);font-size:13px;font-weight:800;line-height:1.4}.notes-editor{gap:8px}.notes-editor span{display:inline-flex;align-items:center;gap:7px}.notes-editor textarea{min-height:128px;resize:vertical;line-height:1.45}.notes-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.comparison-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.comparison-card{position:relative;min-width:0;display:grid;gap:10px;padding-top:16px;border-top:1px solid var(--line)}.comparison-card:not(.compact-chart){grid-template-rows:auto 56px auto}.chart-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.chart-head h3{font-size:16px}.chart-head span{text-align:right;line-height:1.35}.comparison-legend{display:flex;flex-wrap:wrap;gap:8px 12px;color:var(--muted);font-size:12px;font-weight:900}.comparison-card:not(.compact-chart) .comparison-legend{min-height:56px;max-height:56px;align-content:flex-start;overflow-y:auto;padding-right:4px}.comparison-legend span{display:inline-flex;align-items:center;gap:6px;max-width:210px}.comparison-legend i{width:10px;height:10px;border-radius:999px;flex:0 0 auto}.mode-legend.comfort i{border-radius:3px;background:#14845f2e}.mode-legend.economy i{border-radius:3px;background:#b762112e}.comparison-card svg{width:100%;height:clamp(230px,26vw,310px);display:block;cursor:crosshair;touch-action:pan-y}.comparison-card svg:focus-visible{border-radius:6px;outline:3px solid rgba(15,118,110,.2);outline-offset:3px}.scrub-readout{display:grid;gap:8px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}.comparison-card:not(.compact-chart) .scrub-readout{position:absolute;z-index:2;top:86px;right:10px;width:min(320px,calc(100% - 20px));max-height:156px;overflow-y:auto;background:#fafcfbf5;box-shadow:0 14px 34px #16252f24}.scrub-readout>strong{color:#1c2d38;font-size:13px;font-weight:900}.scrub-readout>div{display:grid;gap:6px}.scrub-readout span{display:grid;grid-template-columns:10px minmax(0,1fr) auto;gap:7px;align-items:center;color:var(--muted);font-size:12px;font-weight:800}.scrub-readout i{width:10px;height:10px;border-radius:999px}.scrub-readout b{overflow:hidden;color:#273946;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.scrub-readout em{color:#17212b;font-style:normal;font-variant-numeric:tabular-nums;font-weight:950}.scrub-readout small{grid-column:2 / 4;color:var(--muted);font-size:11px;font-weight:800}.scrub-hit-area{fill:transparent;pointer-events:all}.compact-chart{gap:8px}.compact-chart .chart-head{flex-direction:column;gap:3px}.compact-chart .chart-head span{text-align:left}.compact-chart .comparison-legend{gap:6px 10px}.compact-chart .comparison-legend span{max-width:100%}.compact-chart svg{height:190px}.mode-band.comfort{fill:#14845f1a}.mode-band.economy{fill:#b762111a}.compare-line{fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.compare-point{stroke-width:2.3}.compare-point.alarm{stroke-width:2}.scrub-line{stroke:#17212b;stroke-dasharray:4 4;stroke-width:1.4}.scrub-point{fill:#fff;stroke-width:3}.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.map-page{display:grid;gap:14px}.map-page .section-head{margin-bottom:0}.map-head-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.map-lock-toggle.unlocked{background:var(--warn)}.map-toolbar{display:flex;align-items:center;gap:6px;min-width:0;padding:8px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft);overflow-x:auto}.map-tool-button{min-height:36px;display:inline-flex;align-items:center;justify-content:center;gap:7px;border:1px solid transparent;border-radius:6px;background:transparent;color:#42505c;padding:0 10px;font-size:13px;font-weight:900;white-space:nowrap}.map-tool-button.active{border-color:#b8d6d1;background:#fff;color:#0f766e;box-shadow:0 1px 3px #10182814}.map-tool-button:disabled{opacity:.42;cursor:default}.map-draft-actions{display:inline-flex;align-items:center;gap:10px;margin-left:auto;padding-left:8px;white-space:nowrap}.map-draft-actions .text-button:disabled,.map-inspector .icon-button:disabled{opacity:.4;cursor:default}.map-merge-actions span{color:#42505c;font-size:12px;font-weight:900}.map-workspace{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,360px);gap:16px;align-items:start}.map-canvas-shell{min-width:0;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:#fff}.floor-map{width:100%;aspect-ratio:1000 / 620;display:block;background:#f8faf9;touch-action:none}.floor-map.tool-wall{cursor:crosshair}.floor-map.tool-device{cursor:copy}.floor-map.tool-merge{cursor:pointer}.floor-map.dragging,.floor-map.dragging .map-device,.floor-map.dragging .wall-boundary{cursor:grabbing}.floor-map.tool-inspect,.floor-map.tool-heat{cursor:default}.floor-map.unlocked.tool-inspect,.floor-map.unlocked.tool-heat{cursor:grab}.map-base{fill:#f4f7f6}.map-plan-shell{fill:#fff;stroke:#cfd9dd;stroke-width:2}.uploaded-map-image{opacity:.66}.fallback-plan-lines{fill:none;stroke:#b7c5cb;stroke-dasharray:8 9;stroke-linecap:round;stroke-width:2;opacity:.75}.heat-layer{mix-blend-mode:multiply;pointer-events:none}.boundary-heat-fill{opacity:.18}.wall-boundary{fill:#ffffff03;stroke-width:8;stroke-linecap:round;stroke-linejoin:round;vector-effect:non-scaling-stroke;opacity:.84}.floor-map.unlocked .wall-boundary{cursor:move}.wall-boundary.selected{stroke-width:11;opacity:1}.wall-boundary.merge-selected{fill:#0f766e2e;stroke-dasharray:18 10;opacity:1}.boundary-label{fill:#17212b;paint-order:stroke;stroke:#ffffffdb;stroke-linejoin:round;stroke-width:4px;font-size:15px;font-weight:950;pointer-events:none}.boundary-label tspan+tspan{fill:#42505c;font-size:12px;font-weight:900}.draft-layer{pointer-events:none}.draft-layer polyline,.draft-layer line{fill:none;stroke:#17212b;stroke-dasharray:10 7;stroke-linecap:round;stroke-linejoin:round;stroke-width:4}.draft-layer line{opacity:.32}.draft-layer circle{fill:#fff;stroke:#0f766e;stroke-width:3}.map-device{cursor:pointer}.floor-map.unlocked .map-device{cursor:move}.map-device-spread{opacity:.18}.map-device-pin{stroke:#fff;stroke-width:4;filter:drop-shadow(0 4px 7px rgba(23,33,43,.22))}.map-device.selected .map-device-pin{stroke:#17212b;stroke-width:5}.map-device-temp{fill:#17212b;paint-order:stroke;stroke:#fffffff0;stroke-linejoin:round;stroke-width:5px;font-size:13px;font-weight:950;pointer-events:none}.map-statusbar{min-height:42px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:9px 12px;border-top:1px solid var(--line);background:var(--panel-soft);color:var(--muted);font-size:12px;font-weight:900}.map-statusbar span,.map-statusbar strong{display:inline-flex;align-items:center;gap:6px}.map-statusbar strong{color:#273946;margin-left:auto}.map-inspector{min-width:0;display:grid;gap:14px;padding-left:16px;border-left:1px solid var(--line)}.map-inspector-section{display:grid;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--line)}.map-inspector-section:last-child{padding-bottom:0;border-bottom:0}.map-inspector h3{margin:0;font-size:14px;letter-spacing:0}.map-inspector-title{display:flex;align-items:center;justify-content:space-between;gap:10px}.icon-button.compact{width:34px;min-height:34px}.map-boundary-summary{display:grid;gap:3px}.map-trace-panel{display:grid;gap:7px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--panel-soft)}.map-trace-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;color:var(--muted);font-size:11px;font-weight:900}.map-trace-note{margin:0;color:#42505c;font-size:12px;font-weight:850;line-height:1.35}.map-boundary-summary strong,.selected-device-editor strong{color:#17212b;font-size:15px}.map-boundary-summary span,.selected-device-editor span{color:var(--muted);font-size:12px;font-weight:800;line-height:1.35}.map-list{display:grid;gap:6px;max-height:220px;overflow-y:auto;padding-right:2px}.map-list-row{width:100%;min-height:48px;display:grid;grid-template-columns:10px minmax(0,1fr) auto;align-items:center;gap:9px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:8px 9px;text-align:left}.map-list-row.active{border-color:#b8d6d1;background:#f6fbf9}.map-list-row.merge-selected{border-color:#0f766e;background:#eef8f5}.map-list-row i{width:10px;height:28px;border-radius:999px}.map-list-row span{min-width:0;display:grid;gap:1px}.map-list-row strong{overflow:hidden;color:#273946;font-size:13px;text-overflow:ellipsis;white-space:nowrap}.map-list-row small{color:var(--muted);font-size:11px;font-weight:800}.map-list-row b{color:#17212b;font-size:13px;font-variant-numeric:tabular-nums}.map-field{gap:6px}.map-field input[type=range]{padding:0}.selected-device-editor{display:grid;gap:10px}.selected-device-editor>div{display:grid;gap:3px}.map-toggle{display:flex;grid-template-columns:none;align-items:center;gap:8px}.map-toggle input{width:17px;height:17px;flex:0 0 auto}.heat-scale{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:8px;color:var(--muted);font-size:12px;font-weight:900}.heat-scale i{height:12px;border-radius:999px;background:linear-gradient(90deg,#2563a8,#0f766e,#b76211,#c5332e)}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.csv-box{min-height:220px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.rules-grid{display:grid;gap:8px}.rule-row{display:grid;grid-template-columns:1.4fr 1fr 110px 60px;gap:10px;align-items:center;padding:10px;border:1px solid var(--line);border-radius:8px}.rule-row label{display:flex;align-items:center;gap:8px}.rule-row input[type=checkbox]{width:16px}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:1180px){.equipment-actions{grid-template-columns:minmax(0,1fr) minmax(240px,270px)}.equipment-actions .filter-chips{grid-column:1 / -1}}@media(max-width:980px){.app-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;padding:12px;display:grid;grid-template-columns:1fr}.sidebar nav{display:flex;overflow-x:auto}.side-brand{padding-bottom:0}.logout-button{display:none}.nav-button{width:auto;white-space:nowrap}.workspace{padding:14px}.topbar,.section-head{flex-direction:column;align-items:stretch}.top-actions{justify-content:flex-start}.dashboard-grid,.history-layout,.history-insights,.equipment-workspace,.comparison-grid,.map-workspace,.admin-grid{grid-template-columns:1fr}.metric-row{grid-template-columns:repeat(3,minmax(0,1fr))}.health-band{grid-template-columns:1fr 1fr}.equipment-actions{justify-items:stretch;min-width:0}.sort-controls,.search-input{max-width:none;width:100%}.compare-toolbar,.compare-actions,.chart-head{align-items:stretch;flex-direction:column}.compare-actions{gap:10px}.equipment-detail,.map-inspector{padding:16px 0 0;border-left:0;border-top:1px solid var(--line)}.filter-chips{justify-content:flex-start}.range-control{width:max-content}.chart-head span{text-align:left}.alert-panel,.main-panel{grid-column:1}.dashboard-grid>.main-panel:not(.full),.dashboard-grid>.alert-panel,.health-band,.history-insights{grid-row:auto}.alert-panel{max-height:none;overflow:visible}.alert-panel .alert-list{overflow:visible;padding-right:0}}@media(max-width:620px){.equipment-actions{grid-template-columns:1fr}.equipment-actions .filter-chips{grid-column:auto}.health-band,.form-grid,.rule-row{grid-template-columns:1fr}.metric-row,.history-summary{grid-template-columns:1fr 1fr}.map-head-actions,.map-toolbar,.map-statusbar{align-items:stretch;flex-direction:column}.map-head-actions .primary-button,.map-head-actions .secondary-button,.map-tool-button{width:100%}.map-draft-actions{width:100%;justify-content:space-between;margin-left:0;padding-left:0}.map-statusbar strong{margin-left:0}.detail-grid,.info-list div{grid-template-columns:1fr}.select-col{width:54px}.range-control{width:100%}.range-control button{flex:1;min-width:0}.trend-chart svg{height:240px}.metric{padding:14px;grid-template-columns:36px 1fr;gap:2px 10px}.metric div{width:36px;height:36px}.metric strong{font-size:24px}.metric span{font-size:12px}.topbar h1{font-size:24px}.health-pill{height:34px;font-size:12px}.data-banner{align-items:flex-start;flex-direction:column}.equipment-table{min-width:0}.equipment-table .mode-col,.equipment-table .status-col,.equipment-table .updated-col{display:none}.equipment-table th,.equipment-table td{padding:11px 6px}.wide-row{grid-template-columns:10px 1fr}.alarm-actions{grid-column:2;justify-items:start}.equipment-table th{font-size:11px}.equipment-table td{font-size:13px}}@media(max-width:440px){.history-summary{grid-template-columns:1fr}.insight-row{align-items:start}.insight-row b{font-size:19px}}
