html,body{height:100%;width:100%;margin:0;padding:0}body{overflow:hidden;background:#0b0f14;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#app{height:100%;width:100%;overflow:hidden}*,*:before,*:after{box-sizing:border-box}button{font:inherit;background:none;border:none;outline:none}input{font:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#ffffff38}.login-page[data-v-5a566eea]{height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;background:var(--bg);font-family:DM Sans,system-ui,-apple-system,sans-serif}.login-card[data-v-5a566eea]{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px 24px}.login-header[data-v-5a566eea]{text-align:center;margin-bottom:28px}.login-logo[data-v-5a566eea]{font-size:24px;font-weight:800;color:var(--accent);letter-spacing:-.02em}.login-subtitle[data-v-5a566eea]{font-size:13px;color:var(--muted);margin-top:6px}.user-list[data-v-5a566eea]{display:flex;flex-direction:column;gap:8px}.user-option[data-v-5a566eea]{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;transition:border-color .2s,background .2s}.user-option[data-v-5a566eea]:hover{border-color:#22d3a74d;background:#22d3a70a}.user-avatar[data-v-5a566eea]{width:38px;height:38px;border-radius:10px;background:var(--accent-dim);color:var(--accent);font-weight:700;font-size:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-info[data-v-5a566eea]{flex:1;min-width:0}.user-name[data-v-5a566eea]{font-weight:600;font-size:14px;color:var(--text)}.user-email[data-v-5a566eea]{font-size:12px;color:var(--muted);margin-top:2px}.role-badge[data-v-5a566eea]{font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap;flex-shrink:0}.role-badge.contractor[data-v-5a566eea]{background:#6366f11f;color:#818cf8;border:1px solid rgba(99,102,241,.2)}.role-badge.homeowner[data-v-5a566eea]{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(34,211,167,.2)}.role-badge.property_manager[data-v-5a566eea]{background:#eab3081f;color:var(--yellow);border:1px solid rgba(234,179,8,.2)}.login-footer[data-v-5a566eea]{text-align:center;font-size:11px;color:var(--muted);margin-top:20px;opacity:.6}:root{--bg: #0b0f14;--surface: #131920;--border: #1e2a36;--text: #d4dce6;--muted: #5a6e80;--accent: #22d3a7;--accent-dim: #1a3d34;--red: #f0544c;--yellow: #eab308;--green: #22d3a7}.app{height:100vh;width:100vw;overflow:hidden;display:grid;grid-template-columns:340px 1fr;background:var(--bg);color:var(--text);font-family:DM Sans,system-ui,-apple-system,sans-serif}.sidebar,.main,.map-wrap{min-height:0;min-width:0}.sidebar{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}.sidebar-header{padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-header-top{display:flex;align-items:flex-start;justify-content:space-between}.btn-logout{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.btn-logout:hover{color:var(--red);border-color:#f0544c4d}.title{font-weight:700;font-size:16px;color:var(--text)}.subtitle{font-size:12px;color:var(--muted);margin-top:4px}.sidebar-search{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.search-input{flex:1;min-width:0;padding:10px 12px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;outline:none;transition:border-color .2s}.search-input::placeholder{color:var(--muted)}.search-input:focus{border-color:var(--accent)}.site-list{flex:1;overflow:auto;padding:10px}.site-accordion{margin-bottom:2px}.site{width:100%;text-align:left;display:grid;grid-template-columns:14px 1fr 14px;gap:10px;align-items:start;padding:10px;border-radius:10px;background:transparent;border:1px solid transparent;cursor:pointer;color:inherit;-webkit-user-select:none;user-select:none;transition:border-color .2s,background .2s}.site:hover{background:#22d3a70a;border-color:var(--border)}.site.active{background:var(--accent-dim);border-color:#22d3a733}.dot{width:10px;height:10px;border-radius:999px;margin-top:4px}.status-icon{display:flex;align-items:center;margin-top:2px}.status-icon.ok{color:var(--green)}.status-icon.warning{color:var(--yellow)}.status-icon.critical{color:var(--red)}.site-name{font-weight:600;font-size:14px;color:var(--text)}.site-meta{font-size:12px;color:var(--muted);margin-top:2px}.site-list-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 0;color:var(--muted);font-size:13px}.empty{margin-top:8px;padding:10px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--muted);font-size:13px}.main{display:grid;grid-template-rows:64px 1fr;overflow:hidden}.banner{display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--border);background:var(--surface)}.banner-title{font-weight:700;font-size:16px;color:var(--text)}.banner-subtitle{font-size:12px;color:var(--muted);margin-top:2px}.banner-right{display:flex;align-items:center;gap:10px;min-width:0}.selected-name{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.btn-home{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;border-radius:8px;border:1px solid rgba(34,211,167,.2);background:var(--accent-dim);color:var(--accent);cursor:pointer;transition:all .2s}.btn-home:hover{background:var(--accent);color:var(--bg)}.pill{font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px}.pill.ok{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(34,211,167,.2)}.pill.warning{background:#eab3081f;color:var(--yellow);border:1px solid rgba(234,179,8,.2)}.pill.critical{background:#f0544c1f;color:var(--red);border:1px solid rgba(240,84,76,.2)}.map-wrap{overflow:hidden;position:relative}.map{height:100%;width:100%;background:var(--bg)}.map-overlay.error{position:absolute;inset:16px;padding:12px 14px;border-radius:12px;background:#f0544c1f;border:1px solid rgba(240,84,76,.25);color:var(--red);font-size:13px}.chevron{align-self:center;color:var(--muted);transition:transform .25s ease;flex-shrink:0}.chevron.open{transform:rotate(180deg)}.sensor-drawer{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}.sensor-drawer.open{grid-template-rows:1fr}.sensor-list{overflow:hidden;padding:0 8px 0 34px}.sensor-drawer.open .sensor-list{padding-bottom:6px}.sensor-row{width:100%;display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;background:transparent;border:1px solid transparent;cursor:pointer;color:var(--text);font-family:inherit;font-size:12px;text-align:left;transition:background .15s,border-color .15s}.sensor-row:hover{background:#22d3a70a;border-color:var(--border)}.sensor-row.active{background:var(--accent-dim);border-color:#22d3a733}.sensor-status{width:7px;height:7px;border-radius:999px;flex-shrink:0}.sensor-status.ok{background:var(--green)}.sensor-status.warning{background:var(--yellow)}.sensor-status.critical{background:var(--red)}.sensor-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sensor-value{color:var(--muted);font-size:11px;white-space:nowrap}.detail-wrap{overflow:auto;padding:24px;background:var(--bg)}.detail-panel{max-width:640px;margin:0 auto}.btn-back{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:8px;background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;margin-bottom:20px}.btn-back:hover{background:var(--accent-dim);border-color:#22d3a733;color:var(--accent)}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.detail-sensor-name{font-size:22px;font-weight:700;color:var(--text)}.detail-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:20px}.detail-card{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--border)}.detail-card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:6px}.detail-card-value{font-size:18px;font-weight:700;color:var(--text)}.detail-card-value.sensor-type{text-transform:capitalize}.status-text-ok{color:var(--green)}.status-text-warning{color:var(--yellow)}.status-text-critical{color:var(--red)}.detail-site-info{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--border);margin-bottom:20px}.detail-site-name{font-size:15px;font-weight:600;color:var(--text)}.detail-site-address{font-size:13px;color:var(--muted);margin-top:2px}.detail-chart-placeholder{padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--border)}.chart-placeholder-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;height:200px;border-radius:8px;background:var(--bg);border:1px dashed var(--border);color:var(--muted);font-size:13px}.chart-box{border-radius:8px;background:var(--bg);border:1px solid var(--border);padding:12px}.chart-svg{width:100%;height:180px;display:block;cursor:default;-webkit-user-select:none;user-select:none}.chart-svg-individual{height:120px}.chart-svg.zoomed{cursor:grab}.chart-svg.panning{cursor:grabbing}.chart-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.chart-legend{display:flex;gap:16px}.chart-reset-btn{padding:4px 10px;border-radius:6px;background:var(--accent-dim);border:1px solid rgba(34,211,167,.2);color:var(--accent);font-family:inherit;font-size:11px;font-weight:600;cursor:pointer;transition:background .15s}.chart-reset-btn:hover{background:var(--accent);color:var(--bg)}.chart-legend-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}.chart-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.detail-card-unit{font-size:13px;font-weight:500;color:var(--muted)}.detail-card-loading{display:flex;align-items:center;justify-content:center;padding:16px 0}.sensor-charts{margin-bottom:20px}.sensor-charts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sensor-chart-card{padding:14px;border-radius:12px;background:var(--surface);border:1px solid var(--border);margin-bottom:10px}.sensor-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.sensor-chart-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text)}.sensor-chart-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sensor-chart-current{font-size:16px;font-weight:700}.sensor-chart-unit{font-size:12px;font-weight:500;opacity:.7}.binary-sensors-row{display:flex;gap:10px;margin-bottom:16px}.binary-sensor-card{flex:1;display:flex;align-items:center;gap:8px;padding:12px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--border);transition:border-color .2s,background .2s}.binary-sensor-card.active{border-color:#f0544c66;background:#f0544c0f}.binary-sensor-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}.binary-sensor-dot.active{animation:pulse-dot 1.5s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.binary-sensor-label{font-size:12px;font-weight:600;color:var(--text);flex:1}.binary-sensor-value{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--green)}.binary-sensor-value.active{color:var(--red)}.binary-badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em;background:var(--accent-dim);color:var(--green);border:1px solid rgba(34,211,167,.2)}.binary-badge.active{background:#f0544c1f;color:var(--red);border-color:#f0544c4d}.state-badge{display:inline-block;font-size:12px;font-weight:700;padding:3px 10px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.state-badge.state-0{background:var(--accent-dim);color:var(--green);border:1px solid rgba(34,211,167,.2)}.state-badge.state-1{background:#eab3081f;color:var(--yellow);border:1px solid rgba(234,179,8,.2)}.state-badge.state-2{background:#fb923c1f;color:#fb923c;border:1px solid rgba(251,146,60,.25)}.state-badge.state-3{background:#f0544c1f;color:var(--red);border:1px solid rgba(240,84,76,.3)}.detail-card-value.awaiting{color:var(--muted);font-size:14px;opacity:.5}.account-panel{position:absolute;top:0;right:0;bottom:0;width:340px;background:var(--surface);border-left:1px solid var(--border);transform:translate(100%);transition:transform .3s ease;overflow-y:auto;padding:20px 16px;z-index:10}.account-panel.open{transform:translate(0)}.account-panel-close{position:absolute;top:12px;right:12px;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.account-panel-close:hover{color:var(--text);border-color:var(--muted)}.account-panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:200px;color:var(--muted);font-size:13px}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.account-panel-error{padding:14px;border-radius:10px;background:#f0544c1f;border:1px solid rgba(240,84,76,.25);color:var(--red);font-size:13px;margin-top:16px}.account-section{margin-bottom:12px}.account-row{display:flex;gap:16px}.account-row .account-section{flex:1}.account-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:4px}.account-value{font-size:14px;font-weight:600;color:var(--text);word-break:break-all}.account-role{text-transform:capitalize}.device-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.device-card{padding:12px;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.device-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.device-name{font-size:13px;font-weight:600;color:var(--text)}.device-active-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;background:#f0544c1f;color:var(--red);border:1px solid rgba(240,84,76,.2)}.device-active-badge.active{background:var(--accent-dim);color:var(--accent);border-color:#22d3a733}.device-details{display:flex;flex-direction:column;gap:4px}.device-detail{display:flex;justify-content:space-between;font-size:12px;color:var(--text)}.device-detail-label{color:var(--muted)}.alert-history-section{margin-top:20px;padding:16px;border-radius:12px;background:var(--surface);border:1px solid var(--border)}.alert-history-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:24px 0;color:var(--muted);font-size:13px}.alert-history-empty{padding:20px 0;text-align:center;color:var(--muted);font-size:13px}.alert-table{width:100%;border-collapse:collapse;font-size:12px}.alert-table th{text-align:left;padding:8px 10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border)}.alert-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text)}.alert-table tbody tr:last-child td{border-bottom:none}.alert-table tbody tr:hover{background:#22d3a70a}.alert-time{white-space:nowrap;color:var(--muted)}.alert-row-critical td:first-child{border-left:3px solid var(--red);padding-left:7px}.alert-row-warning td:first-child{border-left:3px solid var(--yellow);padding-left:7px}.device-empty{margin-top:8px;padding:12px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--muted);font-size:13px;text-align:center}.diag-dot-legend{background:#f0544c!important;box-shadow:0 0 0 2px #f0544c4d}.diagnostics-section{margin-top:20px}.diag-cards{margin-top:10px;display:flex;flex-direction:column;gap:8px}.diag-card{padding:12px;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.diag-card.critical{border-color:#f0544c66;background:#f0544c0f}.diag-card.warning{border-color:#eab30859;background:#eab3080d}.diag-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.diag-title{font-weight:600;font-size:13px;color:var(--text)}.diag-severity-pill{display:inline-block;padding:1px 7px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.diag-severity-pill.critical{background:#f0544c33;color:#f0544c}.diag-severity-pill.warning{background:#eab30833;color:#eab308}.diag-severity-pill.info{background:#5a6e8033;color:#8899a6}.diag-description{font-size:12px;color:var(--muted);line-height:1.45;margin-bottom:8px}.diag-action{display:flex;gap:6px;align-items:flex-start;font-size:12px;color:var(--text);line-height:1.4;padding:8px 10px;border-radius:8px;background:#22d3a70f;border:1px solid rgba(34,211,167,.15)}.app[data-v-efd91ef5]{height:100vh;width:100vw;overflow:hidden;display:grid;grid-template-columns:340px 1fr;background:var(--bg);color:var(--text);font-family:DM Sans,system-ui,-apple-system,sans-serif}.sidebar[data-v-efd91ef5],.main[data-v-efd91ef5],.map-wrap[data-v-efd91ef5]{min-height:0;min-width:0}.sidebar[data-v-efd91ef5]{display:flex;flex-direction:column;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}.sidebar-header[data-v-efd91ef5]{padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-header-top[data-v-efd91ef5]{display:flex;align-items:flex-start;justify-content:space-between}.btn-logout[data-v-efd91ef5]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.btn-logout[data-v-efd91ef5]:hover{color:var(--red);border-color:#f0544c4d}.title[data-v-efd91ef5]{font-weight:700;font-size:16px;color:var(--text)}.subtitle[data-v-efd91ef5]{font-size:12px;color:var(--muted);margin-top:4px}.sidebar-search[data-v-efd91ef5]{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border)}.search-input[data-v-efd91ef5]{flex:1;min-width:0;padding:10px 12px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--text);font-family:DM Sans,sans-serif;font-size:13px;outline:none;transition:border-color .2s}.search-input[data-v-efd91ef5]::placeholder{color:var(--muted)}.search-input[data-v-efd91ef5]:focus{border-color:var(--accent)}.btn-home[data-v-efd91ef5]{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:36px;height:36px;border-radius:8px;border:1px solid rgba(34,211,167,.2);background:var(--accent-dim);color:var(--accent);cursor:pointer;transition:all .2s}.btn-home[data-v-efd91ef5]:hover{background:var(--accent);color:var(--bg)}.site-list[data-v-efd91ef5]{flex:1;overflow:auto;padding:10px}.site-accordion[data-v-efd91ef5]{margin-bottom:2px}.site[data-v-efd91ef5]{width:100%;text-align:left;display:grid;grid-template-columns:14px 1fr 14px;gap:10px;align-items:start;padding:10px;border-radius:10px;background:transparent;border:1px solid transparent;cursor:pointer;color:inherit;-webkit-user-select:none;user-select:none;transition:border-color .2s,background .2s}.site[data-v-efd91ef5]:hover{background:#22d3a70a;border-color:var(--border)}.site.active[data-v-efd91ef5]{background:var(--accent-dim);border-color:#22d3a733}.status-icon[data-v-efd91ef5]{display:flex;align-items:center;margin-top:2px}.status-icon.ok[data-v-efd91ef5]{color:var(--green)}.status-icon.warning[data-v-efd91ef5]{color:var(--yellow)}.status-icon.critical[data-v-efd91ef5]{color:var(--red)}.site-name[data-v-efd91ef5]{font-weight:600;font-size:14px;color:var(--text)}.site-meta[data-v-efd91ef5]{font-size:12px;color:var(--muted);margin-top:2px}.site-list-loading[data-v-efd91ef5]{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px 0;color:var(--muted);font-size:13px}.empty[data-v-efd91ef5]{margin-top:8px;padding:10px;border-radius:10px;background:var(--bg);border:1px solid var(--border);color:var(--muted);font-size:13px}.chevron[data-v-efd91ef5]{align-self:center;color:var(--muted);transition:transform .25s ease;flex-shrink:0}.chevron.open[data-v-efd91ef5]{transform:rotate(180deg)}.sensor-drawer[data-v-efd91ef5]{display:grid;grid-template-rows:0fr;transition:grid-template-rows .25s ease}.sensor-drawer.open[data-v-efd91ef5]{grid-template-rows:1fr}.sensor-list[data-v-efd91ef5]{overflow:hidden;padding:0 8px 0 34px}.sensor-drawer.open .sensor-list[data-v-efd91ef5]{padding-bottom:6px}.sensor-row[data-v-efd91ef5]{width:100%;display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;background:transparent;border:1px solid transparent;cursor:pointer;color:var(--text);font-family:inherit;font-size:12px;text-align:left;transition:background .15s,border-color .15s}.sensor-row[data-v-efd91ef5]:hover{background:#22d3a70a;border-color:var(--border)}.sensor-row.active[data-v-efd91ef5]{background:var(--accent-dim);border-color:#22d3a733}.sensor-status[data-v-efd91ef5]{width:7px;height:7px;border-radius:999px;flex-shrink:0}.sensor-status.ok[data-v-efd91ef5]{background:var(--green)}.sensor-status.warning[data-v-efd91ef5]{background:var(--yellow)}.sensor-status.critical[data-v-efd91ef5]{background:var(--red)}.sensor-name[data-v-efd91ef5]{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sensor-value[data-v-efd91ef5]{color:var(--muted);font-size:11px;white-space:nowrap}.main[data-v-efd91ef5]{display:grid;grid-template-rows:64px 1fr;overflow:hidden}.banner[data-v-efd91ef5]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--border);background:var(--surface)}.banner-title[data-v-efd91ef5]{font-weight:700;font-size:16px;color:var(--text)}.banner-subtitle[data-v-efd91ef5]{font-size:12px;color:var(--muted);margin-top:2px}.banner-right[data-v-efd91ef5]{display:flex;align-items:center;gap:10px;min-width:0}.selected-name[data-v-efd91ef5]{font-weight:600;font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.pill[data-v-efd91ef5]{font-size:12px;font-weight:600;padding:6px 12px;border-radius:999px}.pill.ok[data-v-efd91ef5]{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(34,211,167,.2)}.pill.warning[data-v-efd91ef5]{background:#eab3081f;color:var(--yellow);border:1px solid rgba(234,179,8,.2)}.pill.critical[data-v-efd91ef5]{background:#f0544c1f;color:var(--red);border:1px solid rgba(240,84,76,.2)}.map-wrap[data-v-efd91ef5]{overflow:hidden;position:relative}.map[data-v-efd91ef5]{height:100%;width:100%;background:var(--bg)}.map-overlay.error[data-v-efd91ef5]{position:absolute;inset:16px;padding:12px 14px;border-radius:12px;background:#f0544c1f;border:1px solid rgba(240,84,76,.25);color:var(--red);font-size:13px}.account-panel[data-v-efd91ef5]{position:absolute;top:0;right:0;bottom:0;width:340px;background:var(--surface);border-left:1px solid var(--border);transform:translate(100%);transition:transform .3s ease;overflow-y:auto;padding:20px 16px;z-index:10}.account-panel.open[data-v-efd91ef5]{transform:translate(0)}.account-panel-close[data-v-efd91ef5]{position:absolute;top:12px;right:12px;display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:8px;border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;transition:color .15s,border-color .15s}.account-panel-close[data-v-efd91ef5]:hover{color:var(--text);border-color:var(--muted)}.account-section[data-v-efd91ef5]{margin-bottom:12px}.account-row[data-v-efd91ef5]{display:flex;gap:16px}.account-row .account-section[data-v-efd91ef5]{flex:1}.account-label[data-v-efd91ef5]{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:4px}.account-value[data-v-efd91ef5]{font-size:14px;font-weight:600;color:var(--text);word-break:break-all}.spinner[data-v-efd91ef5]{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin-efd91ef5 .8s linear infinite}@keyframes spin-efd91ef5{to{transform:rotate(360deg)}}
