*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%}body{color:#1a1a1a;background:#f5f5f5;min-height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}table{border-collapse:collapse;width:100%}select,input,button,textarea{font-family:inherit;font-size:inherit}.header{z-index:100;background:#fff;border-bottom:1px solid #e5e5e5;justify-content:space-between;align-items:center;padding:12px 24px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:10px;display:flex}.header-right{align-items:center;gap:12px;display:flex}.header h1{color:#1a1a1a;font-size:16px;font-weight:600}.header-dot{background:#16a34a;border-radius:50%;flex-shrink:0;width:10px;height:10px}.header-user{color:#374151;font-size:13px;font-weight:500}.header-logout{color:#6b7280;cursor:pointer;background:0 0;border:1px solid #d1d5db;border-radius:4px;padding:4px 10px;font-size:12px;transition:all .15s}.header-logout:hover{color:#dc2626;background:#fef2f2;border-color:#dc2626}.header-status{color:#6b7280;font-size:12px}.tabs{flex-wrap:wrap;gap:8px;padding:16px 24px 0;display:flex}.tab{color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fff;border:1px solid #d1d5db;border-radius:9999px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex;position:relative}.tab:hover{background:#f3f4f6;border-color:#9ca3af}.tab.active{color:#fff;background:#2563eb;border-color:#2563eb}.tab.active:hover{background:#1d4ed8}.tab.tab-alerts.active{background:#dc2626;border-color:#dc2626}.tab.tab-alerts.active:hover{background:#b91c1c}.tab-badge{color:#fff;background:#dc2626;border-radius:9999px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-6px;right:-6px}.filter-bar{background:#fff;border:1px solid #e5e5e5;border-radius:10px;flex-direction:column;gap:12px;margin:16px 24px;padding:16px;display:flex}.filter-row{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.filter-group{flex-direction:column;gap:4px;min-width:140px;display:flex}.filter-group label{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;font-size:10px;font-weight:600}.filter-group select,.filter-group input[type=text],.filter-group input[type=search],.filter-group input[type=number]{color:#1a1a1a;background:#fff;border:1px solid #d1d5db;border-radius:6px;outline:none;padding:6px 10px;transition:border-color .15s}.filter-group select:focus,.filter-group input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.filter-actions{align-items:flex-end;gap:8px;display:flex}.btn{color:#374151;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #d1d5db;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{background:#f3f4f6;border-color:#9ca3af}.btn-primary{color:#fff;background:#2563eb;border-color:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-secondary{color:#374151;background:#f3f4f6;border-color:#e5e7eb}.btn-secondary:hover{background:#e5e7eb}.btn-sm{padding:4px 10px;font-size:12px}.btn-danger{color:#fff;background:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#b91c1c}.summary-cards{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px;padding:0 24px;display:grid}.summary-card{background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:16px}.summary-card.clickable{cursor:pointer;transition:border-color .15s,box-shadow .15s}.summary-card.clickable:hover{border-color:#9ca3af;box-shadow:0 1px 4px #00000014}.summary-card.clickable.active{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.summary-card-label{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;margin-bottom:4px;font-size:10px;font-weight:600}.summary-card-value{font-size:28px;font-weight:700;line-height:1.2}.summary-card-value.green{color:#16a34a}.summary-card-value.amber{color:#d97706}.summary-card-value.red{color:#dc2626}.summary-card-value.blue{color:#2563eb}.summary-card-subtitle{color:#6b7280;margin-top:2px;font-size:12px}.table-container{background:#fff;border:1px solid #e5e5e5;border-radius:10px;margin:0 24px 24px;overflow:hidden}.table-header{border-bottom:1px solid #e5e5e5;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.table-row-count{color:#6b7280;font-size:13px}.table-actions{gap:8px;display:flex}.results-table{width:100%;font-size:13px}.results-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:#6b7280;cursor:default;white-space:nowrap;-webkit-user-select:none;user-select:none;background:#fafafa;border-bottom:1px solid #e5e5e5;padding:10px 12px;font-size:11px;font-weight:600}.results-table th.sortable{cursor:pointer}.results-table th.sortable:hover{color:#2563eb}.results-table th .sort-indicator{color:#9ca3af;margin-left:4px;font-size:10px;display:inline-block}.results-table th.sorted .sort-indicator{color:#2563eb}.results-table td{vertical-align:middle;border-bottom:1px solid #f3f4f6;padding:8px 12px}.results-table tbody tr:hover{background:#f9fafb}.results-table tbody tr:last-child td{border-bottom:none}.column-filter-row th{background:#fafafa;border-bottom:2px solid #e5e5e5;padding:4px 6px 8px;font-weight:400}.column-filter-cell{vertical-align:middle}.column-filter-select,.column-filter-input{color:#374151;background:#fff;border:1px solid #d1d5db;border-radius:4px;outline:none;width:100%;min-width:60px;padding:3px 6px;font-size:11px;transition:border-color .15s}.column-filter-select:focus,.column-filter-input:focus{border-color:#2563eb;box-shadow:0 0 0 1px #2563eb26}.column-filter-select:not(:focus){color:#6b7280}.column-filter-input::placeholder{color:#9ca3af}.status-badge{white-space:nowrap;border-radius:9999px;padding:2px 8px;font-size:11px;font-weight:600;line-height:1.4;display:inline-block}.status-badge.online,.status-badge.healthy,.status-badge.connected,.status-badge.resolved{color:#15803d;background:#dcfce7}.status-badge.warning{color:#92400e;background:#fef3c7}.status-badge.error,.status-badge.critical,.status-badge.disconnected{color:#991b1b;background:#fee2e2}.status-badge.low-power{color:#c2410c;background:#fff7ed}.status-badge.stale{color:#6b21a8;background:#f3e8ff}.status-badge.churned{color:#9ca3af;background:#e5e7eb;text-decoration:line-through}.status-badge.offline,.status-badge.unconfigured{color:#4b5563;background:#f3f4f6}.status-badge.info{color:#1e40af;background:#dbeafe}.status-badge.active{color:#991b1b;background:#fee2e2}.mono{font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.sensor-link{color:#2563eb;cursor:pointer;font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:12px}.sensor-link:hover{text-decoration:underline}.os-tag{color:#4b5563;background:#f3f4f6;border-radius:4px;padding:1px 6px;font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:11px;display:inline-block}.rssi-good{color:#16a34a;font-weight:600}.rssi-okay{color:#2563eb;font-weight:600}.rssi-warning{color:#d97706;font-weight:600}.rssi-critical{color:#dc2626;font-weight:600}.tilt-good{color:#16a34a}.tilt-warning{color:#d97706}.tilt-critical{color:#dc2626;font-weight:600}.disconnect-tag{white-space:nowrap;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.disconnect-tag.connection_timeout{color:#92400e;background:#fef3c7}.disconnect-tag.cloud_disconnect,.disconnect-tag.server_disconnect{color:#1e40af;background:#dbeafe}.disconnect-tag.credential_rejected{color:#991b1b;background:#fee2e2}.disconnect-tag.client_disconnect{color:#6b21a8;background:#f3e8ff}.disconnect-tag:not([class*=\ ]){color:#4b5563;background:#f3f4f6}.org-grid{grid-template-columns:repeat(2,1fr);gap:16px;padding:0 24px 24px;display:grid}.org-card{cursor:pointer;background:#fff;border:1px solid #e5e5e5;border-left-width:4px;border-radius:10px;padding:16px;transition:box-shadow .15s,border-color .15s}.org-card:hover{box-shadow:0 2px 8px #00000014}.org-card.health-good{border-left-color:#16a34a}.org-card.health-warning{border-left-color:#d97706}.org-card.health-critical{border-left-color:#dc2626}.org-card-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.org-card-name{color:#1a1a1a;font-size:15px;font-weight:600}.org-card-health{font-size:20px;font-weight:700}.org-card-meta{color:#6b7280;margin-bottom:10px;font-size:12px}.org-card-status{gap:12px;font-size:12px;display:flex}.org-card-status span{align-items:center;gap:4px;display:flex}.org-card-status .dot{border-radius:50%;width:8px;height:8px;display:inline-block}.dot.green{background:#16a34a}.dot.red{background:#dc2626}.dot.purple{background:#7c3aed}.dot.orange{background:#f97316}.dot.gray{background:#9ca3af}.filter-pills{flex-wrap:wrap;gap:6px;display:flex}.filter-pill{color:#374151;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:9999px;padding:4px 12px;font-size:12px;font-weight:500;transition:all .15s}.filter-pill:hover{background:#f3f4f6}.filter-pill.active{color:#fff;background:#2563eb;border-color:#2563eb}.alert-list{flex-direction:column;gap:12px;padding:0 24px 24px;display:flex}.alert-card{background:#fff;border:1px solid #e5e5e5;border-left-width:4px;border-radius:10px;padding:16px}.alert-card.severity-critical{border-left-color:#dc2626}.alert-card.severity-warning{border-left-color:#d97706}.alert-card.severity-info{border-left-color:#2563eb}.alert-card-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;display:flex}.alert-card-title{color:#1a1a1a;font-size:15px;font-weight:600}.alert-card-time{color:#6b7280;white-space:nowrap;font-size:12px}.alert-card-description{color:#4b5563;margin-bottom:10px;font-size:13px;line-height:1.5}.alert-card-meta{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.meta-tag{border-radius:4px;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block}.meta-tag.type{color:#1e40af;background:#dbeafe}.meta-tag.org{color:#6b21a8;background:#f3e8ff}.meta-tag.sensor-type{color:#92400e;background:#fef3c7}.meta-tag.firmware{color:#4b5563;background:#f3f4f6}.alert-card-sparkline{align-items:flex-end;gap:2px;height:32px;margin-bottom:12px;display:flex}.sparkline-bar{background:#93c5fd;border-radius:2px 2px 0 0;flex:1;min-width:4px;transition:background .15s}.sparkline-bar.high{background:#dc2626}.sparkline-bar.medium{background:#d97706}.alert-card-actions{gap:8px;display:flex}.breadcrumb{color:#6b7280;align-items:center;gap:6px;padding:16px 24px 0;font-size:13px;display:flex}.breadcrumb a{color:#2563eb}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:#9ca3af}.sensor-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;padding:16px 24px;display:flex}.sensor-header-left{flex-direction:column;gap:6px;display:flex}.sensor-header-id{color:#1a1a1a;font-family:SF Mono,SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:22px;font-weight:700}.sensor-header-meta{color:#6b7280;flex-wrap:wrap;gap:8px;font-size:12px;display:flex}.sensor-header-meta span{align-items:center;gap:4px;display:flex}.sensor-header-actions{gap:8px;display:flex}.detail-cards{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;padding:0 24px;display:grid}.detail-card{background:#fff;border:1px solid #e5e5e5;border-radius:10px;padding:16px}.detail-card-title{text-transform:uppercase;letter-spacing:.5px;color:#6b7280;border-bottom:1px solid #f3f4f6;margin-bottom:12px;padding-bottom:8px;font-size:12px;font-weight:600}.detail-row{justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;display:flex}.detail-row-label{color:#6b7280}.detail-row-value{color:#1a1a1a;font-weight:500}.chart-container{background:#fff;border:1px solid #e5e5e5;border-radius:10px;margin:0 24px 24px;padding:16px}.chart-title{color:#1a1a1a;margin-bottom:4px;font-size:14px;font-weight:600}.chart-subtitle{color:#6b7280;margin-bottom:12px;font-size:12px}.chart-toolbar{gap:4px;margin-bottom:12px;display:flex}.chart-toolbar .btn{padding:3px 10px;font-size:11px}.chart-toolbar .btn.active{color:#fff;background:#2563eb;border-color:#2563eb}.bar-chart{align-items:flex-end;gap:1px;height:120px;padding-top:8px;display:flex;position:relative}.bar-chart-bar{border-radius:1px 1px 0 0;flex:1;min-width:2px;transition:opacity .15s;position:relative}.bar-chart-bar:hover{opacity:.8}.bar-chart-bar.rssi-good-bar{background:#16a34a}.bar-chart-bar.rssi-warning-bar{background:#d97706}.bar-chart-bar.rssi-critical-bar{background:#dc2626}.bar-chart-threshold{z-index:1;border-top:2px dashed #dc2626;position:absolute;left:0;right:0}.bar-chart-threshold-label{color:#dc2626;font-size:10px;font-weight:600;position:absolute;top:-14px;right:0}.heatmap{grid-template-columns:40px repeat(24,1fr);gap:2px;font-size:10px;display:grid}.heatmap-row-label{color:#6b7280;align-items:center;padding-right:4px;font-size:11px;display:flex}.heatmap-col-labels{display:contents}.heatmap-col-label{text-align:center;color:#9ca3af;padding-bottom:2px;font-size:9px}.heatmap-cell{aspect-ratio:1;border-radius:2px;min-height:16px}.heatmap-cell.intensity-0{background:#f3f4f6}.heatmap-cell.intensity-1{background:#fecaca}.heatmap-cell.intensity-2{background:#f87171}.heatmap-cell.intensity-3{background:#dc2626}.heatmap-cell.intensity-4{background:#991b1b}.event-timeline{flex-direction:column;gap:0;display:flex}.event-item{border-bottom:1px solid #f3f4f6;align-items:flex-start;gap:12px;padding:10px 0;font-size:13px;display:flex}.event-item:last-child{border-bottom:none}.event-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.event-dot.connected{background:#16a34a}.event-dot.disconnected{background:#dc2626}.event-dot.connect_failed{background:#d97706}.event-content{flex:1}.event-type{color:#1a1a1a;font-weight:500}.event-time{color:#6b7280;margin-left:8px;font-size:12px}.event-detail{color:#6b7280;margin-top:2px;font-size:12px}.loading{color:#6b7280;justify-content:center;align-items:center;padding:48px;font-size:14px;display:flex}.loading:after{content:"";border:2px solid #d1d5db;border-top-color:#2563eb;border-radius:50%;width:16px;height:16px;margin-left:8px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#991b1b;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin:16px 24px;padding:12px 16px;font-size:13px}.empty-state{color:#6b7280;text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;font-size:14px;display:flex}.empty-state-title{color:#374151;margin-bottom:4px;font-size:15px;font-weight:600}.btn-export{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-export:hover{background:#f9fafb}.trend-bar{border-radius:3px;gap:2px;height:6px;margin-top:10px;display:flex;overflow:hidden}.trend-bar-segment{border-radius:1px;flex:1}.trend-bar-segment.good{background:#16a34a}.trend-bar-segment.warning{background:#d97706}.trend-bar-segment.bad{background:#dc2626}.issue-tags{flex-wrap:wrap;gap:4px;margin-top:8px;display:flex}.issue-tag{color:#991b1b;background:#fee2e2;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:500;display:inline-block}.issue-tag.warning{color:#92400e;background:#fef3c7}@media (max-width:900px){.summary-cards{grid-template-columns:repeat(2,1fr)}.detail-cards,.org-grid{grid-template-columns:1fr}}@media (max-width:600px){.summary-cards{grid-template-columns:1fr}.header h1{font-size:14px}.filter-row{flex-direction:column}.filter-group{min-width:100%}.sensor-header{flex-direction:column}.tabs{padding:12px 16px 0}.filter-bar{margin:12px 16px}.summary-cards{padding:0 16px}.table-container{margin:0 16px 16px}.alert-list,.org-grid{padding:0 16px 16px}.chart-container{margin:0 16px 16px}.breadcrumb{padding:12px 16px 0}.sensor-header{padding:12px 16px}.detail-cards{padding:0 16px}}
