:root{
  --bg: #f4f6f7;
  --surface: #ffffff;
  --surface-2: #eef2f2;
  --border: #dde4e4;
  --text: #122024;
  --text-muted: #5a6b6e;
  --accent: #CC0000;       /* Würth-Rot */
  --accent-2: #A30000;
  --accent-soft: #fbe3e3;
  --warn: #b45309;
  --danger: #b91c1c;
  --good: #15803d;
  --shadow: 0 1px 2px rgba(18,32,36,.05), 0 8px 24px rgba(18,32,36,.06);
  --radius: 14px;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-display: 'Space Grotesk', 'Inter', sans-serif;
}
html.dark{
  --bg: #0b1416;
  --surface: #122023;
  --surface-2: #16292d;
  --border: #1f3a3f;
  --text: #e8f0f0;
  --text-muted: #94aab0;
  --accent: #ff5252;
  --accent-2: #ff7a7a;
  --accent-soft: #3a1414;
  --good: #4ade80;
  --warn: #fbbf24;
  --danger: #f87171;
  --shadow: 0 1px 2px rgba(0,0,0,.3), 0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box;}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;transition:background .3s,color .3s;
}
h1,h2,h3{font-family:var(--font-display);margin:0;letter-spacing:-.01em;}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--surface) 88%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--border);}
.header-inner{max-width:1240px;margin:0 auto;padding:12px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.brand{display:flex;align-items:center;gap:12px;color:var(--accent);}
.brand-text{display:flex;flex-direction:column;line-height:1.1;}
.brand-name{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text);letter-spacing:-.02em;}
.brand-accent{color:var(--accent);}
.brand-sub{font-size:12px;color:var(--text-muted);font-weight:500;}
.logo-mark{flex:none;}
.header-right{display:flex;align-items:center;gap:12px;}
.trust-badge{display:inline-flex;align-items:center;gap:6px;background:var(--accent-soft);color:var(--accent);
  font-weight:600;font-size:13px;padding:7px 13px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);}
.trust-badge svg{color:var(--accent);}
.theme-toggle{background:var(--surface-2);border:1px solid var(--border);color:var(--text);
  width:38px;height:38px;border-radius:10px;display:grid;place-items:center;cursor:pointer;transition:.2s;}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent);}
.icon-moon{display:none;}
html.dark .icon-sun{display:none;}
html.dark .icon-moon{display:block;}

/* ===== Layout ===== */
.container{max-width:1240px;margin:0 auto;padding:24px;}
.customer-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px;margin-bottom:20px;}
.customer-name-input{font-family:var(--font-display);font-size:26px;font-weight:600;color:var(--text);
  background:transparent;border:none;border-bottom:2px dashed var(--border);padding:2px 0;min-width:280px;max-width:100%;}
.customer-name-input:focus{outline:none;border-bottom-color:var(--accent);}
.report-meta{color:var(--text-muted);font-size:13px;margin:0;}

.layout-grid{display:grid;grid-template-columns:330px 1fr;gap:24px;align-items:start;}
.input-column{display:flex;flex-direction:column;gap:20px;position:sticky;top:78px;}

.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow);}
.panel-title{font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border);}

.field{margin-bottom:14px;}
.field-label{display:block;font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.03em;}
.field input[type=number],.field input[type=text],.field select,
.customer-head input{width:100%;padding:9px 11px;border:1px solid var(--border);border-radius:9px;
  background:var(--surface-2);color:var(--text);font-family:var(--font-body);font-size:14.5px;}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.field-hint{display:block;font-size:11.5px;color:var(--text-muted);margin-top:4px;}
.note-box{background:var(--surface-2);border-left:3px solid var(--accent);border-radius:8px;padding:10px 12px;font-size:12.5px;color:var(--text-muted);}
.note-box strong{color:var(--text);}

/* Slider */
.slider-field{margin-bottom:18px;}
.slider-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:6px;}
.slider-head label{font-size:13px;font-weight:600;}
.slider-head output{font-family:var(--font-display);font-weight:600;color:var(--accent);font-size:15px;}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--accent) var(--pct,50%),var(--surface-2) var(--pct,50%));cursor:pointer;}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;
  background:var(--accent);border:3px solid var(--surface);box-shadow:0 1px 4px rgba(0,0,0,.25);cursor:pointer;}
