:root{--primary:#0f172a;--accent:#6366f1;--accent2:#8b5cf6;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--bg:#f1f5f9;--card:#fff;--border:#e2e8f0;--text:#1e293b;--muted:#64748b;--radius:12px;--shadow:0 4px 24px rgba(0,0,0,0.08);}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;}

/* LOGIN */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a 0%,#1e1b4b 50%,#0f172a 100%);position:relative;overflow:hidden;}
.login-bg{position:absolute;inset:0;pointer-events:none;}
.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.25;animation:float 8s ease-in-out infinite;}
.orb1{width:500px;height:500px;background:radial-gradient(circle,#6366f1,transparent);top:-150px;left:-150px;}
.orb2{width:400px;height:400px;background:radial-gradient(circle,#8b5cf6,transparent);bottom:-100px;right:-100px;animation-delay:3s;}
.orb3{width:300px;height:300px;background:radial-gradient(circle,#06b6d4,transparent);top:40%;left:40%;animation-delay:6s;}
@keyframes float{0%,100%{transform:translateY(0) scale(1);}50%{transform:translateY(-30px) scale(1.08);}}
.login-card{background:rgba(255,255,255,0.04);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,0.1);border-radius:24px;padding:44px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:0 32px 80px rgba(0,0,0,0.4);}
.login-logo{text-align:center;margin-bottom:36px;}
.logo-icon{font-size:3.5rem;margin-bottom:10px;animation:pulse 2s ease-in-out infinite;}
@keyframes pulse{0%,100%{filter:drop-shadow(0 0 24px #6366f1);}50%{filter:drop-shadow(0 0 40px #8b5cf6);}}
.login-logo h1{font-size:2rem;font-weight:800;color:#fff;letter-spacing:-1px;}
.login-logo p{color:rgba(255,255,255,0.45);font-size:0.875rem;margin-top:6px;}
.login-card .form-group{margin-bottom:18px;}
.login-card label{display:block;font-size:0.72rem;font-weight:700;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:7px;}
.login-card input{width:100%;padding:13px 16px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:10px;color:#fff;font-size:0.9rem;outline:none;transition:all 0.2s;}
.login-card input:focus{border-color:#6366f1;background:rgba(99,102,241,0.12);box-shadow:0 0 0 3px rgba(99,102,241,0.15);}
.login-card input::placeholder{color:rgba(255,255,255,0.25);}
.error-msg{background:rgba(239,68,68,0.12);border:1px solid rgba(239,68,68,0.25);color:#fca5a5;padding:10px 14px;border-radius:8px;font-size:0.82rem;margin-bottom:14px;}
.login-hint{text-align:center;color:rgba(255,255,255,0.25);font-size:0.72rem;margin-top:18px;}

/* SIDEBAR */
.app{display:flex;min-height:100vh;}
.sidebar{width:240px;background:var(--primary);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;box-shadow:4px 0 24px rgba(0,0,0,0.25);}
.sidebar-logo{padding:20px 18px;border-bottom:1px solid rgba(255,255,255,0.07);display:flex;align-items:center;gap:12px;}
.logo-sm{width:38px;height:38px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;box-shadow:0 4px 12px rgba(99,102,241,0.4);}
.sidebar-logo h2{font-size:0.95rem;font-weight:700;color:#fff;}
.sidebar-logo span{font-size:0.65rem;color:rgba(255,255,255,0.35);}
.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto;}
.nav-section{padding:14px 18px 4px;font-size:0.6rem;text-transform:uppercase;letter-spacing:1.5px;color:rgba(255,255,255,0.28);font-weight:700;}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 18px;cursor:pointer;font-size:0.84rem;color:rgba(255,255,255,0.6);border-left:3px solid transparent;transition:all 0.2s;}
.nav-item:hover{background:rgba(255,255,255,0.05);color:#fff;}
.nav-item.active{background:rgba(99,102,241,0.18);color:#fff;border-left-color:#6366f1;}
.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,0.07);display:flex;align-items:center;gap:10px;}
.user-info{flex:1;display:flex;align-items:center;gap:10px;}
.user-avatar{width:34px;height:34px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:0.9rem;flex-shrink:0;}
.user-name{font-size:0.82rem;font-weight:600;color:#fff;}
.user-role{font-size:0.65rem;color:rgba(255,255,255,0.35);text-transform:uppercase;}
.btn-logout{background:rgba(255,255,255,0.06);border:none;color:rgba(255,255,255,0.4);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:1rem;transition:all 0.2s;}
.btn-logout:hover{background:rgba(239,68,68,0.2);color:#ef4444;}

/* MAIN */
.main{margin-left:240px;flex:1;display:flex;flex-direction:column;}
.page{display:none;flex-direction:column;min-height:100vh;}
.page.active{display:flex;}
.topbar{background:var(--card);border-bottom:1px solid var(--border);padding:15px 28px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 1px 8px rgba(0,0,0,0.04);}
.topbar h1{font-size:1.1rem;font-weight:700;}
.topbar-time{font-size:0.78rem;color:var(--muted);}
.content{padding:24px 28px;flex:1;}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px;}
.stat-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);position:relative;overflow:hidden;transition:transform 0.2s,box-shadow 0.2s;cursor:default;}
.stat-card:hover{transform:translateY(-3px);box-shadow:0 8px 32px rgba(0,0,0,0.12);}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--g,linear-gradient(90deg,#6366f1,#8b5cf6));}
.stat-label{font-size:0.7rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:0.6px;}
.stat-value{font-size:2.2rem;font-weight:800;color:var(--text);line-height:1;margin:6px 0 4px;}
.stat-sub{font-size:0.72rem;color:var(--muted);}

/* CHARTS */
.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.chart-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);}
.chart-title{font-size:0.88rem;font-weight:700;margin-bottom:16px;color:var(--text);}

/* TABLE */
.table-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;}
.table-header{padding:16px 20px;border-bottom:1px solid var(--border);}
.table-header h3{font-size:0.9rem;font-weight:700;}
.table-toolbar{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;gap:10px;align-items:center;}
.search-input{flex:1;padding:8px 14px;border:1px solid var(--border);border-radius:8px;font-size:0.85rem;outline:none;background:var(--bg);transition:border 0.2s;}
.search-input:focus{border-color:var(--accent);}
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:0.82rem;}
thead th{background:#f8fafc;padding:10px 14px;text-align:left;font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;}
tbody tr{border-bottom:1px solid var(--border);transition:background 0.15s;}
tbody tr:last-child{border-bottom:none;}
tbody tr:hover{background:#f8fafc;}
td{padding:11px 14px;vertical-align:middle;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:0.68rem;font-weight:700;}
.badge-blue{background:#eff6ff;color:#2563eb;}
.badge-purple{background:#f5f3ff;color:#7c3aed;}
.badge-green{background:#f0fdf4;color:#16a34a;}
.badge-red{background:#fef2f2;color:#dc2626;}
.badge-gray{background:#f1f5f9;color:#475569;}
.badge-ai{background:linear-gradient(135deg,#f5f3ff,#eff6ff);color:#6d28d9;border:1px solid #ddd6fe;}
.mono{font-family:'Courier New',monospace;font-size:0.74rem;color:var(--muted);}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;font-size:0.84rem;font-weight:600;cursor:pointer;border:none;transition:all 0.2s;}
.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 14px rgba(99,102,241,0.35);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(99,102,241,0.45);}
.btn-outline{background:transparent;color:var(--text);border:1px solid var(--border);}
.btn-outline:hover{background:var(--bg);}
.btn-success{background:var(--success);color:#fff;}
.btn-danger{background:var(--danger);color:#fff;}
.btn-sm{padding:5px 12px;font-size:0.78rem;}
.btn-full{width:100%;justify-content:center;padding:13px;font-size:0.95rem;}
.btn-icon{padding:6px 10px;border-radius:7px;background:var(--bg);border:1px solid var(--border);cursor:pointer;font-size:0.85rem;transition:all 0.2s;}
.btn-icon:hover{background:#fee2e2;border-color:#fca5a5;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);}
.modal{background:var(--card);border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,0.2);}
.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-header h3{font-size:1rem;font-weight:700;}
.modal-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--muted);padding:4px 8px;border-radius:6px;}
.modal-close:hover{background:var(--bg);color:var(--text);}
.modal-body{padding:20px 24px;}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-group.full{grid-column:1/-1;}
.form-group label{font-size:0.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;}
.form-group input,.form-group select,.form-group textarea{padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-size:0.875rem;color:var(--text);background:var(--bg);outline:none;transition:border 0.2s;font-family:inherit;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent);background:#fff;}
.form-group textarea{resize:vertical;min-height:80px;}

/* SITES */
.sites-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;height:calc(100vh - 130px);}
.sites-list{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow-y:auto;}
.site-item{padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.15s;}
.site-item:hover{background:var(--bg);}
.site-item.active{background:#f5f3ff;border-left:3px solid var(--accent);}
.site-item h4{font-size:0.875rem;font-weight:700;margin-bottom:2px;}
.site-item p{font-size:0.74rem;color:var(--muted);}
.map-container{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
.map-header{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.map-header h3{font-size:0.9rem;font-weight:700;}
.map-legend{display:flex;gap:14px;font-size:0.74rem;color:var(--muted);}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block;margin-right:4px;}
.dot.gw{background:#6366f1;}
.dot.nd{background:#10b981;}
.map-canvas{flex:1;position:relative;background:#f8fafc;background-image:radial-gradient(circle,#cbd5e1 1px,transparent 1px);background-size:28px 28px;overflow:hidden;cursor:crosshair;min-height:380px;}
.map-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--muted);font-size:0.9rem;line-height:2.2;}
.map-pin{position:absolute;transform:translate(-50%,-50%);cursor:pointer;transition:transform 0.2s;text-align:center;}
.map-pin:hover{transform:translate(-50%,-50%) scale(1.15);}
.pin-marker{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;box-shadow:0 4px 14px rgba(0,0,0,0.2);border:3px solid #fff;margin:0 auto;}
.pin-marker.gw{background:linear-gradient(135deg,#6366f1,#8b5cf6);}
.pin-marker.nd{background:linear-gradient(135deg,#10b981,#059669);}
.pin-label{font-size:0.62rem;margin-top:3px;font-weight:700;color:var(--text);background:#fff;padding:2px 6px;border-radius:4px;box-shadow:0 1px 4px rgba(0,0,0,0.1);white-space:nowrap;display:inline-block;}
.map-toolbar{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:10px;}

/* CONGREGATION */
.node-info-card{background:var(--card);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px;display:flex;gap:16px;align-items:center;}
.node-icon{width:56px;height:56px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0;}
.recipe-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden;}
.recipe-header{padding:16px 20px;background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;display:flex;align-items:center;justify-content:space-between;}
.recipe-header h3{font-size:0.95rem;font-weight:700;}
.recipe-header p{font-size:0.74rem;color:rgba(255,255,255,0.45);margin-top:2px;}
.motor-grid{padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;}
.motor-card{border:1px solid var(--border);border-radius:10px;padding:16px;background:#fafbff;transition:border-color 0.2s;}
.motor-card.saved{border-color:var(--success);background:#f0fdf4;}
.motor-card h5{font-size:0.85rem;font-weight:700;margin-bottom:12px;color:var(--text);}
.matrix-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:0.8rem;}
.matrix-row label{color:var(--muted);width:120px;flex-shrink:0;font-weight:500;}
.matrix-row input,.matrix-row select,.matrix-row textarea{flex:1;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:0.8rem;background:#fff;outline:none;transition:border 0.2s;}
.matrix-row input:focus,.matrix-row select:focus{border-color:var(--accent);}

/* IMPORT */
.import-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.import-card{background:var(--card);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--border);display:flex;flex-direction:column;gap:14px;}
.import-card h3{font-size:0.95rem;font-weight:700;}
.import-desc{font-size:0.76rem;color:var(--muted);line-height:1.5;}
.drop-zone{border:2px dashed var(--border);border-radius:10px;padding:28px;text-align:center;cursor:pointer;color:var(--muted);font-size:0.85rem;transition:all 0.2s;display:block;line-height:1.8;}
.drop-zone:hover{border-color:var(--accent);color:var(--accent);background:#f5f3ff;}
.format-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;padding:20px;}
.format-title{font-size:0.8rem;font-weight:700;color:var(--accent);margin-bottom:8px;}
.format-pre{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:12px;font-size:0.7rem;overflow-x:auto;white-space:pre;line-height:1.6;}

/* TOAST */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px;}
.toast{background:var(--primary);color:#fff;padding:12px 18px;border-radius:10px;font-size:0.84rem;box-shadow:0 8px 28px rgba(0,0,0,0.2);display:flex;align-items:center;gap:8px;animation:slideIn 0.3s ease;min-width:240px;}
.toast.success{background:var(--success);}
.toast.error{background:var(--danger);}
.toast.warning{background:var(--warning);color:#1e293b;}
@keyframes slideIn{from{transform:translateX(110%);opacity:0;}to{transform:translateX(0);opacity:1;}}

/* RESPONSIVE */
@media(max-width:900px){
  .sidebar{width:200px;}
  .main{margin-left:200px;}
  .charts-grid{grid-template-columns:1fr;}
  .sites-layout{grid-template-columns:1fr;height:auto;}
  .import-grid{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
}
.pin-actions{display:none;gap:4px;margin-top:4px;justify-content:center;}
.map-pin:hover .pin-actions{display:flex;}
.pin-btn{font-size:0.7rem;padding:2px 6px;border-radius:4px;cursor:pointer;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,0.15);transition:all 0.2s;}
.pin-btn:hover{transform:scale(1.1);}
.config-btn{background:#6366f1;color:#fff;}
.gw-btn{background:#10b981;color:#fff;}
.del-btn{background:#ef4444;color:#fff;}
.gw-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--card);border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,0.25);z-index:300;width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border);}
.gw-popup-header{padding:16px 20px;background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;display:flex;align-items:center;justify-content:space-between;}
.gw-popup-header h4{font-size:0.95rem;font-weight:700;}
.gw-popup-header button{background:rgba(255,255,255,0.1);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:0.9rem;}
.gw-popup-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;}
.gw-node-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.2s;font-size:0.82rem;}
.gw-node-item:hover{background:#f5f3ff;border-color:var(--accent);}
#mapCanvas.drag-over{background-color:#f0f4ff;border:2px dashed var(--accent);}
/* DATA TABS */
.data-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap;}
.data-tab{padding:7px 16px;border-radius:8px;border:1px solid var(--border);background:var(--bg);font-size:0.82rem;font-weight:600;cursor:pointer;transition:all 0.2s;color:var(--muted);}
.data-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.data-tab-content{display:none;}
.data-tab-content.active{display:block;}
.time-config{display:flex;align-items:center;gap:10px;background:#f8fafc;padding:10px 14px;border-radius:8px;margin-bottom:14px;flex-wrap:wrap;border:1px solid var(--border);}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:blink 1s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.data-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.data-chart-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--border);}
.data-chart-title{font-size:0.8rem;font-weight:700;margin-bottom:10px;color:var(--text);}
.live-values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;}
.live-val-card{background:#f8fafc;border-radius:8px;padding:12px;border:1px solid var(--border);}
.live-val-header{display:flex;justify-content:space-between;align-items:center;font-size:0.8rem;margin-bottom:8px;}
.live-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.live-progress-fill{height:100%;border-radius:3px;transition:width 0.5s ease;}

/* RMS */
.rms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;}
.rms-card{background:#f8fafc;border-radius:10px;padding:16px;border:1px solid var(--border);text-align:center;}
.rms-label{font-size:0.75rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;}
.rms-value{font-size:2rem;font-weight:800;color:var(--text);line-height:1;}
.rms-unit{font-size:0.72rem;color:var(--muted);margin-bottom:10px;}

/* WATER GRAPHIC */
.water-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:16px;}
.water-card{text-align:center;}
.water-label{font-size:0.78rem;font-weight:700;color:var(--text);margin-bottom:10px;}
.water-tank-wrap{display:flex;gap:6px;justify-content:center;align-items:flex-end;}
.water-tank{width:60px;height:180px;border:3px solid var(--border);border-radius:8px;position:relative;overflow:hidden;background:#f1f5f9;}
.water-fill{position:absolute;bottom:0;left:0;right:0;transition:height 0.8s ease;border-radius:0 0 5px 5px;}
.water-bubbles{position:absolute;bottom:0;left:0;right:0;height:100%;pointer-events:none;}
.bubble{position:absolute;bottom:0;border-radius:50%;background:rgba(255,255,255,0.5);animation:rise linear infinite;}
@keyframes rise{0%{bottom:0;opacity:0.8;}100%{bottom:100%;opacity:0;}}
.water-scale{display:flex;flex-direction:column;justify-content:space-between;height:180px;font-size:0.6rem;color:var(--muted);padding:2px 0;}
.water-value{font-size:0.85rem;font-weight:700;color:var(--text);margin-top:8px;}

/* PIN ACTIONS */
.pin-actions{display:none;gap:3px;margin-top:4px;justify-content:center;flex-wrap:wrap;}
.map-pin:hover .pin-actions{display:flex;}
.pin-btn{font-size:0.65rem;padding:2px 5px;border-radius:4px;cursor:pointer;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,0.15);transition:all 0.2s;border:none;}
.pin-btn:hover{transform:scale(1.1);}
.config-btn{background:#6366f1;color:#fff;}
.move-btn{background:#f59e0b;color:#fff;}
.data-btn{background:#10b981;color:#fff;}
.gw-btn{background:#06b6d4;color:#fff;}
.del-btn{background:#ef4444;color:#fff;}

/* GATEWAY POPUP */
.gw-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--card);border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,0.25);z-index:300;width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border);}
.gw-popup-header{padding:16px 20px;background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;display:flex;align-items:center;justify-content:space-between;}
.gw-popup-header h4{font-size:0.95rem;font-weight:700;}
.gw-popup-header button{background:rgba(255,255,255,0.1);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;}
.gw-popup-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;}
.gw-node-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.2s;font-size:0.82rem;}
.gw-node-item:hover{background:#f5f3ff;border-color:var(--accent);}
/* COMPANY NAME */
.sidebar-logo h2{font-size:0.8rem;font-weight:700;color:#fff;line-height:1.3;}
.sidebar-logo span{font-size:0.58rem;color:rgba(255,255,255,0.35);}

/* NODE HW ICON */
.node-hw-icon{display:inline-flex;align-items:center;}
.node-hw-icon svg{border-radius:4px;box-shadow:0 2px 6px rgba(99,102,241,0.3);}

/* NODE DATA MODAL CONTROLS */
.nd-control-bar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;background:#f8fafc;padding:12px 16px;border-radius:10px;border:1px solid var(--border);margin-bottom:10px;}
.nd-ctrl-group{display:flex;flex-direction:column;gap:4px;}
.nd-ctrl-group label{font-size:0.65rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;}
.nd-select{padding:6px 10px;border-radius:7px;border:1px solid var(--border);font-size:0.82rem;background:#fff;outline:none;}
.nd-select:focus{border-color:var(--accent);}
.nd-download-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:linear-gradient(135deg,#f0fdf4,#f8fafc);padding:10px 14px;border-radius:10px;border:1px solid #bbf7d0;margin-bottom:14px;}

/* DATA TABS */
.data-tab{padding:6px 13px;border-radius:7px;border:1px solid var(--border);background:var(--bg);font-size:0.78rem;font-weight:600;cursor:pointer;transition:all 0.2s;color:var(--muted);}
.data-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.data-tab-content{display:none;}
.data-tab-content.active{display:block;}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:blink 1s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}

/* OVERALL CHARTS */
.nd-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.nd-chart-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--border);}
.nd-chart-title{font-size:0.8rem;font-weight:700;margin-bottom:10px;}
.nd-live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;}
.nd-live-card{background:#f8fafc;border-radius:8px;padding:12px;border:1px solid var(--border);}

/* RMS */
.nd-rms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;}
.nd-rms-card{background:#f8fafc;border-radius:10px;padding:16px;border:1px solid var(--border);text-align:center;}
.nd-rms-label{font-size:0.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;}
.nd-rms-val{font-size:1.8rem;font-weight:800;line-height:1;}
.nd-rms-unit{font-size:0.7rem;color:var(--muted);margin-bottom:10px;}

/* WATER */
.nd-water-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:16px;}
.nd-water-card{text-align:center;}
.nd-water-label{font-size:0.78rem;font-weight:700;margin-bottom:8px;}
.nd-water-wrap{display:flex;gap:5px;justify-content:center;align-items:flex-end;}
.nd-water-tank{width:50px;height:150px;border:3px solid var(--border);border-radius:8px;position:relative;overflow:hidden;background:#f1f5f9;}
.nd-water-fill{position:absolute;bottom:0;left:0;right:0;transition:height 0.8s ease;border-radius:0 0 5px 5px;}
.nd-water-scale{display:flex;flex-direction:column;justify-content:space-between;height:150px;font-size:0.56rem;color:var(--muted);padding:2px 0;}
.nd-water-val{font-size:0.8rem;font-weight:700;margin-top:6px;}
@keyframes rise{0%{bottom:0;opacity:0.8;}100%{bottom:100%;opacity:0;}}

/* PICK TO PICK */
.nd-ptp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;}
.nd-ptp-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--border);}
.nd-ptp-stat{flex:1;text-align:center;}
.nd-ptp-lbl{font-size:0.62rem;color:var(--muted);font-weight:600;text-transform:uppercase;margin-bottom:3px;}
.nd-ptp-val{font-size:1rem;font-weight:800;}

/* PIN ACTIONS */
.pin-actions{display:none;gap:3px;margin-top:4px;justify-content:center;flex-wrap:wrap;}
.map-pin:hover .pin-actions{display:flex;}
.pin-btn{font-size:0.65rem;padding:2px 5px;border-radius:4px;cursor:pointer;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,0.15);transition:all 0.2s;border:none;}
.pin-btn:hover{transform:scale(1.1);}
.config-btn{background:#6366f1;color:#fff;}
.move-btn{background:#f59e0b;color:#fff;}
.data-btn{background:#10b981;color:#fff;}
.gw-btn{background:#06b6d4;color:#fff;}
.del-btn{background:#ef4444;color:#fff;}

/* GW POPUP */
.gw-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--card);border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,0.25);z-index:300;width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border);}
.gw-popup-header{padding:16px 20px;background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;display:flex;align-items:center;justify-content:space-between;}
.gw-popup-header h4{font-size:0.95rem;font-weight:700;}
.gw-popup-header button{background:rgba(255,255,255,0.1);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;}
.gw-popup-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;}
.gw-node-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.2s;font-size:0.82rem;}
.gw-node-item:hover{background:#f5f3ff;border-color:var(--accent);}
.nd-control-bar{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap;background:#f8fafc;padding:12px 16px;border-radius:10px;border:1px solid var(--border);margin-bottom:10px;}
.nd-ctrl-group{display:flex;flex-direction:column;gap:4px;}
.nd-ctrl-group label{font-size:0.65rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;}
.nd-select{padding:6px 10px;border-radius:7px;border:1px solid var(--border);font-size:0.82rem;background:#fff;outline:none;}
.nd-download-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;background:linear-gradient(135deg,#f0fdf4,#f8fafc);padding:10px 14px;border-radius:10px;border:1px solid #bbf7d0;margin-bottom:14px;}
.data-tab{padding:6px 13px;border-radius:7px;border:1px solid var(--border);background:var(--bg);font-size:0.78rem;font-weight:600;cursor:pointer;transition:all 0.2s;color:var(--muted);}
.data-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.data-tab-content{display:none;}
.data-tab-content.active{display:block;}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--success);animation:blink 1s infinite;}
@keyframes blink{0%,100%{opacity:1;}50%{opacity:0.3;}}
.nd-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px;}
.nd-chart-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--border);}
.nd-chart-title{font-size:0.8rem;font-weight:700;margin-bottom:10px;}
.nd-live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:10px;}
.nd-live-card{background:#f8fafc;border-radius:8px;padding:12px;border:1px solid var(--border);}
.nd-rms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;}
.nd-rms-card{background:#f8fafc;border-radius:10px;padding:16px;border:1px solid var(--border);text-align:center;}
.nd-rms-label{font-size:0.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;}
.nd-rms-val{font-size:1.8rem;font-weight:800;line-height:1;}
.nd-rms-unit{font-size:0.7rem;color:var(--muted);margin-bottom:10px;}
.nd-water-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:16px;}
.nd-water-card{text-align:center;}
.nd-water-label{font-size:0.78rem;font-weight:700;margin-bottom:8px;}
.nd-water-wrap{display:flex;gap:5px;justify-content:center;align-items:flex-end;}
.nd-water-tank{width:50px;height:150px;border:3px solid var(--border);border-radius:8px;position:relative;overflow:hidden;background:#f1f5f9;}
.nd-water-fill{position:absolute;bottom:0;left:0;right:0;transition:height 0.8s ease;border-radius:0 0 5px 5px;}
.nd-water-scale{display:flex;flex-direction:column;justify-content:space-between;height:150px;font-size:0.56rem;color:var(--muted);padding:2px 0;}
.nd-water-val{font-size:0.8rem;font-weight:700;margin-top:6px;}
@keyframes rise{0%{bottom:0;opacity:0.8;}100%{bottom:100%;opacity:0;}}
.nd-ptp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;}
.nd-ptp-card{background:#f8fafc;border-radius:10px;padding:14px;border:1px solid var(--border);}
.nd-ptp-stat{flex:1;text-align:center;}
.nd-ptp-lbl{font-size:0.62rem;color:var(--muted);font-weight:600;text-transform:uppercase;margin-bottom:3px;}
.nd-ptp-val{font-size:1rem;font-weight:800;}
.pin-actions{display:none;gap:3px;margin-top:4px;justify-content:center;flex-wrap:wrap;}
.map-pin:hover .pin-actions{display:flex;}
.pin-btn{font-size:0.65rem;padding:2px 5px;border-radius:4px;cursor:pointer;background:#fff;box-shadow:0 1px 4px rgba(0,0,0,0.15);transition:all 0.2s;border:none;}
.pin-btn:hover{transform:scale(1.1);}
.config-btn{background:#6366f1;color:#fff;}
.move-btn{background:#f59e0b;color:#fff;}
.data-btn{background:#10b981;color:#fff;}
.gw-btn{background:#06b6d4;color:#fff;}
.del-btn{background:#ef4444;color:#fff;}
.gw-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--card);border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,0.25);z-index:300;width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border);}
.gw-popup-header{padding:16px 20px;background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#fff;display:flex;align-items:center;justify-content:space-between;}
.gw-popup-header h4{font-size:0.95rem;font-weight:700;}
.gw-popup-header button{background:rgba(255,255,255,0.1);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;}
.gw-popup-body{padding:16px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;}
.gw-node-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all 0.2s;font-size:0.82rem;}
.gw-node-item:hover{background:#f5f3ff;border-color:var(--accent);}
.sidebar-logo h2{font-size:0.8rem;font-weight:700;color:#fff;line-height:1.3;}
.sidebar-logo span{font-size:0.58rem;color:rgba(255,255,255,0.35);}
/* MOTOR HEALTH */
.motor-health-bar{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border);}
.health-score-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:20px;font-size:0.72rem;font-weight:800;color:#fff;}
.health-track{height:8px;background:var(--border);border-radius:4px;overflow:hidden;}
.health-fill{height:100%;border-radius:4px;transition:width 0.5s ease;}

/* MOTOR SECTIONS */
.motor-section-title{font-size:0.68rem;font-weight:800;text-transform:uppercase;letter-spacing:0.8px;color:var(--accent);margin:14px 0 8px;padding-bottom:5px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:5px;}

/* FAULT FREQ INFO */
.fault-freq-info{font-size:0.72rem;color:var(--muted);background:#f8fafc;padding:6px 10px;border-radius:6px;margin-bottom:8px;border-left:3px solid var(--accent);}

/* TIMING CONFIG */
.timing-select{flex:1;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-size:0.8rem;background:#fff;outline:none;}
.timing-select:focus{border-color:var(--accent);}
.timing-info{font-size:0.72rem;color:#059669;background:#f0fdf4;padding:6px 10px;border-radius:6px;margin-bottom:8px;border-left:3px solid #10b981;font-weight:500;}

/* CLOUD CONFIG PREVIEW */
.cloud-config-preview{background:linear-gradient(135deg,#0f172a,#1e1b4b);border-radius:10px;padding:12px 16px;margin:12px 0;color:#fff;}
.ccp-title{font-size:0.72rem;font-weight:700;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:8px;}
.ccp-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid rgba(255,255,255,0.08);font-size:0.78rem;color:rgba(255,255,255,0.6);}
.ccp-row:last-child{border-bottom:none;}
.ccp-val{font-weight:700;color:#fff;}

/* SLEEP STATUS */
.sleep-status-bar{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#1e293b,#334155);color:#fff;padding:10px 16px;border-radius:10px;margin-bottom:12px;gap:10px;flex-wrap:wrap;}
.sleep-status-bar span{font-size:0.82rem;font-weight:600;}

