*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#f5f7fa;--card:#ffffff;--border:#e8ecf1;--border-light:#f0f2f5;
  --text:#1a2233;--text-secondary:#6b7280;--text-muted:#9ca3af;
  --accent:#007BFF;--accent-light:rgba(0,123,255,.08);--accent-hover:#0045DB;
  --brand-violet:#A33CFF;--brand-cyan:#65C7FF;--brand-navy:#1F2933;
  --pv:#f59e0b;--pv-light:rgba(245,158,11,.08);
  --grid-c:#3b82f6;--grid-light:rgba(59,130,246,.08);
  --load:#ef4444;--load-light:rgba(239,68,68,.08);
  --batt:#10b981;--batt-light:rgba(16,185,129,.08);
  --online:#22c55e;--offline:#ef4444;--warning:#f59e0b;
  --radius:12px;--radius-sm:8px;--radius-xs:6px;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.08);
  --shadow-lg:0 10px 30px rgba(0,0,0,.1);
  --font-display:'Poppins',sans-serif;
  --font-body:'Montserrat',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;min-height:100vh;-webkit-font-smoothing:antialiased}

/* -- Navbar -- */
.navbar{background:var(--card);border-bottom:1px solid var(--border);padding:0 24px;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:50}
.nav-left{display:flex;align-items:center;gap:32px}
.nav-logo{display:flex;align-items:center;text-decoration:none}
.nav-tabs{display:flex;gap:4px;height:56px;align-items:stretch}
.nav-tab{display:flex;align-items:center;padding:0 16px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;position:relative;transition:color .2s;font-family:var(--font-body);white-space:nowrap}
.nav-tab:hover{color:var(--text)}
.nav-tab.active{color:var(--accent);font-weight:600}
.nav-tab.active::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:2px;background:var(--accent);border-radius:2px 2px 0 0}
.nav-tab .tab-badge{background:var(--accent-light);color:var(--accent);font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;margin-left:6px}
.nav-right{display:flex;align-items:center;gap:12px}
.nav-user{font-size:12px;color:var(--text-secondary);font-weight:500}
.btn-logout{padding:6px 14px;background:var(--load-light);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-xs);color:var(--load);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.btn-logout:hover{background:rgba(239,68,68,.15)}
.btn-refresh{padding:6px 10px;background:var(--accent-light);border:1px solid rgba(0,123,255,.15);border-radius:var(--radius-xs);color:var(--accent);cursor:pointer;display:flex;align-items:center;transition:all .2s}
.btn-refresh:hover{background:rgba(0,123,255,.12)}
.btn-refresh svg{width:16px;height:16px}

