@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--bg-primary:#0a0a0a;--bg-secondary:#111;--bg-card:#161616;--bg-hover:#1a1a1a;--border:#222;--border-light:#2a2a2a;--neon:#0f8;--neon-dim:#00cc6a;--neon-glow:#00ff8826;--neon-glow-sm:#00ff8814;--text-primary:#f0f0f0;--text-secondary:#888;--text-muted:#555;--red:#f44;--orange:#f80;--yellow:#fc0;--blue:#48f;--font-main:"Inter", sans-serif;--font-mono:"JetBrains Mono", monospace;--radius:8px;--radius-lg:12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--neon-dim)}a{color:var(--neon);text-decoration:none}a:hover{color:var(--neon-dim)}button{cursor:pointer;font-family:var(--font-main)}input,select,textarea{font-family:var(--font-main);background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius);outline:none;padding:8px 12px;transition:border-color .2s}input:focus,select:focus,textarea:focus{border-color:var(--neon);box-shadow:0 0 0 2px var(--neon-glow-sm)}.neon{color:var(--neon)}.muted{color:var(--text-muted)}.mono{font-family:var(--font-mono)}.login-page{background:var(--bg-primary);background-image:radial-gradient(circle at 20%,#00ff8808 0%,#0000 50%),radial-gradient(circle at 80% 20%,#00ff8805 0%,#0000 40%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:400px;padding:40px}.login-logo{text-align:center;color:var(--neon);margin-bottom:32px}.login-logo h1{color:var(--neon);letter-spacing:1px;margin:12px 0 6px;font-size:28px;font-weight:700}.login-logo p{color:var(--text-muted);font-size:13px}.login-form{flex-direction:column;gap:20px;display:flex}.form-group input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);padding:10px 14px;font-size:14px}.input-wrap{position:relative}.input-wrap input{width:100%;padding-right:40px}.eye-btn{color:var(--text-muted);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.eye-btn:hover{color:var(--text-secondary)}.login-error{color:var(--red);border-radius:var(--radius);background:#ff44441a;border:1px solid #ff44444d;padding:10px 14px;font-size:13px}.login-btn{background:var(--neon);color:#000;border-radius:var(--radius);letter-spacing:.3px;border:none;width:100%;padding:12px;font-size:15px;font-weight:600;transition:all .2s}.login-btn:hover:not(:disabled){background:var(--neon-dim);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.dashboard{max-width:1400px}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-primary);font-size:24px;font-weight:600}.page-sub{color:var(--text-muted);margin-top:4px;font-size:13px}.refresh-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);align-items:center;gap:6px;padding:8px 14px;font-size:13px;transition:all .15s;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.stats-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:14px;padding:16px;display:flex}.stat-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.stat-icon.green{background:var(--neon-glow);color:var(--neon)}.stat-icon.blue{color:var(--blue);background:#4488ff1f}.stat-icon.red{color:var(--red);background:#ff44441f}.stat-icon.orange{color:var(--orange);background:#ff88001f}.stat-val{color:var(--text-primary);font-size:26px;font-weight:700;font-family:var(--font-mono);line-height:1}.stat-label{color:var(--text-muted);margin-top:4px;font-size:12px}.gh-tab{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:6px 14px;font-size:13px;transition:all .15s}.gh-tab:hover{border-color:var(--neon-dim);color:var(--text-primary)}.gh-tab.active{background:var(--neon-glow);border-color:var(--neon);color:var(--neon)}.stations-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;display:grid}.station-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;padding:16px;transition:all .15s}.station-card:hover{border-color:var(--neon-dim);transform:translateY(-2px)}.station-card.online{border-left:3px solid var(--neon)}.station-card.offline{border-left:3px solid var(--border);opacity:.7}.card-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.card-title{color:var(--text-primary);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.status-dot.on{background:var(--neon);box-shadow:0 0 6px var(--neon)}.status-dot.off{background:var(--text-muted)}.card-row-tag{color:var(--text-muted);background:var(--bg-secondary);font-size:11px;font-family:var(--font-mono);border-radius:10px;padding:2px 8px}.card-metrics{grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;display:grid}.metric{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;display:flex}.metric svg{color:var(--text-muted);flex-shrink:0}.badge{font-size:11px;font-weight:600;font-family:var(--font-mono);border-radius:4px;margin-left:auto;padding:2px 6px}.badge.green{background:var(--neon-glow);color:var(--neon)}.badge.red{color:var(--red);background:#ff44441f}.badge.gray{background:var(--bg-secondary);color:var(--text-muted)}.card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding-top:10px;display:flex}.plant-type{color:var(--text-muted);font-size:12px;font-style:italic}.conn-status{align-items:center;gap:4px;font-size:11px;display:flex}.conn-status.on{color:var(--neon)}.conn-status.off{color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;grid-column:1/-1;align-items:center;gap:12px;padding:60px;display:flex}.dashboard-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.greenhouse-tabs{flex-wrap:wrap;gap:6px;margin-bottom:0;display:flex}.dash-search{align-items:center;display:flex;position:relative}.dash-search input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);width:240px;padding:7px 32px 7px 30px;font-size:13px}.dash-search input:focus{border-color:var(--neon)}.dash-search .search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.dash-search .search-clear{color:var(--text-muted);background:0 0;border:none;align-items:center;padding:2px;display:flex;position:absolute;right:8px}.result-info{color:var(--text-muted);margin-bottom:10px;font-size:12px}.pagination{justify-content:center;align-items:center;gap:4px;margin-top:20px;display:flex}.page-btn{border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-card);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.page-btn:hover{border-color:var(--neon);color:var(--neon)}.page-btn.active{background:var(--neon-glow);border-color:var(--neon);color:var(--neon)}.page-btn:disabled{opacity:.3;cursor:default}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--neon);transform:translateY(-2px)}.station-detail{max-width:1200px}.metrics-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px;display:grid}.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.metric-card.ok{border-top:2px solid var(--neon)}.metric-card.warn{border-top:2px solid var(--red)}.metric-label{color:var(--text-muted);margin-bottom:8px;font-size:12px}.metric-value{font-size:24px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.metric-unit{color:var(--text-muted);margin-left:4px;font-size:13px}.chart-section,.command-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;padding:20px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header h2,.command-section h2{color:var(--text-primary);margin-bottom:16px;font-size:16px;font-weight:600}.hours-tabs{align-items:center;gap:4px;display:flex}.hours-tab{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);border-radius:20px;padding:4px 10px;font-size:12px;transition:all .15s}.hours-tab.active{background:var(--neon-glow);border-color:var(--neon);color:var(--neon)}.chart-wrap{margin-top:8px}.command-row{align-items:center;gap:10px;display:flex}.command-row select{flex:1;padding:10px 14px}.send-btn{background:var(--neon);color:#000;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .15s;display:flex}.send-btn:hover{background:var(--neon-dim)}.cmd-result{color:var(--neon);margin-top:10px;font-size:13px}.analysis-overall{border-radius:var(--radius);border:1px solid;align-items:flex-start;gap:14px;margin-bottom:16px;padding:16px;display:flex}.analysis-overall.ok{background:var(--neon-glow);border-color:var(--neon)}.analysis-overall.warning{border-color:var(--yellow);background:#ffcc0014}.analysis-overall.alarm{border-color:var(--orange);background:#ff880014}.analysis-overall.critical{border-color:var(--red);background:#ff444414}.analysis-overall.unknown{background:var(--bg-secondary);border-color:var(--border)}.analysis-overall-icon{flex-shrink:0;font-size:24px}.analysis-overall-msg{color:var(--text-primary);font-size:14px;font-weight:600}.analysis-plant{color:var(--text-muted);margin-top:4px;font-size:12px;font-style:italic}.analysis-params{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.analysis-param{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);border-left:3px solid var(--border);padding:12px 14px}.analysis-param.ok{border-left-color:var(--neon)}.analysis-param.warning{border-left-color:var(--yellow)}.analysis-param.alarm{border-left-color:var(--orange)}.analysis-param.critical{border-left-color:var(--red)}.analysis-param-header{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:8px;display:flex}.analysis-param-name{color:var(--text-primary);flex:1;font-size:13px;font-weight:600}.analysis-param-value{font-size:13px;font-family:var(--font-mono);color:var(--text-primary)}.analysis-param-optimal{color:var(--text-muted);font-size:11px}.analysis-recs{flex-direction:column;gap:4px;margin:0;padding-left:16px;display:flex}.analysis-recs li{color:var(--text-secondary);font-size:12px;line-height:1.6}.analysis-disclaimer{border-radius:var(--radius);background:#ff88000f;border:1px solid #f803;margin-bottom:12px;padding:14px}.disclaimer-title{color:var(--orange);margin-bottom:8px;font-size:12px;font-weight:600}.analysis-disclaimer p{color:var(--text-secondary);font-size:12px;line-height:1.7}.analysis-sources{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);padding:14px}.sources-title{color:var(--text-secondary);margin-bottom:8px;font-size:12px;font-weight:600}.analysis-sources ul{flex-direction:column;gap:4px;padding-left:16px;display:flex}.analysis-sources li{color:var(--text-muted);font-size:11px;font-style:italic;line-height:1.6}.detail-back-row{margin-bottom:12px}.btn-back{color:var(--text-secondary,#a0a0a0);cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:all .15s;display:inline-flex}.btn-back:hover{color:#0f8;border-color:#0f8}.detail-header{background:0 0;border:none;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;padding:0;display:flex}.detail-title h1{color:var(--text-primary,#fff);margin:0 0 4px;font-size:24px;font-weight:700}.detail-title .page-sub{color:var(--text-muted,#707070);margin:0;font-size:13px}.online-badge{white-space:nowrap;border:1px solid;border-radius:999px;flex-shrink:0;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:500;display:inline-flex}.online-badge.on{color:#0f8;background:#00ff8814;border-color:#0f8}.online-badge.off{color:#f44;background:#ff44441a;border-color:#f44}.detail-tabs{scrollbar-width:none;background:0 0;border-bottom:1px solid #1f1f1f;gap:4px;margin-bottom:20px;padding:0;display:flex;overflow-x:auto}.detail-tabs::-webkit-scrollbar{display:none}.detail-tab{color:var(--text-muted,#707070);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 14px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.detail-tab:hover{color:var(--text-secondary,#a0a0a0)}.detail-tab.active{color:#0f8;border-bottom-color:#0f8}.threshold-toggle-row{background:#00ff880a;border:1px solid #1f2f24;border-radius:8px;margin-top:8px;padding:12px 14px}.toggle-switch{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;display:inline-flex}.toggle-switch input{opacity:0;pointer-events:none;position:absolute}.toggle-slider{background:#2a2a2a;border-radius:999px;flex-shrink:0;width:36px;height:20px;transition:background .2s;position:relative}.toggle-slider:before{content:"";background:#888;border-radius:50%;width:16px;height:16px;transition:transform .2s,background .2s;position:absolute;top:2px;left:2px}.toggle-switch input:checked~.toggle-slider{background:#00ff884d}.toggle-switch input:checked~.toggle-slider:before{background:#0f8;transform:translate(16px)}.toggle-label{color:var(--text-primary,#fff);font-size:13px;font-weight:500}.toggle-hint{color:var(--text-muted,#707070);margin:8px 0 0;font-size:12px;line-height:1.5}.form-group input:disabled{opacity:.4;cursor:not-allowed}.alarms-page{max-width:1200px}.page-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:16px;padding-bottom:0;display:flex}.page-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.page-tab:hover{color:var(--text-primary)}.page-tab.active{color:var(--neon);border-bottom-color:var(--neon)}.tab-badge{border-radius:10px;padding:1px 6px;font-size:11px;font-weight:700}.tab-badge.red{color:var(--red);background:#ff444426}.tab-badge.orange{color:var(--orange);background:#ff880026}.filter-row{flex-wrap:wrap;gap:20px;margin-bottom:14px;display:flex}.filter-group{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.filter-label{color:var(--text-muted);font-size:12px;font-weight:500}.filter-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:20px;padding:4px 12px;font-size:12px;transition:all .15s}.filter-btn:hover{border-color:var(--neon-dim);color:var(--text-primary)}.filter-btn.active{background:var(--neon-glow);border-color:var(--neon);color:var(--neon)}.filter-btn.critical.active{border-color:var(--red);color:var(--red);background:#ff44441a}.filter-btn.alarm.active{border-color:var(--orange);color:var(--orange);background:#ff88001a}.filter-btn.warning.active{border-color:var(--yellow);color:var(--yellow);background:#ffcc001a}.alarms-list{flex-direction:column;gap:8px;display:flex}.alarm-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:12px;padding:12px 16px;transition:all .15s;display:flex}.alarm-row.resolved{opacity:.5}.alarm-sev{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:flex}.alarm-sev.red{color:var(--red);background:#ff44441f}.alarm-sev.orange{color:var(--orange);background:#ff88001f}.alarm-sev.yellow{color:var(--yellow);background:#ffcc001f}.alarm-sev.blue{color:var(--blue);background:#4488ff1f}.alarm-sev.green{background:var(--neon-glow);color:var(--neon)}.alarm-info{flex:1;min-width:0}.alarm-type{color:var(--text-primary);font-size:13px;font-weight:500}.alarm-loc{color:var(--text-muted);margin-top:2px;font-size:11px}.alarm-desc{color:var(--text-secondary);margin-top:2px;font-size:11px;font-style:italic}.alarm-vals{text-align:right;flex-direction:column;gap:2px;display:flex}.alarm-val{font-size:12px;font-family:var(--font-mono);color:var(--text-primary)}.alarm-thr{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.alarm-sev-label{text-align:center;min-width:60px}.sev-badge{text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.alarm-time{color:var(--text-muted);white-space:nowrap;align-items:center;gap:4px;font-size:11px;display:flex}.alarm-actions{flex-shrink:0;gap:6px;display:flex}.btn-ack{border-radius:var(--radius);color:var(--orange);cursor:pointer;background:#ff88001a;border:1px solid #ff88004d;padding:5px 10px;font-size:12px}.btn-resolve{background:var(--neon-glow);border-radius:var(--radius);color:var(--neon);cursor:pointer;border:1px solid #00ff884d;align-items:center;gap:4px;padding:5px 10px;font-size:12px;display:flex}.resolved-tag{color:var(--text-muted);background:var(--bg-secondary);border-radius:var(--radius);padding:4px 8px;font-size:11px}.refresh-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;align-items:center;gap:6px;padding:8px 14px;font-size:13px;transition:all .15s;display:flex}.refresh-btn:hover{border-color:var(--neon);color:var(--neon)}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:12px;padding:60px;display:flex}.customers-page{max-width:1200px}.btn-primary{background:var(--neon);color:#000;border-radius:var(--radius);border:none;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.btn-primary:hover{background:var(--neon-dim)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border);padding:14px 16px;font-size:13px}.data-table tr:last-child td{border-bottom:none}.clickable-row{cursor:pointer}.clickable-row:hover td{background:var(--bg-hover)}.customer-name{font-weight:500}.customer-email{color:var(--text-muted);margin-top:2px;font-size:12px}.plan-badge{background:var(--neon-glow);color:var(--neon);text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.status-badge{text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.status-badge.red{color:var(--red);background:#ff44441f}.status-badge.orange{color:var(--orange);background:#ff88001f}.status-badge.yellow{color:var(--yellow);background:#ffcc001f}.modal-overlay{z-index:9999;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:10000;width:100%;max-width:580px;max-height:90vh;position:relative;overflow-y:auto}.modal-lg{max-width:720px}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h2{color:var(--text-primary);font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);border-radius:var(--radius);background:0 0;border:none;align-items:center;padding:4px;display:flex}.modal-close:hover{color:var(--red)}.modal-body{flex-direction:column;gap:24px;padding:20px 24px;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.form-section h3{color:var(--neon);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:13px;font-weight:500}.form-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:500}.form-group input,.form-group select{width:100%;padding:9px 12px;font-size:13px}.plan-cards{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.plan-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:center;padding:14px;transition:all .15s}.plan-card:hover{border-color:var(--neon-dim)}.plan-card.selected{background:var(--neon-glow);border-color:var(--neon)}.plan-name{color:var(--text-primary);margin-bottom:4px;font-size:14px;font-weight:600}.plan-price{color:var(--neon);margin-bottom:4px;font-size:15px;font-weight:700}.plan-detail{color:var(--text-muted);font-size:11px}.price-display{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);color:var(--neon);font-size:16px;font-weight:700;font-family:var(--font-mono);align-items:center;gap:8px;padding:9px 12px;display:flex}.price-sub{color:var(--text-muted);font-size:11px;font-weight:400}.btn-cancel{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);background:0 0;padding:8px 18px;font-size:13px}.btn-cancel:hover{border-color:var(--text-secondary);color:var(--text-primary)}.sub-info{flex-wrap:wrap;align-items:center;gap:12px;padding:10px 0;display:flex}.gh-list{flex-direction:column;gap:6px;display:flex}.gh-row{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:10px;padding:10px 14px;display:flex}.gh-name{color:var(--text-primary);font-size:13px;font-weight:500}.gh-loc{color:var(--text-muted);margin-top:1px;font-size:11px}.empty-gh{text-align:center;color:var(--text-muted);padding:20px;font-size:13px}.modal-tabs{border-bottom:1px solid var(--border);padding:0 24px;display:flex}.modal-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:12px 16px;font-size:13px;font-weight:500;transition:all .15s}.modal-tab:hover{color:var(--text-primary)}.modal-tab.active{color:var(--neon);border-bottom-color:var(--neon)}.modal-tab.disabled{opacity:.4;cursor:not-allowed}.tab-lock{margin-left:4px;font-size:11px}.gh-add-form{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);margin-top:14px;padding:14px}.modal-xl{max-width:780px}.btn-sm{padding:5px 12px;font-size:12px}.devices-page{max-width:1400px}.device-stats{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.stat-chip{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;transition:all .15s;display:flex}.stat-chip:hover{border-color:var(--neon-dim)}.stat-chip.active.blue{border-color:var(--blue);background:#4488ff1a}.stat-chip.active.green{background:var(--neon-glow);border-color:var(--neon)}.stat-chip.active.red{border-color:var(--red);background:#ff44441a}.stat-chip-val{font-size:16px;font-weight:700;font-family:var(--font-mono);color:var(--text-primary)}.stat-chip-label{color:var(--text-secondary);font-size:12px}.device-serial{align-items:center;display:flex}.search-bar{align-items:center;margin-bottom:16px;display:flex;position:relative}.search-bar input{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);padding:10px 14px 10px 38px;font-size:13px}.search-bar input:focus{border-color:var(--neon)}.search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:12px}.search-clear{color:var(--text-muted);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.search-clear:hover{color:var(--text-primary)}.text-muted{color:var(--text-muted);font-style:italic}.action-btns{gap:6px;display:flex}.btn-icon{border-radius:var(--radius);border:1px solid var(--border);width:30px;height:30px;color:var(--text-muted);background:0 0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-icon.edit:hover{border-color:var(--neon);color:var(--neon)}.btn-icon.delete:hover{border-color:var(--red);color:var(--red)}.btn-danger{border-radius:var(--radius);color:var(--red);background:#ff44441a;border:1px solid #ff44444d;padding:8px 18px;font-size:13px;font-weight:500}.confirm-modal{max-width:400px}.loading{text-align:center;color:var(--text-muted);padding:40px}.settings-page{max-width:700px}.settings-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.settings-card h3{color:var(--text-primary);font-size:15px;font-weight:600}.settings-msg{border-radius:var(--radius);margin-bottom:16px;padding:10px 16px;font-size:13px}.settings-msg.success{background:var(--neon-glow);color:var(--neon)}.settings-msg.error{color:var(--red);background:#ff44441a}.telegram-help{background:var(--bg-secondary);border-radius:var(--radius);color:var(--text-secondary);margin-top:12px;padding:10px 14px;font-size:12.5px}.notif-info{flex-direction:column;gap:8px;display:flex}.notif-row{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);align-items:center;gap:14px;padding:12px 16px;display:flex}.notif-icon{font-size:20px}.notif-title{color:var(--text-primary);font-size:13px;font-weight:500}.notif-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.notif-levels{flex-direction:column;gap:8px;display:flex}.notif-level-row{align-items:center;gap:12px;display:flex}.sev-badge{text-transform:uppercase;white-space:nowrap;border-radius:10px;padding:2px 10px;font-size:11px;font-weight:600}.sev-badge.red{color:var(--red);background:#ff44441f}.sev-badge.orange{color:var(--orange);background:#ff88001f}.sev-badge.yellow{color:var(--yellow);background:#ffcc001f}.sev-badge.blue{color:var(--blue);background:#4488ff1f}.sev-badge.green{background:var(--neon-glow);color:var(--neon)}.sev-badge.gray{background:var(--bg-secondary);color:var(--text-muted)}.status-badge{border-radius:10px;margin-left:auto;padding:2px 10px;font-size:11px;font-weight:600}.status-badge.green{background:var(--neon-glow);color:var(--neon)}.status-badge.gray{background:var(--bg-secondary);color:var(--text-muted)}.settings-tabs{border-bottom:1px solid var(--border);margin-bottom:20px}.settings-tabs .detail-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:7px;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.settings-tabs .detail-tab:hover{color:var(--text-primary)}.settings-tabs .detail-tab.active{color:var(--neon);border-bottom-color:var(--neon)}.send-btn.secondary{color:var(--text-secondary,#a0a0a0);background:0 0;border:1px solid #2a2a2a}.send-btn.secondary:hover{color:#0f8;border-color:#0f8}.apply-confirm{background:#ff99000f;border:1px solid #ff99004d;border-radius:8px;align-items:flex-start;gap:12px;margin-top:16px;padding:14px;display:flex}.apply-confirm strong{color:#f90;font-size:14px}.apply-confirm p{color:var(--text-secondary,#a0a0a0);margin:4px 0 0;font-size:13px;line-height:1.5}.add-user-form{background:#00ff880a;border:1px solid #1f2f24;border-radius:8px;margin-top:16px;padding:16px}.user-list .data-table{border-collapse:collapse;width:100%;font-size:13px}.user-list .data-table th{text-align:left;color:var(--text-muted,#707070);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #1f1f1f;padding:10px 12px;font-size:12px;font-weight:500}.user-list .data-table td{color:var(--text-primary,#fff);border-bottom:1px solid #161616;padding:12px}.user-list .data-table tr:hover td{background:#ffffff05}.role-badge{text-transform:uppercase;letter-spacing:.3px;border-radius:4px;padding:3px 8px;font-size:11px;font-weight:500;display:inline-block}.role-badge.super_admin{color:#f66;background:#ff44441f;border:1px solid #ff44444d}.role-badge.manager{color:#0f8;background:#00ff881f;border:1px solid #00ff884d}.role-badge.technician{color:#48f;background:#4488ff1f;border:1px solid #4488ff4d}.icon-btn-danger{color:#888;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:4px;padding:6px 8px;transition:all .15s}.icon-btn-danger:hover{color:#f44;background:#ff444414;border-color:#f44}.analytics-page{padding:24px 32px}.analytics-page .page-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.analytics-page .page-header h1{color:var(--text-primary,#fff);margin:0 0 4px;font-size:24px;font-weight:700}.analytics-page .page-sub{color:var(--text-muted,#707070);margin:0;font-size:13px}.period-bar{gap:6px;margin-bottom:20px;display:flex}.summary-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px;display:grid}.sum-card{background:linear-gradient(#00ff8808 0%,#0000 100%),#0c0c0c;border:1px solid #00ff882e;border-radius:10px;padding:16px 18px;transition:all .2s;position:relative;box-shadow:inset 0 0 0 1px #00ff880a,0 0 12px #00ff880a}.sum-card:before{content:"";-webkit-mask-composite:xor;opacity:.6;pointer-events:none;background:linear-gradient(135deg,#0f86 0%,#00ff880d 50%,#0f83 100%);border-radius:10px;padding:1px;transition:opacity .2s;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.sum-card:hover{border-color:#0f86;transform:translateY(-1px);box-shadow:inset 0 0 0 1px #00ff8814,0 0 24px #00ff881f,0 4px 16px #0006}.sum-card:hover:before{opacity:1}.sum-card.green{border-color:#0f86;box-shadow:inset 0 0 0 1px #00ff8814,0 0 18px #00ff881a}.sum-card.red{border-color:#f446;box-shadow:inset 0 0 0 1px #ff444414,0 0 18px #ff44441f}.sum-card.red:before{background:linear-gradient(135deg,#f446 0%,#ff44440d 50%,#f443 100%)}.sum-label{text-transform:uppercase;letter-spacing:.7px;color:#00ff88b3;margin-bottom:10px;font-size:11px;font-weight:500}.sum-card.red .sum-label{color:#ff6666b3}.sum-value{color:var(--text-primary,#fff);text-shadow:0 0 12px #00ff8826;justify-content:space-between;align-items:center;font-size:24px;font-weight:700;display:flex}.sum-card.red .sum-value{text-shadow:0 0 12px #f443}.sum-unit{color:var(--text-muted,#707070);text-shadow:none;margin-left:4px;font-size:13px;font-weight:400}.analytics-card{background:linear-gradient(#00ff8806 0%,#0000 60%),#0a0a0a;border:1px solid #00ff882e;border-radius:10px;margin-bottom:22px;padding:18px 22px;transition:box-shadow .2s,border-color .2s;position:relative;box-shadow:inset 0 0 0 1px #00ff880a,0 0 16px #00ff880a}.analytics-card:hover{border-color:#00ff884d;box-shadow:inset 0 0 0 1px #00ff8814,0 0 24px #00ff8814}.analytics-card .card-header{border-bottom:1px solid #00ff8814;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;padding-bottom:12px;display:flex}.analytics-card .card-header h3{color:var(--text-primary,#fff);text-shadow:0 0 8px #0f83;margin:0;font-size:15px;font-weight:600}.analytics-card .card-header h3 svg{color:#0f8;filter:drop-shadow(0 0 4px #00ff8880)}.analytics-card select{color:var(--text-primary,#fff);cursor:pointer;background:#0a0a0a;border:1px solid #00ff8840;border-radius:6px;max-width:180px;padding:6px 12px;font-size:12px;transition:border-color .15s,box-shadow .15s}.analytics-card select:hover,.analytics-card select:focus{border-color:#0f8;outline:none;box-shadow:0 0 8px #0f83}.dev-count{color:#00ff88b3;letter-spacing:.3px;background:#00ff880f;border:1px solid #00ff8826;border-radius:999px;padding:4px 12px;font-size:11px;font-weight:500}.empty-state-mini{text-align:center;color:var(--text-muted,#707070);flex-direction:column;align-items:center;gap:10px;padding:50px 20px;font-size:13px;display:flex}.empty-state-mini.ok{color:#0f8;text-shadow:0 0 8px #00ff884d;font-weight:500}.dev-list{flex-direction:column;gap:8px;display:flex}.dev-row{background:#0a0a0a;border:1px solid #1f1f1f;border-left:3px solid #555;border-radius:8px;grid-template-columns:2fr 3fr auto;align-items:center;gap:12px;padding:12px 16px;font-size:13px;transition:all .15s;display:grid}.dev-row:hover{background:#0d0d0d}.dev-row.minor{border-left-color:#fd4;box-shadow:-2px 0 8px #ffdd441a}.dev-row.warning{border-left-color:#f80;box-shadow:-2px 0 8px #ff880026}.dev-row.critical{background:#ff44440a;border-left-color:#f44;box-shadow:-2px 0 12px #f443}.dev-station strong{color:var(--text-primary,#fff)}.dev-greenhouse{color:var(--text-muted,#707070);margin-left:4px;font-size:12px}.dev-param{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.dev-label{color:var(--text-secondary,#a0a0a0);min-width:60px;font-weight:500}.dev-value{color:var(--text-primary,#fff);font-family:Courier New,monospace;font-weight:600}.dev-arrow{color:#f80;font-size:14px}.dev-limit{color:var(--text-muted,#707070);font-size:11px}.dev-severity{text-align:right;flex-direction:column;align-items:flex-end;gap:2px;font-size:11px;font-weight:500;display:flex}.dev-severity.minor{color:#fd4}.dev-severity.warning{color:#f80}.dev-severity.critical{color:#f44;text-shadow:0 0 6px #f446}.dev-pct{color:var(--text-muted,#707070);font-size:10px}.compare-table-wrap{border:1px solid #00ff880f;border-radius:6px;overflow-x:auto}.compare-table{border-collapse:collapse;width:100%;font-size:13px}.compare-table th{text-align:left;color:#00ff88b3;text-transform:uppercase;letter-spacing:.6px;background:#00ff8808;border-bottom:1px solid #00ff881f;padding:12px 14px;font-size:11px;font-weight:500}.compare-table th.num,.compare-table td.num{text-align:right;font-family:Courier New,monospace}.compare-table td{color:var(--text-primary,#fff);border-bottom:1px solid #161616;padding:11px 14px}.compare-table tr:hover td{background:#00ff8806}.compare-table td.muted{color:var(--text-muted,#707070);font-size:12px}.compare-table td.outlier{color:#f80;text-shadow:0 0 6px #ff88004d;background:#ff880014;font-weight:600}.table-legend{color:var(--text-muted,#707070);align-items:center;gap:6px;margin:12px 0 0;font-size:11px;display:flex}.outlier-dot{background:#f80;border-radius:50%;width:8px;height:8px;display:inline-block;box-shadow:0 0 6px #f809}.hours-tab{color:var(--text-secondary,#a0a0a0);cursor:pointer;background:0 0;border:1px solid #0f83;border-radius:6px;align-items:center;gap:4px;padding:6px 14px;font-size:12px;transition:all .15s;display:inline-flex}.hours-tab:hover{color:#0f8;border-color:#0f8;box-shadow:0 0 10px #0f83}.hours-tab.active{color:#0f8;background:#00ff881f;border-color:#0f8;box-shadow:0 0 12px #00ff884d,inset 0 0 0 1px #0f83}.spinning{animation:1s linear infinite spin}.hist-stats{border-bottom:1px solid #00ff8814;flex-wrap:wrap;gap:14px;margin-bottom:8px;padding:10px 0 14px;display:flex}.hist-stat{color:var(--text-muted,#707070);font-size:12px}.hist-stat span{margin-right:4px}.hist-stat strong{color:var(--text-primary,#fff);font-family:Courier New,monospace;font-weight:600}.hist-stat.hist-homog strong.good{color:#0f8;text-shadow:0 0 6px #0f86}.hist-stat.hist-homog strong.mid{color:#fd4}.hist-stat.hist-homog strong.bad{color:#f80;text-shadow:0 0 6px #ff88004d}.event-station-table{border-top:1px solid #00ff8814;margin-top:18px;padding-top:14px}.event-station-table h4{color:#00ff88b3;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;font-size:12px;font-weight:500}.alarm-summary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.alarm-sub-card{background:#0003;border:1px solid #00ff8814;border-radius:8px;padding:14px}.alarm-sub-card h4{color:#00ff88b3;text-transform:uppercase;letter-spacing:.5px;margin:0 0 10px;font-size:12px;font-weight:500}.alarm-stations-card{grid-column:1/-1}.alarm-stations-card .compare-table th,.alarm-stations-card .compare-table td{padding:8px 12px}.layout{background:var(--bg-primary);min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:10;flex-direction:column;width:220px;min-height:100vh;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{color:var(--neon);border-bottom:1px solid var(--border);letter-spacing:.5px;align-items:center;gap:10px;padding:20px 16px;font-size:18px;font-weight:700;display:flex}.logo-icon{color:var(--neon)}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.nav-item{border-radius:var(--radius);color:var(--text-secondary);align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--neon-glow);color:var(--neon);border:1px solid #0f83}.sidebar-footer{border-top:1px solid var(--border);align-items:center;gap:8px;padding:12px 8px;display:flex}.user-info{flex:1;align-items:center;gap:10px;display:flex;overflow:hidden}.user-avatar{background:var(--neon-glow);width:32px;height:32px;color:var(--neon);border:1px solid #00ff884d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.user-details{overflow:hidden}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.user-role{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:11px}.logout-btn{color:var(--text-muted);border-radius:var(--radius);background:0 0;border:none;align-items:center;padding:6px;transition:all .15s;display:flex}.logout-btn:hover{color:var(--red);background:#ff44441a}.main-content{flex:1;min-height:100vh;margin-left:220px;padding:20px 20px 20px 24px;overflow-y:auto}