input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--accent);border:3px solid var(--surface);cursor:pointer;}

/* Toggle */
.toggle-field{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;font-size:13px;font-weight:600;}
.switch{position:relative;display:inline-block;width:46px;height:26px;}
.switch input{opacity:0;width:0;height:0;}
.slider-track{position:absolute;inset:0;background:var(--surface-2);border:1px solid var(--border);border-radius:999px;transition:.25s;}
.slider-track:before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:var(--text-muted);border-radius:50%;transition:.25s;}
.switch input:checked + .slider-track{background:var(--accent);border-color:var(--accent);}
.switch input:checked + .slider-track:before{transform:translateX(20px);background:#fff;}

/* ===== Steuerbare Lasten ===== */
.panel-intro{font-size:12.5px;color:var(--text-muted);margin:-4px 0 16px;line-height:1.45;}
.panel-intro strong{color:var(--text);}
.lasten-liste{display:flex;flex-direction:column;gap:14px;}
.last-item{border:1px solid var(--border);border-radius:10px;padding:11px 12px;background:var(--surface-2);transition:.2s;}
.last-item.inaktiv{opacity:.5;}
.last-head{display:flex;align-items:center;gap:10px;margin-bottom:8px;}
.last-check{position:relative;flex:none;width:38px;height:22px;}
.last-check input{opacity:0;width:0;height:0;}
.last-check .lc-track{position:absolute;inset:0;background:var(--surface);border:1px solid var(--border);border-radius:999px;transition:.25s;cursor:pointer;}
.last-check .lc-track:before{content:"";position:absolute;height:15px;width:15px;left:3px;top:2.5px;background:var(--text-muted);border-radius:50%;transition:.25s;}
.last-check input:checked + .lc-track{background:var(--accent);border-color:var(--accent);}
.last-check input:checked + .lc-track:before{transform:translateX(16px);background:#fff;}
.last-name{font-size:13px;font-weight:600;color:var(--text);flex:1;min-width:0;}
.last-kw{font-family:var(--font-display);font-weight:600;color:var(--accent);font-size:14px;flex:none;}
.last-item.inaktiv .last-kw{color:var(--text-muted);}
.last-item input[type=range]{height:5px;}
.lasten-summe{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px;padding-top:13px;border-top:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-muted);}
.lasten-summe strong{font-family:var(--font-display);font-size:17px;color:var(--accent);}

.kpi-peak{grid-column:span 2;}
.kpi-peak .kpi-unit{line-height:1.3;}

/* ===== E-Ladestationen / THG ===== */
.lade-gruppen{display:flex;flex-direction:column;gap:14px;margin-bottom:6px;}
.lade-item{border:1px solid var(--border);border-radius:10px;padding:11px 12px;background:var(--surface-2);transition:.2s;}
.lade-item.inaktiv{opacity:.5;}
.lade-head{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.lade-name{font-size:13px;font-weight:600;color:var(--text);flex:1;min-width:0;}
.lade-status{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--accent);
  background:var(--accent-soft);padding:3px 8px;border-radius:999px;flex:none;}
.lade-status.lade-status-plan{color:var(--warn);background:color-mix(in srgb,var(--warn) 16%,transparent);}
.lade-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.lade-mini{display:flex;flex-direction:column;gap:3px;min-width:0;}
.lade-mini.lade-mini-wide{grid-column:span 2;}
.lade-mini span{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;}
.lade-mini input[type=number]{width:100%;padding:7px 9px;border:1px solid var(--border);border-radius:8px;
  background:var(--surface);color:var(--text);font-family:var(--font-body);font-size:14px;}
.lade-mini input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.lade-calc{margin-top:9px;width:100%;border:1px dashed var(--border);background:transparent;color:var(--text-muted);
  font-family:var(--font-body);font-size:11.5px;font-weight:600;padding:7px 8px;border-radius:8px;cursor:pointer;transition:.2s;}
.lade-calc:hover{border-color:var(--accent);color:var(--accent);}
.thg-plan-toggle{margin-top:16px;margin-bottom:0;}
.thg-note{margin-top:16px;}
.kpi-thg{grid-column:span 2;}

/* ===== Result column ===== */
.result-column{display:flex;flex-direction:column;gap:20px;min-width:0;}
.tabs{display:flex;gap:6px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:5px;flex-wrap:wrap;box-shadow:var(--shadow);}
.tab{flex:1 1 auto;min-width:120px;padding:9px 12px;border:none;background:transparent;color:var(--text-muted);
  font-family:var(--font-body);font-weight:600;font-size:13.5px;border-radius:8px;cursor:pointer;transition:.2s;white-space:nowrap;}
.tab:hover{color:var(--text);}
.tab.active{background:var(--accent);color:#fff;}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:3px;min-width:0;}
.kpi-label{font-size:12px;color:var(--text-muted);font-weight:600;line-height:1.25;}
.kpi-value{font-family:var(--font-display);font-size:26px;font-weight:700;line-height:1.1;letter-spacing:-.02em;word-break:break-word;}
.kpi-unit{font-size:11.5px;color:var(--text-muted);}
.kpi-hero{background:linear-gradient(135deg,var(--accent),var(--accent-2));border-color:transparent;color:#fff;}
.kpi-hero .kpi-label,.kpi-hero .kpi-unit{color:rgba(255,255,255,.85);}
.kpi-hero .kpi-value{color:#fff;}
.kpi-value.pos{color:var(--good);}
.kpi-value.neg{color:var(--danger);}

.recommendation{display:flex;gap:14px;align-items:flex-start;background:var(--surface);border:1px solid var(--border);
  border-left:4px solid var(--accent);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);}
.recommendation.good{border-left-color:var(--good);}
.recommendation.warn{border-left-color:var(--warn);}
.recommendation.bad{border-left-color:var(--danger);}
.rec-icon{font-size:22px;line-height:1;flex:none;}
.recommendation strong{font-family:var(--font-display);font-size:15px;}
.recommendation p{margin:4px 0 0;color:var(--text-muted);font-size:13.5px;}

.chart-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow);min-width:0;}
.chart-title{font-size:15.5px;font-weight:600;}
.chart-sub{font-size:12.5px;color:var(--text-muted);margin:4px 0 12px;}
.chart-box{position:relative;height:300px;}
.chart-box.chart-box-split{height:150px;}
.chart-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.chart-row .chart-box{height:280px;}

/* ===== Footer ===== */
.site-footer{border-top:1px solid var(--border);margin-top:30px;}
.site-footer p{max-width:1240px;margin:0 auto;padding:20px 24px;color:var(--text-muted);font-size:12.5px;text-align:center;}

/* ===== Responsive ===== */
@media (max-width:900px){
  .layout-grid{grid-template-columns:1fr;}
  .input-column{position:static;}
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .chart-row{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .kpi-peak{grid-column:span 2;}
}
@media (max-width:520px){
  .container{padding:16px;}
  .header-inner{padding:10px 16px;flex-wrap:wrap;}
  .brand-sub{display:none;}
  .trust-badge{font-size:12px;padding:6px 10px;}
  .kpi-grid{grid-template-columns:1fr 1fr;}
  .kpi-value{font-size:22px;}
  .customer-name-input{font-size:20px;min-width:0;width:100%;}
  .tab{min-width:0;font-size:12.5px;padding:8px 6px;}
  .chart-box{height:260px;}
}

/* ===== Pro-Freischaltung / Badge ===== */
.pro-badge{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:#fff;font-weight:600;font-size:12.5px;padding:6px 12px;border-radius:999px;}
.pro-unlock{position:relative;display:flex;}
.pro-unlock-btn{background:var(--surface-2);border:1px solid var(--border);color:var(--text);
  font-family:var(--font-body);font-weight:600;font-size:13px;padding:8px 14px;border-radius:10px;cursor:pointer;transition:.2s;}
.pro-unlock-btn:hover{border-color:var(--accent);color:var(--accent);}
.pro-unlock-panel{position:absolute;top:calc(100% + 8px);right:0;width:240px;background:var(--surface);
  border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:14px;display:none;z-index:50;}
.pro-unlock-panel.open{display:block;}
.pro-code-row{display:flex;gap:8px;}
.pro-code-row input{flex:1;min-width:0;padding:8px 10px;border:1px solid var(--border);border-radius:8px;
  background:var(--surface-2);color:var(--text);font-family:var(--font-body);font-size:14px;}
.pro-code-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.pro-code-row button{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:0 14px;font-weight:600;cursor:pointer;}
.pro-code-msg{margin:8px 0 0;font-size:12px;color:var(--text-muted);}
.pro-code-msg.err{color:var(--danger);}

/* ===== Export-Bereich ===== */
.export-section{position:relative;}
.export-head{display:flex;align-items:center;gap:10px;margin-bottom:2px;}
.export-pro-tag{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;
  font-size:11px;font-weight:700;padding:2px 9px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;}
.export-lock-hint{background:var(--surface-2);border-left:3px solid var(--warn);border-radius:8px;
  padding:10px 12px;font-size:12.5px;color:var(--text-muted);margin:12px 0;display:none;}
.export-section.pro-locked{opacity:.92;}
.export-section.pro-locked .export-grid,.export-section.pro-locked .elektriker-form{opacity:.55;filter:grayscale(.3);}
.export-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px;}
.export-card{border:1px solid var(--border);border-radius:12px;padding:16px;background:var(--surface-2);
  display:flex;flex-direction:column;gap:7px;}
.export-card-icon{font-size:22px;}
.export-card h4{font-family:var(--font-display);font-size:15px;margin:0;}
.export-card p{font-size:12.5px;color:var(--text-muted);margin:0;flex:1;line-height:1.45;}
.export-btn{margin-top:6px;background:var(--accent);color:#fff;border:none;border-radius:9px;
  font-family:var(--font-body);font-weight:600;font-size:13.5px;padding:10px 12px;cursor:pointer;transition:.2s;}
.export-btn:hover:not(:disabled){background:var(--accent-2);}
.export-btn:disabled{background:var(--surface);color:var(--text-muted);border:1px solid var(--border);cursor:not-allowed;}
.el-toggle{background:transparent;border:1px dashed var(--border);color:var(--text-muted);border-radius:8px;
  font-family:var(--font-body);font-weight:600;font-size:12px;padding:7px 10px;cursor:pointer;transition:.2s;}
.el-toggle:hover:not(:disabled){border-color:var(--accent);color:var(--accent);}
.el-toggle:disabled{cursor:not-allowed;opacity:.6;}
.bank-fields{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.bank-mini{display:flex;flex-direction:column;gap:3px;}
.bank-mini span{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;}
.bank-mini input{width:100%;padding:7px 8px;border:1px solid var(--border);border-radius:7px;
  background:var(--surface);color:var(--text);font-family:var(--font-body);font-size:13.5px;}
.bank-mini input:focus{outline:none;border-color:var(--accent);}

/* Elektriker-Formular */
.elektriker-form{display:none;margin-top:18px;border-top:1px solid var(--border);padding-top:16px;}
.elektriker-form.open{display:block;}
.ef-title{font-family:var(--font-display);font-size:14px;margin:0 0 12px;}
.ef-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.ef-field{display:flex;flex-direction:column;gap:4px;}
.ef-field.ef-wide{grid-column:span 2;}
.ef-field span{font-size:11.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em;}
.ef-field input,.ef-field textarea,.ef-field select{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;
  background:var(--surface-2);color:var(--text);font-family:var(--font-body);font-size:14px;}
.ef-field input:focus,.ef-field textarea:focus,.ef-field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
.ef-field textarea{resize:vertical;}
.el-foto-preview{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.el-foto-thumb{position:relative;width:90px;height:90px;border-radius:8px;overflow:hidden;border:1px solid var(--border);}
.el-foto-thumb img{width:100%;height:100%;object-fit:cover;}
.el-foto-thumb button{position:absolute;top:3px;right:3px;width:20px;height:20px;border:none;border-radius:50%;
  background:rgba(0,0,0,.6);color:#fff;font-size:14px;line-height:1;cursor:pointer;}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text);
  color:var(--bg);padding:12px 20px;border-radius:10px;font-size:13.5px;font-weight:500;box-shadow:var(--shadow);
  opacity:0;pointer-events:none;transition:.3s;z-index:100;max-width:90vw;text-align:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

@media (max-width:680px){
  .export-grid{grid-template-columns:1fr;}
  .ef-grid{grid-template-columns:1fr;}
  .ef-field.ef-wide{grid-column:span 1;}
  .pro-unlock-panel{right:auto;left:0;}
}

/* ===== News-Laufband (RSS) ===== */
.news-ticker{
  display:flex;align-items:stretch;gap:0;
  background:var(--surface);border-bottom:1px solid var(--border);
  position:sticky;top:57px;z-index:25;overflow:hidden;
}
.news-ticker-label{
  display:flex;align-items:center;gap:6px;
  flex:0 0 auto;padding:8px 14px;
  background:var(--accent);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:12px;
  letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;
}
.news-ticker-viewport{
  flex:1 1 auto;overflow:hidden;position:relative;display:flex;align-items:center;
}
.news-ticker-track{
  display:inline-flex;align-items:center;white-space:nowrap;
  will-change:transform;animation:news-marquee 60s linear infinite;
}
.news-ticker-viewport:hover .news-ticker-track{animation-play-state:paused;}
.news-item{
  display:inline-flex;align-items:center;font-size:13.5px;color:var(--text);
  padding:8px 0;margin-right:34px;text-decoration:none;
}
.news-item:hover{color:var(--accent);}
.news-item .news-dot{
  width:6px;height:6px;border-radius:50%;background:var(--accent);
  margin-right:12px;flex:0 0 auto;
}
.news-item .news-src{color:var(--text-muted);margin-left:8px;font-size:12px;}
@keyframes news-marquee{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
@media (prefers-reduced-motion: reduce){
  .news-ticker-track{animation-duration:140s;}
}
@media (max-width:720px){
  .news-ticker{top:53px;}
  .news-ticker-label{padding:8px 10px;font-size:11px;}
}

/* ====================== LASTGANG-ANALYSE-DASHBOARD ====================== */
.lg-panel{padding:0;overflow:hidden;border-left:4px solid var(--border);}
.lg-panel.lg-rot{border-left-color:var(--danger);}
.lg-panel.lg-gelb{border-left-color:var(--warn);}
.lg-panel.lg-gruen,.lg-panel.lg-ok{border-left-color:var(--good);}

.lg-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;
  gap:10px;background:none;border:0;cursor:pointer;padding:16px 18px;
  font-family:var(--font-display);font-size:16px;font-weight:600;color:var(--text);text-align:left;}
.lg-toggle:hover{background:var(--surface-2);}
.lg-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;}
.lg-toggle-left{display:flex;align-items:center;gap:10px;min-width:0;}
.lg-toggle-title{white-space:nowrap;}
.lg-ne{font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.02em;
  padding:2px 8px;border-radius:6px;white-space:nowrap;
  background:var(--accent-soft);color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);}
.lg-ampel{width:14px;height:14px;border-radius:50%;flex:0 0 auto;background:var(--text-muted);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--text-muted) 25%,transparent);}
.lg-rot .lg-ampel{background:var(--danger);box-shadow:0 0 0 3px color-mix(in srgb,var(--danger) 25%,transparent);}
.lg-gelb .lg-ampel{background:var(--warn);box-shadow:0 0 0 3px color-mix(in srgb,var(--warn) 25%,transparent);}
.lg-gruen .lg-ampel,.lg-ok .lg-ampel{background:var(--good);box-shadow:0 0 0 3px color-mix(in srgb,var(--good) 25%,transparent);}
.lg-badge{font-family:var(--font-body);font-size:12px;font-weight:600;padding:2px 9px;border-radius:999px;
  background:var(--surface-2);color:var(--text-muted);white-space:nowrap;}
.lg-rot .lg-badge{background:color-mix(in srgb,var(--danger) 14%,transparent);color:var(--danger);}
.lg-gelb .lg-badge{background:color-mix(in srgb,var(--warn) 16%,transparent);color:var(--warn);}
.lg-gruen .lg-badge,.lg-ok .lg-badge{background:color-mix(in srgb,var(--good) 14%,transparent);color:var(--good);}
.lg-chevron{flex:0 0 auto;color:var(--text-muted);transition:transform .25s ease;}
.lg-panel.collapsed .lg-chevron{transform:rotate(-90deg);}

.lg-body{padding:0 18px 18px;}
.lg-panel.collapsed .lg-body{display:none;}
.lg-intro{font-size:13px;line-height:1.5;color:var(--text-muted);margin:0 0 14px;}

.lg-pot-summe{display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:12px 14px;border-radius:10px;margin-bottom:14px;
  background:color-mix(in srgb,var(--good) 10%,var(--surface));
  border:1px solid color-mix(in srgb,var(--good) 35%,transparent);}
.lg-pot-summe-label{font-size:13px;color:var(--text-muted);}
.lg-pot-summe strong{font-family:var(--font-display);font-size:18px;color:var(--good);}

.lg-warnungen{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;}
.lg-item{border:1px solid var(--border);border-radius:10px;padding:12px 13px;background:var(--surface);
  border-left-width:3px;}
.lg-item.s-rot{border-left-color:var(--danger);}
.lg-item.s-gelb{border-left-color:var(--warn);}
.lg-item.s-gruen{border-left-color:var(--good);}
.lg-item-head{display:flex;align-items:center;gap:8px;margin-bottom:5px;}
.lg-item-sym{font-size:14px;line-height:1;flex:0 0 auto;}
.lg-item-title{font-weight:600;font-size:13.5px;color:var(--text);}
.lg-item-msg{font-size:12.5px;line-height:1.5;color:var(--text-muted);margin:0;}
.lg-item-pot{margin-top:8px;font-size:12.5px;line-height:1.5;color:var(--text);
  background:var(--surface-2);border-radius:8px;padding:8px 10px;}
.lg-item-pot strong{color:var(--good);}
.lg-jump{margin-top:9px;display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-body);font-size:12.5px;font-weight:600;cursor:pointer;
  background:var(--accent-soft);color:var(--accent);border:0;border-radius:8px;padding:7px 11px;
  transition:background .15s ease;}
