:root{--bg: #f8fafc;--surface: #ffffff;--surface2: #f1f5f9;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--primary: #1d4ed8;--primary-dark: #1e3a8a;--primary-light: #dbeafe;--accent: #f97316;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--radius: 8px;--shadow: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -2px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -4px rgba(0,0,0,.05)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,system-ui,sans-serif;font-size:14px;min-height:100vh;-webkit-font-smoothing:antialiased}.header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:10}.header-title{font-size:16px;font-weight:700;color:var(--primary);letter-spacing:-.01em}.header-tabs{display:flex;gap:4px}.tab-btn{padding:6px 14px;border:none;border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;font-size:13px;font-weight:500;transition:background .15s,color .15s}.tab-btn:hover{background:var(--surface2);color:var(--text)}.tab-btn.active{background:var(--primary);color:#fff}.main{padding:20px;display:grid;grid-template-columns:minmax(280px,360px) 1fr;grid-template-areas:"left right" "gauges gauges";gap:20px;align-items:stretch}.col-left{grid-area:left;display:flex;flex-direction:column;gap:16px;min-height:0}.col-right{grid-area:right;display:flex;flex-direction:column;gap:16px;min-height:0}.gauge-strip{grid-area:gauges}.col-left .card:last-child{flex:1;display:flex;flex-direction:column}.col-left .card:last-child .panel-meta{margin-top:auto}.col-right .history-card{flex:1;display:flex;flex-direction:column;min-height:0}@media (max-width: 820px){.main{grid-template-columns:1fr;grid-template-areas:"left" "right" "gauges"}}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.card-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.dot.offline{background:var(--muted)}.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.metric{display:flex;flex-direction:column;gap:2px}.metric-label{font-size:11px;color:var(--muted)}.metric-value{font-size:22px;font-weight:700;line-height:1}.metric-unit{font-size:11px;color:var(--muted)}.metric-value.ok{color:var(--text)}.metric-value.warn{color:var(--warning)}.metric-value.danger{color:var(--danger)}.gauge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border)}.needle-gauge{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:8px 6px 4px}.needle-gauge-label{font-size:14px;font-weight:700;color:var(--text);text-transform:capitalize;margin-top:6px;text-align:center;letter-spacing:-.01em}.needle-gauge-sub{font-size:12px;font-weight:600;margin-top:2px;text-align:center}.gauge-strip-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,210px));gap:20px;justify-content:center;padding-top:8px}.chart-area{flex:1;min-height:240px}.chart-area>*{height:100%}.gauge-wrap{display:flex;flex-direction:column;align-items:center;gap:8px}.gauge-row{display:flex;gap:16px;justify-content:center;margin-top:4px}.gauge-stat{text-align:center}.gauge-stat .lbl{font-size:10px;color:var(--muted)}.gauge-stat .val{font-size:15px;font-weight:600}.relay-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:12px;font-size:12px;font-weight:600}.relay-badge.on{background:#f59e0b22;color:var(--warning);border:1px solid var(--warning)}.relay-badge.off{background:#94a3b822;color:var(--muted);border:1px solid var(--border)}.alerts-page{padding:20px}.alerts-toolbar{display:flex;gap:10px;margin-bottom:14px;align-items:center}.filter-btn{padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--muted);cursor:pointer;font-size:12px}.filter-btn.active{border-color:var(--primary);color:var(--primary)}.alert-table{width:100%;border-collapse:collapse}.alert-table th{text-align:left;padding:8px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border)}.alert-table td{padding:10px;border-bottom:1px solid var(--border);vertical-align:middle}.alert-table tr:hover td{background:var(--surface2)}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.badge.overtemp,.badge.overvoltage,.badge.overload{background:#ef444422;color:var(--danger)}.badge.undertemp,.badge.undervoltage{background:var(--primary-light);color:var(--primary)}.badge.deviation,.badge.low_pf{background:#f59e0b22;color:var(--warning)}.resolve-btn{padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;font-size:12px}.resolve-btn:hover{border-color:var(--success);color:var(--success)}.resolved{color:var(--muted);font-size:12px}.settings-page{padding:20px;max-width:560px}.settings-page h2{font-size:15px;margin-bottom:16px}.form-section{margin-bottom:20px}.form-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:12px;color:var(--muted)}.field input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:7px 10px;font-size:14px;outline:none}.field input:focus{border-color:var(--primary)}.save-btn{padding:8px 24px;background:var(--primary);border:none;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:600;cursor:pointer}.save-btn:hover{opacity:.9}.save-msg{font-size:13px;color:var(--success);margin-left:12px}.device-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:6px 10px;font-size:13px;margin-bottom:16px;outline:none}.settings-page{max-width:780px}.param-threshold-table{display:flex;flex-direction:column;gap:2px}.param-threshold-head,.param-threshold-row{display:grid;grid-template-columns:160px 1fr 100px 100px;align-items:center;gap:10px}.param-threshold-head{font-size:10px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 4px 6px;border-bottom:1px solid var(--border)}.param-threshold-row{padding:5px 4px;border-radius:var(--radius)}.param-threshold-row:hover{background:var(--surface2)}.param-name{font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.param-stats{display:flex;gap:6px;flex-wrap:wrap}.stat-badge{display:inline-flex;align-items:center;gap:3px;background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:2px 6px;font-size:10px;white-space:nowrap}.stat-badge-label{color:var(--muted)}.stat-badge-value{color:var(--text);font-weight:600}.threshold-input{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:5px 8px;font-size:12px;outline:none;width:100%}.threshold-input:focus{border-color:var(--primary)}.chart-toolbar{display:flex;gap:6px;margin-bottom:12px;align-items:center;flex-wrap:wrap}.period-btn{padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;font-size:12px;transition:border-color .15s,color .15s}.period-btn:hover,.period-btn.active{border-color:var(--primary);color:var(--primary)}.live-btn{padding:3px 9px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:11px;cursor:pointer;transition:border-color .15s,color .15s;white-space:nowrap}.live-btn.active{border-color:var(--success);color:var(--success)}.toolbar-sep{flex:1;min-width:4px}.nav-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;font-size:14px;flex-shrink:0;transition:border-color .15s,color .15s}.nav-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.nav-btn:disabled{opacity:.3;cursor:default}.chart-range{font-size:11px;color:var(--muted);white-space:nowrap;padding:0 2px}.chart-spin{font-size:14px;color:var(--primary);display:inline-block;animation:chart-rotate 1s linear infinite}@keyframes chart-rotate{to{transform:rotate(360deg)}}.chart-empty{color:var(--muted);padding:40px 0;text-align:center;font-size:13px}.load-earlier-btn{display:block;width:100%;margin-top:6px;padding:5px;border:1px dashed var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);font-size:12px;cursor:pointer;text-align:center;transition:border-color .15s,color .15s}.load-earlier-btn:hover{border-color:var(--primary);color:var(--primary)}.series-checks{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.series-check{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 9px 4px 6px;border-radius:12px;border:1px solid var(--border);background:var(--surface2);color:var(--text);transition:background .15s,border-color .15s,color .15s,opacity .15s}.series-check:hover{border-color:var(--primary)}.series-check:not(.off){background:var(--surface2);border-color:var(--border);opacity:1}.series-check.off{opacity:.4;background:transparent;color:var(--muted)}.series-check.off .series-dot{background:var(--border)!important}.series-check input{display:none}.series-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;transition:background .15s}.panel-meta{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;font-size:11px;color:var(--muted)}.param-cfg-btn{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);background:transparent;color:var(--muted);cursor:pointer;font-size:13px;padding:0;transition:border-color .15s,color .15s}.param-cfg-btn:hover{border-color:var(--primary);color:var(--primary)}.param-cfg-panel{margin-bottom:12px;padding:10px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius)}.param-cfg-title{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}.param-cfg-checks{display:flex;flex-wrap:wrap;gap:8px 14px}@media (max-width: 640px){.main{flex-direction:column}.metric-grid{grid-template-columns:1fr 1fr 1fr}}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:36px 32px;width:100%;max-width:360px}.login-logo{font-size:20px;font-weight:700;color:var(--primary);margin-bottom:4px}.login-sub{font-size:13px;color:var(--muted);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:14px}.login-error{background:#ef444422;border:1px solid var(--danger);border-radius:var(--radius);color:var(--danger);font-size:12px;padding:7px 10px}.mgr-wrap{min-height:100vh}.mgr-stats-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:4px}.mgr-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;min-width:110px;flex:1}.mgr-stat-value{font-size:26px;font-weight:700;line-height:1}.mgr-stat-label{font-size:11px;color:var(--muted);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.mgr-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:10px}.mgr-table{width:100%;border-collapse:collapse;font-size:13px}.mgr-table th{text-align:left;padding:8px 10px;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap}.mgr-table td{padding:9px 10px;border-bottom:1px solid var(--border);vertical-align:middle}.mgr-table tr:hover td{background:var(--surface2)}.mgr-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600}.mgr-badge.admin{background:var(--primary-light);color:var(--primary)}.mgr-badge.viewer{background:#94a3b822;color:var(--muted)}.mgr-badge.energy{background:#f59e0b22;color:var(--warning)}.mgr-badge.temperature{background:#22c55e22;color:var(--success)}.mgr-badge.telegram{background:var(--primary-light);color:var(--primary)}.mgr-badge.whatsapp,.mgr-badge.sent{background:#22c55e22;color:var(--success)}.mgr-badge.failed{background:#ef444422;color:var(--danger)}.mgr-user-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:4px}.mgr-user-form input,.mgr-user-form select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:6px 10px;font-size:13px;outline:none}.mgr-user-form input:focus,.mgr-user-form select:focus{border-color:var(--primary)}.mgr-inline-form{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.mgr-inline-form input,.mgr-inline-form select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:4px 8px;font-size:12px;outline:none}.mgr-assign-panel{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-top:4px}.mgr-assign-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:6px;max-height:260px;overflow-y:auto}.mgr-assign-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;background:var(--surface);transition:border-color .15s}.mgr-assign-item:hover{border-color:var(--primary)}.mgr-assign-item.checked{border-color:var(--success);background:#22c55e0d}.mgr-assign-item input{accent-color:var(--success);width:14px;height:14px;flex-shrink:0}.mgr-assign-name{font-size:12px;flex:1}.mgr-toggle{display:inline-flex;align-items:center;cursor:pointer}.mgr-toggle input{display:none}.mgr-toggle-track{width:36px;height:20px;background:var(--border);border-radius:10px;position:relative;transition:background .2s}.mgr-toggle-track:after{content:"";position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s}.mgr-toggle input:checked+.mgr-toggle-track{background:var(--success)}.mgr-toggle input:checked+.mgr-toggle-track:after{transform:translate(16px)}
