@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}.refresh-btn:hover{border-color:var(--neon);color:var(--neon)}.spinning{animation:1s linear infinite spin}@keyframes spin{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}.greenhouse-tabs{flex-wrap:wrap;gap:6px;margin-bottom:16px;display:flex}.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(280px,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}.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}.alarms-page{max-width:1200px}.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:14px;padding:14px 16px;transition:all .15s;display:flex}.alarm-row.resolved{opacity:.5}.alarm-severity{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.alarm-severity.red{color:var(--red);background:#ff44441f}.alarm-severity.orange{color:var(--orange);background:#ff88001f}.alarm-severity.yellow{color:var(--yellow);background:#ffcc001f}.alarm-severity.blue{color:var(--blue);background:#4488ff1f}.alarm-info{flex:1}.alarm-type{color:var(--text-primary);font-size:14px;font-weight:500}.alarm-location{color:var(--text-muted);margin-top:2px;font-size:12px}.alarm-values{text-align:right;flex-direction:column;gap:2px;display:flex}.alarm-val{font-size:13px;font-family:var(--font-mono);color:var(--text-primary)}.alarm-threshold{color:var(--text-muted);font-size:11px;font-family:var(--font-mono)}.alarm-time{color:var(--text-muted);white-space:nowrap;align-items:center;gap:4px;font-size:12px;display:flex}.alarm-actions{gap:6px;display:flex}.btn-ack{border-radius:var(--radius);color:var(--orange);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);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}.loading{text-align:center;color:var(--text-muted);padding:40px}.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)}.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}.data-table tr: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.active{background:var(--neon-glow);color:var(--neon)}.status-badge.expired{color:var(--red);background:#ff44441f}.status-badge.readonly{color:var(--orange);background:#ff88001f}.status-badge.suspended{color:var(--yellow);background:#ffcc001f}.modal-overlay{z-index:1000;background:#000000b3;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);width:100%;max-width:580px;max-height:90vh;overflow-y:auto}.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}.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:16px;font-weight:700}.plan-detail{color:var(--text-muted);font-size:11px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.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)}.layout{background:var(--bg-primary);min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;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:24px;overflow-y:auto}