/* -- Main -- */
.main{max-width:1400px;margin:0 auto;padding:20px 24px 40px}
.tab-panel{display:none}
.tab-panel.active{display:block;animation:fadeUp .3s ease-out}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* -- KPI Cards -- */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi-card{border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;color:#fff;min-height:100px}
.kpi-card .kpi-icon{position:absolute;top:16px;right:16px;width:40px;height:40px;background:rgba(255,255,255,.2);border-radius:10px;display:flex;align-items:center;justify-content:center}
.kpi-card .kpi-icon svg{width:22px;height:22px;stroke:rgba(255,255,255,.9)}
.kpi-card .kpi-label{font-size:12px;font-weight:500;opacity:.85;margin-bottom:8px;letter-spacing:.02em}
.kpi-card .kpi-value{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.1;margin-bottom:2px}
.kpi-card .kpi-unit{font-size:13px;font-weight:400;opacity:.7}
.kpi-card .kpi-sub{font-size:11px;opacity:.6;margin-top:6px}
.kpi-pv{background:linear-gradient(135deg,#007BFF,#65C7FF)}
.kpi-daily{background:linear-gradient(135deg,#0045DB,#007BFF)}
.kpi-monthly{background:linear-gradient(135deg,#A33CFF,#65C7FF)}
.kpi-total{background:linear-gradient(135deg,#1F2933,#007BFF)}

/* -- Toolbar -- */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.toolbar-left{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.search-box{position:relative}
.search-box input{padding:8px 12px 8px 34px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font-body);color:var(--text);background:var(--card);width:240px;transition:border-color .2s}
.search-box input:focus{outline:none;border-color:var(--accent)}
.search-box input::placeholder{color:var(--text-muted)}
.search-box svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;stroke:var(--text-muted)}
.filter-tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px}
.filter-tab{padding:6px 14px;font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;border-radius:var(--radius-xs);transition:all .2s;font-family:var(--font-body);white-space:nowrap}
.filter-tab:hover{color:var(--text)}
.filter-tab.active{background:var(--card);color:var(--accent);font-weight:600;box-shadow:var(--shadow)}
.filter-tab .count{font-size:10px;font-weight:700;margin-left:4px;opacity:.7}
.toolbar-right{display:flex;align-items:center;gap:8px}

/* -- Device Table -- */
.table-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;color:var(--text-muted);font-size:11px;padding:12px 14px;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.04em;font-weight:600;background:var(--bg);white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--border-light);font-size:13px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover{background:rgba(0,123,255,.02)}
.tbl .td-name{font-weight:600;color:var(--text)}
.tbl .td-sub{font-size:11px;color:var(--text-muted);font-weight:400;display:block;margin-top:1px}
.tbl .td-right{text-align:right;font-variant-numeric:tabular-nums}
.tbl .td-center{text-align:center}
.tbl .td-mono{font-family:'Cascadia Code','Fira Code',Consolas,monospace;font-size:12px;color:var(--text-secondary)}

/* Status dot */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;flex-shrink:0}
.dot-online{background:var(--online);box-shadow:0 0 6px rgba(34,197,94,.4)}
.dot-offline{background:var(--offline)}
.dot-warning{background:var(--warning)}
.status-pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.status-pill.online{background:rgba(34,197,94,.08);color:#16a34a}
.status-pill.offline{background:rgba(239,68,68,.08);color:var(--offline)}
.status-pill.warning{background:rgba(245,158,11,.08);color:#d97706}

/* EMS Mode badge (Anlagenliste) */
.ems-mode-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.02em;margin-top:3px;line-height:1.3}
.ems-mode-tag.mode-auto{background:rgba(16,185,129,.1);color:#059669;border:1px solid rgba(16,185,129,.2)}
.ems-mode-tag.mode-manual{background:var(--accent-light);color:var(--accent);border:1px solid rgba(0,123,255,.2)}
.ems-mode-tag.mode-safe{background:rgba(239,68,68,.08);color:var(--load);border:1px solid rgba(239,68,68,.2)}
.ems-mode-tag.state-charging{background:rgba(59,130,246,.08);color:var(--grid-c);border:1px solid rgba(59,130,246,.2)}
.ems-mode-tag.state-discharging{background:rgba(245,158,11,.08);color:#d97706;border:1px solid rgba(245,158,11,.2)}
.ems-mode-tag.state-error{background:rgba(239,68,68,.1);color:var(--load);border:1px solid rgba(239,68,68,.25)}
.ems-mode-tag.state-curtailed{background:rgba(239,68,68,.06);color:#b91c1c;border:1px solid rgba(239,68,68,.2)}

/* SOC bar */
.soc-bar{display:flex;align-items:center;gap:8px}
.soc-bar-track{width:48px;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden}
.soc-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}

/* Sparkline */
.sparkline{display:block}

/* Action buttons */
.btn-action{padding:5px 12px;border-radius:var(--radius-xs);font-size:11px;font-weight:600;cursor:pointer;border:1px solid;transition:all .2s;font-family:var(--font-body);text-decoration:none;display:inline-block}
.btn-action.primary{background:var(--accent-light);border-color:rgba(0,123,255,.2);color:var(--accent)}
.btn-action.primary:hover{background:rgba(0,123,255,.15)}
.btn-action.danger{background:var(--load-light);border-color:rgba(239,68,68,.2);color:var(--load)}
.btn-action.danger:hover{background:rgba(239,68,68,.15)}
.btn-action.success{background:var(--batt-light);border-color:rgba(16,185,129,.2);color:#059669}
.btn-action.success:hover{background:rgba(16,185,129,.15)}

/* -- Energie-Tab -- */
.energy-live-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}
.energy-live-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;transition:border-color .2s}
.energy-live-item:hover{border-color:rgba(0,123,255,.2)}
.energy-live-item .eli-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:block;margin-bottom:6px}
.energy-live-item .eli-value{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.1}
.energy-live-item .eli-unit{font-size:12px;color:var(--text-muted);font-weight:400}
.energy-live-item.pv .eli-value{color:var(--pv)}
.energy-live-item.grid .eli-value{color:var(--grid-c)}
.energy-live-item.load .eli-value{color:var(--load)}
.energy-live-item.batt .eli-value{color:var(--batt)}
.energy-live-item.soc .eli-value{color:var(--accent)}

.badges-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.badge{padding:5px 14px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid}
.badge-mode{background:var(--accent-light);color:var(--accent);border-color:rgba(0,123,255,.2)}
.badge-state{background:var(--batt-light);color:#059669;border-color:rgba(16,185,129,.2)}
.badge-14a{background:var(--pv-light);color:#d97706;border-color:rgba(245,158,11,.2)}
.badge-14a.active{background:rgba(239,68,68,.08);color:var(--load);border-color:rgba(239,68,68,.3);animation:pulse14 2s ease-in-out infinite}
.badge-winter{background:var(--grid-light);color:var(--grid-c);border-color:rgba(59,130,246,.2)}
.badge-winter.active{background:rgba(59,130,246,.15);color:#1d4ed8}
.badge-modbus{background:var(--batt-light);color:#059669;border-color:rgba(16,185,129,.2)}
.badge-modbus.error{background:var(--load-light);color:var(--load);border-color:rgba(239,68,68,.2)}
@keyframes pulse14{0%,100%{opacity:1}50%{opacity:.5}}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);transition:border-color .2s}
.card:hover{border-color:rgba(0,123,255,.15)}
.card h3{font-size:11px;color:var(--text-muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.chart-container{position:relative;height:280px}
.chart-controls{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.chart-controls input[type=date],.chart-controls select{padding:7px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;font-family:var(--font-body)}
.chart-controls input[type=date]:focus,.chart-controls select:focus{outline:none;border-color:var(--accent)}
.btn-sm{padding:7px 14px;background:var(--accent);border:none;border-radius:var(--radius-xs);color:#fff;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:background .2s}
.btn-sm:hover{background:var(--accent-hover)}
.provider-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;margin-right:4px}
.provider-local{background:#f1f5f9;color:#64748b}
.provider-google{background:#e8f0fe;color:#1a73e8}
.provider-apple{background:#1d1d1f;color:#fff}
.chip{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500;background:var(--accent-light);color:var(--accent);margin-right:4px;cursor:default}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:16px}
.stat-item{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center}
.stat-item .si-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:block;margin-bottom:6px}
.stat-item .si-value{font-family:var(--font-display);font-size:22px;font-weight:700}

/* -- System Monitoring -- */
.monitor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:20px}
.monitor-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.monitor-card h3{font-size:11px;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.monitor-value{font-family:var(--font-display);font-size:28px;font-weight:700;line-height:1.1;margin-bottom:2px}
.monitor-sub{font-size:12px;color:var(--text-muted);margin-bottom:10px}
.monitor-bar{height:6px;background:var(--border-light);border-radius:3px;overflow:hidden;margin-bottom:12px}
.monitor-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}
.monitor-chart{position:relative;height:100px}

.section-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.section-title .auto-tag{font-size:9px;color:var(--text-muted);font-weight:400;letter-spacing:0;text-transform:none}

/* Readings table */
.readings-wrap{max-height:400px;overflow-y:auto;border-radius:var(--radius-sm)}
.readings-wrap::-webkit-scrollbar{width:6px}
.readings-wrap::-webkit-scrollbar-track{background:var(--bg)}
.readings-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* Clients section */
.clients-card{margin-top:16px}

/* -- Firmware -- */
.fw-upload-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}
.fw-form{display:flex;flex-direction:column;gap:10px}
.fw-form input[type=text],.fw-form input[type=file],.fw-form textarea{padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;font-family:var(--font-body)}
.fw-form input:focus,.fw-form textarea:focus{outline:none;border-color:var(--accent)}
.fw-form textarea{resize:vertical}

/* -- Toast -- */
.toast{position:fixed;top:-60px;right:20px;padding:12px 24px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;z-index:200;transition:top .35s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}
.toast.show{top:16px}
.toast.ok{background:#ecfdf5;color:#059669;border:1px solid rgba(16,185,129,.3)}
.toast.fail{background:#fef2f2;color:var(--load);border:1px solid rgba(239,68,68,.3)}

/* -- Refresh Bar -- */
.refresh-bar{position:fixed;top:0;left:0;width:100%;height:2px;z-index:100}
.refresh-bar .bar{height:100%;background:var(--accent);width:0;transition:width .3s}

/* -- Empty state -- */
.empty-state{padding:40px 20px;text-align:center;color:var(--text-muted);font-size:13px}
.empty-state svg{width:40px;height:40px;stroke:var(--border);margin-bottom:12px;display:block;margin-left:auto;margin-right:auto}

/* -- Anlage-Tab (DEYE Cloud Style) -- */
.station-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:20px}
.station-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.station-header-left{display:flex;align-items:center;gap:12px}
.station-header-left .station-name{font-family:var(--font-display);font-size:18px;font-weight:700}
.station-header-left .station-status{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600}
.station-header-left .station-meta{font-size:11px;color:var(--text-muted)}
.station-header select{padding:6px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-family:var(--font-body);color:var(--text)}

.flow-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.flow-card h3{font-size:13px;color:#1a1a2e;font-weight:600;margin:0}

/* Animated PowerFlow SVG */
.pf-wrap{max-width:580px;margin:0 auto}
.pf-wrap svg#pf{width:100%;height:auto;max-height:75vh}
@media(prefers-reduced-motion:reduce){.pf-wrap #dots-layer{display:none}}
.pf-toggles{display:flex;flex-wrap:wrap;gap:16px;margin:10px 0 0;align-items:center}
.pf-tgl-wrap{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);cursor:pointer;user-select:none}
.pf-tgl{position:relative;width:32px;height:18px;background:var(--border);border-radius:9px;transition:background .2s;flex-shrink:0}
.pf-tgl.on{background:var(--accent)}
.pf-tgl-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}
.pf-tgl.on .pf-tgl-knob{transform:translateX(14px)}

/* Summary sidebar */
.summary-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.summary-card .summary-header{padding:16px 18px 10px;font-size:12px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border-light)}
.summary-item{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border-light);transition:background .15s}
.summary-item:last-child{border-bottom:none}
.summary-item:hover{background:rgba(0,123,255,.02)}
.summary-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.summary-icon svg{width:20px;height:20px}
.summary-icon.ic-prod{background:rgba(245,158,11,.1)}
.summary-icon.ic-prod svg{stroke:#f59e0b}
.summary-icon.ic-cons{background:rgba(59,130,246,.1)}
.summary-icon.ic-cons svg{stroke:#3b82f6}
.summary-icon.ic-daily{background:rgba(16,185,129,.1)}
.summary-icon.ic-daily svg{stroke:#10b981}
.summary-icon.ic-co2{background:rgba(139,92,246,.1)}
.summary-icon.ic-co2 svg{stroke:#8b5cf6}
.summary-icon.ic-auto{background:rgba(236,72,153,.1)}
.summary-icon.ic-auto svg{stroke:#ec4899}
.summary-icon.ic-self{background:rgba(245,158,11,.1)}
.summary-icon.ic-self svg{stroke:#f59e0b}
.summary-text{flex:1;min-width:0}
.summary-text .st-label{font-size:11px;color:var(--text-muted);font-weight:500;display:block;margin-bottom:2px}
.summary-text .st-value{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--text);line-height:1.1}
.summary-text .st-unit{font-size:12px;font-weight:400;color:var(--text-muted)}

/* Revenue card */
.revenue-card{background:linear-gradient(135deg,#007BFF 0%,#65C7FF 100%);border-radius:var(--radius);padding:18px;color:#fff;margin-bottom:16px}
.revenue-card .rev-label{font-size:11px;font-weight:500;opacity:.8;margin-bottom:6px}
.revenue-card .rev-value{font-family:var(--font-display);font-size:32px;font-weight:700;line-height:1.1}
.revenue-card .rev-unit{font-size:14px;font-weight:400;opacity:.7}
.revenue-card .rev-sub{font-size:11px;opacity:.6;margin-top:8px;display:flex;gap:16px}
.revenue-card .rev-badge{display:inline-block;background:rgba(255,255,255,.2);padding:3px 10px;border-radius:12px;font-size:10px;font-weight:600;margin-top:8px}

/* Station device badges */
.dev-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:500;background:var(--bg);border:1px solid var(--border);color:var(--text-secondary)}
.dev-badge .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.btn-remote{display:none;align-items:center;gap:6px;padding:7px 14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s;box-shadow:0 2px 8px rgba(99,102,241,.25)}
.btn-remote:hover{filter:brightness(1.1);box-shadow:0 4px 12px rgba(99,102,241,.35)}
.btn-remote svg{width:14px;height:14px}

/* Station charts row */
.station-charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}

/* -- Detail Cards (Inverter/BMS/Comm) -- */
.detail-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px}
.detail-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.detail-card .dc-header{padding:12px 16px 8px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:8px}
.detail-card .dc-header .dc-dot{width:7px;height:7px;border-radius:50%}
.detail-card .dc-body{padding:10px 16px 14px}
.detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px;border-bottom:1px solid rgba(232,236,241,.3)}
.detail-row:last-child{border-bottom:none}
.detail-row .dr-label{color:var(--text-muted);font-weight:500}
.detail-row .dr-value{font-weight:600;color:var(--text);font-family:var(--font-display)}
.detail-row .dr-value.ok{color:#22c55e}
.detail-row .dr-value.warn{color:#f59e0b}
.detail-row .dr-value.err{color:#ef4444}
.detail-row .dr-value.muted{color:var(--text-muted);font-weight:400}
.pv-bar-row{display:flex;align-items:center;gap:8px;padding:3px 0}
.pv-bar-label{font-size:11px;color:var(--text-muted);width:26px;font-weight:500}
.pv-bar-track{flex:1;height:10px;background:var(--bg);border-radius:4px;overflow:hidden}
.pv-bar-fill{height:100%;border-radius:4px;transition:width .3s}
.pv-bar-val{font-size:11px;font-weight:600;width:48px;text-align:right;font-family:var(--font-display)}
.comm-dots{display:flex;gap:16px;flex-wrap:wrap;padding:6px 0}
.comm-dot-item{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500}
.comm-dot-item .cdot{width:8px;height:8px;border-radius:50%}
.comm-dot-item .cdot.on{background:#22c55e}
.comm-dot-item .cdot.off{background:#d1d5db}

/* -- Event-Log Card -- */
.log-card-full{grid-column:1/-1}
.log-toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--border-light)}
.log-toolbar select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-family:var(--font-body);background:var(--card);color:var(--text)}
.log-list{max-height:500px;overflow-y:auto;padding:0}
.log-entry{display:flex;align-items:baseline;gap:8px;padding:5px 16px;font-size:12px;font-family:'Cascadia Code','Fira Code',Consolas,monospace;border-bottom:1px solid rgba(232,236,241,.2)}
.log-entry:hover{background:rgba(0,123,255,.02)}
.log-entry .log-time{color:var(--text-muted);white-space:nowrap;min-width:60px}
.log-entry .log-lvl{font-weight:700;min-width:28px;text-align:center;border-radius:3px;padding:0 4px;font-size:10px}
.log-entry .log-lvl.INF{color:#6b7280}
.log-entry .log-lvl.WRN{color:#d97706;background:rgba(217,119,6,.08)}
.log-entry .log-lvl.ERR{color:#dc2626;background:rgba(220,38,38,.08)}
.log-entry .log-mod{color:var(--accent);min-width:56px;font-size:11px}
.log-entry .log-msg{color:var(--text);flex:1;word-break:break-word}
.log-empty{padding:20px 16px;text-align:center;color:var(--text-muted);font-size:12px}
.log-more{display:block;width:100%;padding:8px;text-align:center;font-size:12px;color:var(--accent);cursor:pointer;border:none;background:none;font-family:var(--font-body);font-weight:500}
.log-more:hover{background:var(--accent-light)}

/* -- Stats Row (2nd KPI row) -- */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);transition:border-color .2s}
.stat-card:hover{border-color:rgba(0,123,255,.15)}
.stat-card .stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-card .stat-icon svg{width:20px;height:20px}
.stat-card .stat-value{font-family:var(--font-display);font-size:22px;font-weight:700}
.stat-card .stat-label{font-size:12px;color:var(--text-secondary)}

/* -- Plant Table -- */
.tbl tr.plant-row{cursor:pointer}
.tbl tr.plant-row:hover{background:var(--accent-light)}

/* -- View Toggle (Anlagenliste / Karte) -- */
.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:var(--bg)}
.view-toggle-btn{padding:7px 16px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;border:none;background:none;font-family:var(--font-body);transition:all .2s;display:flex;align-items:center;gap:6px;white-space:nowrap}
.view-toggle-btn:hover{color:var(--text)}
.view-toggle-btn.active{background:var(--card);color:var(--accent);box-shadow:var(--shadow)}
.view-toggle-btn svg{width:14px;height:14px}

/* -- Map Container -- */
.map-container{display:none;height:500px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow)}
.map-container.active{display:block}

/* -- Modal -- */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:150;display:flex;align-items:center;justify-content:center}
.pac-container{z-index:200!important}
.modal-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);max-width:480px;width:100%;box-shadow:var(--shadow-lg)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 14px;border-bottom:1px solid var(--border-light)}
.modal-header h3{font-size:15px;font-weight:700;font-family:var(--font-display)}
.modal-header button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;padding:4px}
.modal-body{padding:16px 20px 20px}
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}
.form-input{width:100%;padding:9px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text);font-size:13px;font-family:var(--font-body);box-sizing:border-box}
.form-input:focus{outline:none;border-color:var(--accent)}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:0 20px 18px}

/* -- Verwaltung Section -- */
.verwaltung-section{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card)}
.verwaltung-header{padding:14px 18px;font-weight:600;font-size:14px;color:var(--text);border-bottom:1px solid var(--border-light)}
.verwaltung-body{padding:16px 18px 18px;display:block}
.verwaltung-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.verwaltung-subsection{margin-bottom:16px}
.verwaltung-subsection h4{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:10px}
.member-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border-light)}
.member-row:last-child{border-bottom:none}
.member-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-light);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.member-info{flex:1;min-width:0}
.member-info .mi-email{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.member-info .mi-role{font-size:10px;color:var(--text-muted)}
.device-mgmt-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border-light)}
.device-mgmt-row:last-child{border-bottom:none}
.role-badge{padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600}
.role-badge.owner{background:rgba(245,158,11,.1);color:#d97706}
.role-badge.installer{background:rgba(59,130,246,.1);color:#2563eb}
.role-badge.viewer{background:rgba(107,114,128,.1);color:#6b7280}
.verwaltung-add-row{display:flex;gap:8px;margin-top:10px;align-items:center}
.verwaltung-add-row input,.verwaltung-add-row select{padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-xs);font-size:12px;font-family:var(--font-body);color:var(--text)}
.verwaltung-add-row input{flex:1;min-width:0}
.verwaltung-add-row input:focus,.verwaltung-add-row select:focus{outline:none;border-color:var(--accent)}
.verwaltung-danger{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-light)}

/* -- Tarif Section -- */
/* PV Dachflaechen Section */
.pv-section{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card)}
.pv-header{padding:14px 18px;font-weight:600;font-size:14px;color:var(--text);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.pv-body{padding:16px 18px 18px}
.df-table{width:100%;border-collapse:collapse;font-size:13px}
.df-table th{text-align:left;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;padding:4px 6px;border-bottom:1px solid var(--border-light)}
.df-table td{padding:6px;border-bottom:1px solid var(--border-light)}
.df-table tr:last-child td{border-bottom:none}
.df-table select,.df-table input{font-size:12px;padding:4px 6px;border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg);color:var(--text);width:100%}
.df-table input[type=number]{width:70px;text-align:center}
.df-faktor{font-weight:600;text-align:center;min-width:45px}
.df-remove{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:2px 6px;border-radius:4px}
.df-remove:hover{color:var(--error);background:rgba(239,68,68,.1)}
.df-summary{margin-top:12px;display:flex;gap:20px;align-items:center;font-size:13px;padding:10px 12px;background:var(--bg);border-radius:var(--radius-sm)}
.df-summary-label{color:var(--text-secondary)}
.df-summary-value{font-weight:700;color:var(--text)}
.df-hint{font-size:10px;color:var(--text-muted);font-weight:400}

.forecast-section{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card)}
.forecast-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--border-light);font-weight:600;font-size:14px}
.forecast-body{padding:16px}
.forecast-grid{display:grid;grid-template-columns:1fr;gap:16px}
.forecast-card{border:1px solid var(--border);border-radius:var(--radius-xs);padding:12px}
.forecast-card h4{margin:0 0 8px;font-size:13px;font-weight:600}
.forecast-card canvas{width:100%!important;height:200px!important}
.forecast-footer{margin-top:8px;font-size:11px;color:var(--text-secondary);display:flex;gap:16px;flex-wrap:wrap}