.lg-jump:hover{background:color-mix(in srgb,var(--accent) 22%,transparent);}
.lg-jump:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.lg-jump svg{width:13px;height:13px;}

.lg-quelle{font-size:11px;line-height:1.5;color:var(--text-muted);margin:14px 0 0;
  padding-top:12px;border-top:1px solid var(--border);}

/* Slider-Highlight beim Anspringen */
.slider-field.lg-highlight,.field.lg-highlight{animation:lgPulse 1.8s ease;border-radius:10px;}
@keyframes lgPulse{
  0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--accent) 55%,transparent);}
  20%{box-shadow:0 0 0 5px color-mix(in srgb,var(--accent) 28%,transparent);background:var(--accent-soft);}
  100%{box-shadow:0 0 0 0 transparent;background:transparent;}
}
@media (prefers-reduced-motion:reduce){
  .slider-field.lg-highlight,.field.lg-highlight{animation:none;outline:2px solid var(--accent);outline-offset:3px;}
  .lg-chevron{transition:none;}
}

/* =====================================================================
   REITER: BATTERIE ALS WIRTSCHAFTSGUT vs. SPARBUCH
   ===================================================================== */
.sb-panel{margin-top:18px;}
.sb-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.sb-laufzeit-tag{font-family:var(--font-body);font-size:12px;font-weight:700;white-space:nowrap;
  padding:3px 11px;border-radius:999px;background:var(--accent-soft);color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);}
.sb-controls{display:grid;grid-template-columns:1.6fr 1fr;gap:16px 20px;align-items:start;margin:14px 0 6px;}
.sb-controls .field{margin:0;}
.sb-hint{font-size:11px;line-height:1.5;color:var(--text-muted);margin:6px 0 0;}
.sb-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:16px 0 4px;}
.sb-card{border:1px solid var(--border);border-radius:14px;padding:16px 18px;background:var(--surface-2);
  display:flex;flex-direction:column;gap:3px;}
.sb-card-batterie{border-color:color-mix(in srgb,var(--accent) 35%,transparent);
  background:color-mix(in srgb,var(--accent-soft) 60%,var(--surface-2));}
.sb-card-label{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;}
.sb-card-value{font-family:var(--font-head,inherit);font-size:30px;font-weight:800;line-height:1.1;color:var(--text);}
.sb-card-batterie .sb-card-value{color:var(--accent);}
.sb-card-sub{font-size:12px;color:var(--text-muted);}
.sb-card-real{margin-top:9px;padding-top:9px;border-top:1px solid var(--border);
  font-size:13px;color:var(--text-muted);display:flex;justify-content:space-between;gap:8px;align-items:baseline;}
.sb-card-real strong{color:var(--text);font-size:15px;}
.sb-card-batterie .sb-card-real strong{color:var(--good);}
.sb-card-batterie .sb-card-real strong.sb-neg{color:var(--danger);}
.sb-fazit{font-size:13.5px;line-height:1.55;color:var(--text);margin:12px 0 4px;
  padding:11px 14px;border-radius:10px;background:var(--surface-2);border-left:3px solid var(--accent);}