.tariff-section{margin-top:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card)}
.tariff-header{padding:14px 18px;font-weight:600;font-size:14px;color:var(--text);border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}
.tariff-header-actions{display:flex;gap:8px}
.tariff-body{padding:16px 18px 18px}
.tariff-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.tariff-config-card{background:var(--bg);border-radius:var(--radius-sm);padding:14px}
.tariff-config-card h4{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:10px}
.tariff-config-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}
.tariff-config-row .tcr-label{color:var(--text-secondary)}
.tariff-config-row .tcr-value{font-weight:600;color:var(--text)}
.tariff-schedule-card{background:var(--bg);border-radius:var(--radius-sm);padding:14px}
.tariff-schedule-card h4{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:10px}
.schedule-bar-row{display:flex;gap:1px;height:40px;border-radius:var(--radius-xs);overflow:hidden}
.schedule-bar{flex:1;display:flex;align-items:flex-end;justify-content:center;font-size:8px;color:#fff;font-weight:600;position:relative;cursor:default;transition:opacity .15s}
.schedule-bar:hover{opacity:.85}
.schedule-bar .sb-hour{position:absolute;bottom:-16px;font-size:9px;color:var(--text-muted);font-weight:500}
.schedule-bar.preset-auto{background:var(--accent)}
.schedule-bar.preset-charge{background:var(--batt)}
.schedule-bar.preset-standby{background:var(--warning)}
.schedule-legend{display:flex;gap:14px;margin-top:20px}
.schedule-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-secondary)}
.schedule-legend-dot{width:10px;height:10px;border-radius:3px}
.price-chart-container{height:140px;margin-top:12px}
/* SOC Schedule Strip (under SOC forecast chart) */
.soc-schedule-strip{display:flex;height:18px;border-radius:3px;overflow:hidden;margin-top:4px;gap:0}
.soc-schedule-strip .ss-block{flex:1;position:relative;min-width:0}
.soc-schedule-strip .ss-block:hover{opacity:.7}
.soc-schedule-strip .ss-block.ss-auto{background:rgba(59,130,246,0.5)}
.soc-schedule-strip .ss-block.ss-charge{background:#22c55e}
.soc-schedule-strip .ss-block.ss-standby{background:var(--warning)}
.soc-schedule-strip .ss-block.ss-past.ss-auto{background:#d1d5db}
.soc-schedule-strip .ss-block.ss-past.ss-charge{background:#86efac}
.soc-schedule-strip .ss-block.ss-past.ss-standby{background:var(--warning);opacity:.4}
.soc-schedule-legend{display:flex;gap:12px;margin-top:6px;justify-content:flex-end}
.soc-schedule-legend span{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-secondary)}
.soc-schedule-legend .ssl-dot{width:8px;height:8px;border-radius:2px;display:inline-block}
.tariff-no-config{text-align:center;padding:30px 0;color:var(--text-muted);font-size:13px}
.tariff-no-config .tnc-icon{font-size:32px;margin-bottom:8px;opacity:.5}

/* Tariff Config Modal */
.tariff-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.tariff-form-section{margin-top:14px}
.tariff-form-section h4{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid var(--border-light)}

/* ═══════════════════════════════════════════════
   OVERVIEW PAGE — Redesigned Metrics + Plant List
   ═══════════════════════════════════════════════ */

/* -- Hero Metrics -- */
.ov-hero{margin-bottom:20px}
.ov-hero-main{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:12px}
.ov-metric{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;display:flex;align-items:flex-start;gap:14px;position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.ov-metric:hover{border-color:rgba(0,123,255,.18);box-shadow:var(--shadow-md)}
.ov-metric__icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ov-metric__icon svg{width:20px;height:20px}
.ov-metric__body{flex:1;min-width:0}
.ov-metric__label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.ov-metric__value{font-family:var(--font-display);font-size:30px;font-weight:800;line-height:1;color:var(--text);display:inline}
.ov-metric__unit{font-size:13px;font-weight:500;color:var(--text-muted);margin-left:3px}
.ov-metric__spark{position:absolute;bottom:0;right:0;width:80px;height:36px;opacity:.5}
.ov-metric--pv .ov-metric__icon{background:var(--pv-light);color:var(--pv)}
.ov-metric--pv .ov-metric__icon svg{stroke:var(--pv)}
.ov-metric--pv .ov-metric__value{color:var(--pv)}
.ov-metric--daily .ov-metric__icon{background:var(--accent-light);color:var(--accent)}
.ov-metric--daily .ov-metric__icon svg{stroke:var(--accent)}
.ov-metric--monthly .ov-metric__icon{background:rgba(163,60,255,.08);color:var(--brand-violet)}
.ov-metric--monthly .ov-metric__icon svg{stroke:var(--brand-violet)}
.ov-metric--yearly .ov-metric__icon{background:rgba(31,41,51,.06);color:var(--brand-navy)}
.ov-metric--yearly .ov-metric__icon svg{stroke:var(--brand-navy)}

/* -- Hero Sub (Chip bar) -- */
.ov-hero-sub{display:flex;gap:10px;flex-wrap:wrap}
.ov-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--card);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--text-secondary);white-space:nowrap}
.ov-chip__dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.ov-chip__dot--accent{background:var(--accent)}
.ov-chip__dot--online{background:var(--online);box-shadow:0 0 6px rgba(34,197,94,.4)}
.ov-chip__val{font-weight:700;color:var(--text);font-family:var(--font-display)}