.sb-chart-box{margin-top:14px;height:220px;}
.sb-quelle{font-size:11px;line-height:1.5;color:var(--text-muted);margin:12px 0 0;
  padding-top:12px;border-top:1px solid var(--border);}
@media (max-width:720px){
  .sb-controls{grid-template-columns:1fr;}
  .sb-grid{grid-template-columns:1fr;}
}

/* =====================================================================
   DATEI-UPLOAD (Auto-Modus) – Drag&Drop-Fläche, Ladeindikator, Hinweise
   Nutzt die bestehenden CSS-Variablen (dark/light kompatibel).
   ===================================================================== */
.upload-zone{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;
  text-align:center;margin-bottom:16px;padding:18px 14px;cursor:pointer;
  background:var(--surface-2);border:1.5px dashed var(--border);border-radius:var(--radius);
  color:var(--text-muted);transition:border-color .2s,background .2s,box-shadow .2s;}
.upload-zone:hover{border-color:var(--accent);}
.upload-zone:focus-visible{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);}
/* Aktiv, während eine Datei über die Fläche gezogen wird */
.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-soft);color:var(--text);}
.upload-icon{color:var(--accent);flex:none;}
.upload-text{margin:0;font-size:13.5px;color:var(--text);}
.upload-sub{margin:0;font-size:11.5px;color:var(--text-muted);}
.upload-link{background:none;border:none;padding:0;margin:0;cursor:pointer;
  color:var(--accent);font-family:var(--font-body);font-size:13.5px;font-weight:600;text-decoration:underline;}
.upload-link:hover{opacity:.8;}

/* Statuszeile (Ladeindikator / Erfolg / Fehler) */
.upload-status{display:flex;align-items:center;gap:8px;margin-bottom:12px;
  font-size:12.5px;border-radius:10px;padding:9px 12px;
  background:var(--surface-2);border:1px solid var(--border);color:var(--text);}
.upload-status.is-error{background:color-mix(in srgb,var(--danger) 14%,transparent);
  border-color:var(--danger);color:var(--danger);}
.upload-status.is-ok{background:color-mix(in srgb,var(--good) 14%,transparent);
  border-color:var(--good);color:var(--good);}
/* Kleiner rotierender Ladeindikator (Spinner) */
.upload-spinner{width:14px;height:14px;flex:none;border-radius:50%;
  border:2px solid var(--border);border-top-color:var(--accent);
  animation:upload-spin .7s linear infinite;}
@keyframes upload-spin{to{transform:rotate(360deg);}}

/* Hinweise aus dem Parser ("Bitte Werte prüfen" etc.) */
.upload-hinweise{margin-bottom:16px;font-size:12px;line-height:1.5;
  background:var(--surface-2);border-left:3px solid var(--warn);border-radius:8px;
  padding:10px 12px;color:var(--text-muted);}
.upload-hinweise strong{display:block;margin-bottom:4px;color:var(--text);}
.upload-hinweise ul{margin:0;padding-left:18px;}
.upload-hinweise li{margin:2px 0;}