/* -- Toolbar -- */
.ov-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.ov-toolbar__left{display:flex;align-items:center;gap:8px;flex-wrap:wrap;flex:1;min-width:0}
.ov-toolbar__right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ov-toolbar__ts{font-size:11px;color:var(--text-muted);white-space:nowrap}

/* -- Mobile Plant Cards (hidden on desktop) -- */
.ov-cards{display:none}
.ov-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,box-shadow .15s}
.ov-card:hover,.ov-card:active{border-color:rgba(0,123,255,.2);box-shadow:var(--shadow-md)}
.ov-card__head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.ov-card__name{font-weight:700;font-size:14px;color:var(--text);line-height:1.2}
.ov-card__addr{font-size:11px;color:var(--text-muted);margin-top:2px}
.ov-card__status{flex-shrink:0;margin-left:10px}
.ov-card__grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:10px}
.ov-card__item{text-align:center}
.ov-card__item-label{display:block;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;font-weight:600;margin-bottom:2px}
.ov-card__item-value{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text)}
.ov-card__item-unit{font-size:11px;color:var(--text-muted);font-weight:400}
.ov-card__foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-top:10px;border-top:1px solid var(--border-light)}
.ov-card__mode{display:inline-flex;align-items:center;gap:4px}
.ov-card__owner{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.ov-card__spark{flex-shrink:0}

/* ═══════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════ */
@media(max-width:1100px){
  .ov-hero-main{grid-template-columns:repeat(2,1fr)}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .energy-live-grid{grid-template-columns:repeat(3,1fr)}
  .station-grid{grid-template-columns:1fr}
  .station-charts{grid-template-columns:1fr}
  .detail-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:900px){
  .detail-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .monitor-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .nav-tabs{overflow-x:auto}
}
@media(max-width:768px){
  .verwaltung-grid{grid-template-columns:1fr}
  .tariff-grid{grid-template-columns:1fr}
  .tariff-form-grid{grid-template-columns:1fr}
  /* Overview: switch table → cards */
  .ov-table-wrap{display:none}
  .ov-cards{display:block}
  .ov-toolbar__left{flex-wrap:wrap}
  .ov-toolbar{flex-direction:column;align-items:stretch}
  .ov-toolbar__right{justify-content:space-between}
  .ov-metric__value{font-size:24px}
  .ov-metric{padding:14px 16px}
}
@media(max-width:640px){
  .navbar{padding:0 12px;height:48px}
  .nav-left{gap:12px}
  .nav-tab{padding:0 10px;font-size:12px}
  .main{padding:12px}
  .ov-hero-main{grid-template-columns:1fr 1fr;gap:10px}
  .ov-metric__icon{width:36px;height:36px;border-radius:9px}
  .ov-metric__icon svg{width:17px;height:17px}
  .ov-metric__label{font-size:10px;margin-bottom:4px}
  .ov-metric__value{font-size:22px}
  .ov-metric__unit{font-size:11px}
  .ov-hero-sub{gap:6px}
  .ov-chip{padding:5px 10px;font-size:11px}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stats-row{grid-template-columns:1fr 1fr;gap:10px}
  .energy-live-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:1fr}
  .toolbar{flex-direction:column;align-items:stretch}
  .search-box input{width:100%}
  .filter-tabs{overflow-x:auto}
  .nav-right{gap:6px}
  .nav-user{display:none}
  .vt-label{display:none}
  .view-toggle-btn{padding:7px 10px}
}
@media(max-width:420px){
  .ov-hero-main{grid-template-columns:1fr 1fr;gap:8px}
  .ov-metric{padding:12px;gap:10px}
  .ov-metric__value{font-size:20px}
  .ov-metric__spark{display:none}
  .ov-card__grid{grid-template-columns:1fr 1fr;gap:8px}
}
