:root {
  --bg:#f7f6f2;--surface:#fff;--surface2:#f0efe9;
  --border:rgba(0,0,0,.10);--border-s:rgba(0,0,0,.18);
  --text:#1a1a18;--muted:#6b6a64;--hint:#9b9a93;
  --green-bg:#eaf3de;--green-b:#b0d47a;--green-t:#2d5a0e;--green-d:#3b6d11;
  --red-bg:#fcebeb;--red-b:#f0a0a0;--red-t:#7a1f1f;
  --amber-bg:#faeeda;--amber-b:#e8b84b;--amber-t:#6b3a08;
  --blue-bg:#e6f1fb;--blue-b:#85b7eb;--blue-t:#0c447c;
  --pdf-bg:#f3edfb;--pdf-b:#c4a8e8;--pdf-t:#4a1d8a;
  --accent:#185fa5;--accent2:#0f4880;
  --r:10px;--rl:14px;
  --shadow:0 1px 3px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);
}
@media(prefers-color-scheme:dark){:root{
  --bg:#181815;--surface:#242420;--surface2:#2e2e28;
  --border:rgba(255,255,255,.10);--border-s:rgba(255,255,255,.18);
  --text:#e8e6de;--muted:#9b9a93;--hint:#6b6a64;
  --green-bg:#1a2e0a;--green-b:#3b6d11;--green-t:#a8d870;--green-d:#c0dd97;
  --red-bg:#2a0f0f;--red-b:#792020;--red-t:#f09595;
  --amber-bg:#2a1a05;--amber-b:#854f0b;--amber-t:#fac775;
  --blue-bg:#082040;--blue-b:#185fa5;--blue-t:#85b7eb;
  --pdf-bg:#1e1030;--pdf-b:#6b3db5;--pdf-t:#c4a8e8;
  --accent:#378add;--accent2:#5ba3e8;
  --shadow:0 1px 4px rgba(0,0,0,.3);
}}
*{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-overlay{position:fixed;inset:0;background:var(--bg);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:32px 28px;width:100%;max-width:380px;box-shadow:0 8px 40px rgba(0,0,0,.12)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.login-logo img{height:36px;width:auto}
.login-logo-title{font-size:15px;font-weight:600}
.login-logo-sub{font-size:11px;color:var(--muted);margin-top:1px}
.login-title{font-size:18px;font-weight:700;margin-bottom:6px}
.login-sub{font-size:13px;color:var(--muted);margin-bottom:20px}
.login-field{margin-bottom:14px}
.login-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);display:block;margin-bottom:5px}
.login-input{width:100%;padding:10px 12px;font-size:14px;font-family:inherit;background:var(--surface2);border:1px solid var(--border-s);border-radius:var(--r);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(24,95,165,.12)}
.login-btn{width:100%;padding:11px;font-size:14px;font-weight:600;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:var(--r);cursor:pointer;transition:background .15s;margin-top:4px}
.login-btn:hover{background:var(--accent2)}
.login-error{font-size:12px;color:var(--red-t);background:var(--red-bg);border:1px solid var(--red-b);border-radius:8px;padding:8px 12px;margin-bottom:12px;display:none}
.login-error.show{display:block}
.login-success{font-size:12px;color:var(--green-t);background:var(--green-bg);border:1px solid var(--green-b);border-radius:8px;padding:8px 12px;margin-bottom:12px;display:none}
.login-success.show{display:block}
.login-divider{border:none;border-top:1px solid var(--border);margin:18px 0}
.login-link{font-size:12px;color:var(--accent);cursor:pointer;text-decoration:underline;text-decoration-style:dotted;background:none;border:none;font-family:inherit;padding:0}
.login-link:hover{color:var(--accent2)}
.reg-back{font-size:12px;color:var(--muted);cursor:pointer;background:none;border:none;font-family:inherit;padding:0;text-decoration:underline;text-decoration-style:dotted}

/* ── UPDATE BANNER ───────────────────────────────────────────────────────────── */
.update-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--accent);color:white;padding:12px 20px;border-radius:12px;font-size:13px;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.25);z-index:9999;display:flex;align-items:center;gap:12px;white-space:nowrap;animation:slideUp .3s ease}
@keyframes slideUp{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.update-banner button{background:white;color:var(--accent);border:none;border-radius:7px;padding:5px 12px;font-size:12px;font-weight:700;cursor:pointer}
.update-banner .close-btn{background:transparent;color:white;border:none;font-size:18px;cursor:pointer;padding:0 4px;line-height:1}

/* ── HEADER ──────────────────────────────────────────────────────────────────── */
.hdr{background:var(--surface);border-bottom:1px solid var(--border);padding:10px 20px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}
.hdr-logo img{height:38px;width:auto;display:block}
.hdr-divider{width:1px;height:32px;background:var(--border-s);flex-shrink:0}
.hdr-title{font-size:15px;font-weight:600;letter-spacing:-.02em}
.hdr-sub{font-size:11px;color:var(--muted);margin-top:1px}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.standort-badge{font-size:11px;padding:3px 10px;border-radius:99px;background:var(--blue-bg);color:var(--blue-t);border:1px solid var(--blue-b);font-weight:500}
.user-badge{font-size:11px;padding:3px 10px;border-radius:99px;background:var(--surface2);color:var(--muted);border:1px solid var(--border)}
.logout-btn{font-size:12px;padding:4px 12px;border-radius:99px;background:transparent;color:var(--muted);border:1px solid var(--border);cursor:pointer;font-family:inherit;transition:all .15s}
.logout-btn:hover{background:var(--red-bg);color:var(--red-t);border-color:var(--red-b)}

.main{max-width:920px;margin:0 auto;padding:20px 16px 48px}

/* ── STANDORT ────────────────────────────────────────────────────────────────── */
.standort-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:20px;box-shadow:var(--shadow);margin-bottom:18px}
.section-title{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px}
.standort-grid{display:flex;flex-direction:column;gap:8px}
.firma-card{background:var(--surface);border:1.5px solid var(--border-s);border-radius:var(--r);overflow:hidden;transition:box-shadow .15s}
.firma-card.open{box-shadow:var(--shadow)}
.firma-header{display:flex;align-items:center;gap:12px;padding:13px 16px;cursor:pointer;user-select:none;transition:background .15s}
.firma-header:hover{background:var(--surface2)}
.firma-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.firma-name{font-size:14px;font-weight:600;color:var(--text);flex:1}
.firma-count{font-size:11px;color:var(--muted);margin-right:8px}
.firma-chevron{font-size:14px;color:var(--hint);transition:transform .2s;flex-shrink:0}
.firma-card.open .firma-chevron{transform:rotate(180deg)}
.filial-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:7px;padding:12px 16px;background:var(--surface2);border-top:1px solid var(--border);animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.scard{background:var(--surface);border:1.5px solid var(--border-s);border-radius:var(--r);padding:10px 12px;cursor:pointer;transition:all .15s;text-align:center}
.scard:hover{border-color:var(--accent);background:var(--blue-bg)}
.scard.active{border-color:var(--accent);background:var(--blue-bg);box-shadow:0 0 0 3px rgba(24,95,165,.12)}
.scard-id{font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em}
.scard-ik{font-size:10px;color:var(--hint);margin-top:2px;font-family:monospace}
.scard.active .scard-id{color:var(--blue-t)}

/* ── SEARCH ──────────────────────────────────────────────────────────────────── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:18px;box-shadow:var(--shadow);margin-bottom:18px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
@media(max-width:540px){.grid2{grid-template-columns:1fr}}
.flabel{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px;display:block}
.sw{position:relative}
.sw input{width:100%;padding:9px 11px 9px 34px;font-size:13px;font-family:inherit;background:var(--surface2);border:1px solid var(--border-s);border-radius:var(--r);color:var(--text);outline:none;transition:border-color .15s,box-shadow .15s}
.sw input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(24,95,165,.12)}
.sw-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--hint);pointer-events:none}
.sw-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--hint);font-size:16px;line-height:1;padding:2px 4px;border-radius:4px;transition:color .1s}
.sw-clear:hover{color:var(--text)}
.btn-check{width:100%;padding:10px;font-size:14px;font-weight:600;font-family:inherit;background:var(--accent);color:#fff;border:none;border-radius:var(--r);cursor:pointer;transition:background .15s,transform .1s;height:38px}
.btn-check:hover{background:var(--accent2)}
.btn-check:active{transform:scale(.98)}
.btn-check:disabled{background:var(--surface2);color:var(--hint);cursor:not-allowed;transform:none}

/* ── DROPDOWN ────────────────────────────────────────────────────────────────── */
.dd{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border-s);border-radius:var(--r);box-shadow:0 8px 32px rgba(0,0,0,.12);z-index:300;max-height:280px;overflow-y:auto}
.ddg{border-bottom:0.5px solid var(--border)}
.ddg:last-child{border-bottom:none}
.ddg-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--hint);padding:6px 12px 2px;background:var(--surface2)}
.ddi{padding:8px 12px;font-size:13px;cursor:pointer;transition:background .1s;border-bottom:0.5px solid var(--border)}
.ddi:last-child{border-bottom:none}
.ddi:hover{background:var(--surface2)}
.ddi-name{font-weight:500}
.ddi-sub{font-size:11px;color:var(--hint);margin-top:1px}
.dd-empty{padding:14px 12px;font-size:13px;color:var(--muted);text-align:center}

/* ── RESULT ──────────────────────────────────────────────────────────────────── */
.result{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);overflow:hidden;box-shadow:var(--shadow);animation:slideIn .2s ease}
@keyframes slideIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.rh{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
.rh.ok{background:var(--green-bg);border-bottom-color:var(--green-b)}
.rh.err{background:var(--red-bg);border-bottom-color:var(--red-b)}
.rdot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.rdot.ok{background:var(--green-d)}
.rdot.err{background:#c03030}
.rh-text .title{font-size:14px;font-weight:600}
.rh-text .title.ok{color:var(--green-t)}
.rh-text .title.err{color:var(--red-t)}
.rh-text .sub{font-size:12px;color:var(--muted);margin-top:2px}
.info-row{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border)}
@media(max-width:500px){.info-row{grid-template-columns:1fr 1fr}}
.ic{padding:12px 18px;border-right:1px solid var(--border)}
.ic:last-child{border-right:none}
.ic-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--hint);margin-bottom:3px}
.ic-val{font-size:14px;font-weight:600}
.ic-val.ok{color:var(--green-d)}
.ic-val.neutral{color:var(--text)}
.ic-val.muted{color:var(--muted);font-weight:400;font-size:13px}
.ic-val.big{font-size:22px;font-weight:700;letter-spacing:-.02em}
.kv-ok{color:var(--green-d)}
.kv-warn{color:#b87010}
.sec{padding:12px 18px;border-bottom:1px solid var(--border)}
.hints-sec{padding:12px 18px;border-bottom:1px solid var(--border)}
.hints-block{border-radius:8px;overflow:hidden;border:1px solid var(--border-s)}
.hint-line{font-size:12px;padding:6px 12px;background:var(--blue-bg);color:var(--blue-t);border-bottom:0.5px solid var(--blue-b);word-break:break-word;white-space:normal;line-height:1.5}
.hint-line:last-child{border-bottom:none}
.hint-line.warn{background:var(--amber-bg);color:var(--amber-t);border-bottom-color:var(--amber-b)}

/* ── ANSPRUCHSMENGE (Höchstmenge / Anspruchshäufigkeit) ─────────────────────── */
.anspruch-box{padding:14px 18px;border-bottom:1px solid var(--amber-b);background:var(--amber-bg)}
.anspruch-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:4px}
.anspruch-menge{font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--amber-t)}
.anspruch-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:3px 9px;border-radius:99px;background:var(--amber-t);color:var(--amber-bg);white-space:nowrap}
.anspruch-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:8px}
.anspruch-text{font-size:12.5px;color:var(--amber-t);line-height:1.5}
.anspruch-quelle{font-size:11px;color:var(--muted);margin-top:6px}
.anspruch-check{font-size:12.5px;font-weight:600;color:var(--amber-t);margin-top:10px;padding-top:10px;border-top:1px solid var(--amber-b)}
.anspruch-regel .anspruch-label{margin-bottom:4px}
.anspruch-trenner{border-top:1px dashed var(--amber-b);margin:10px 0}

/* ── KAV-SCHWELLENWERT (Kostenübernahmeantrag ab bestimmtem Preis) ─────────── */
.kav-box{padding:14px 18px;border-bottom:1px solid var(--red-b);background:var(--red-bg)}
.kav-title{font-size:12.5px;font-weight:700;color:var(--red-t);margin-bottom:4px}
.kav-text{font-size:12.5px;color:var(--red-t);line-height:1.5}
.kav-hinweis{font-size:12.5px;color:var(--red-t);margin-top:6px;padding-top:6px;border-top:1px solid var(--red-b)}

/* ── ZUZAHLUNG ───────────────────────────────────────────────────────────────── */
.zahlung-sec{padding:16px 18px;border-bottom:1px solid var(--border);background:var(--surface2)}
.zahlung-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px}
.zahlung-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.zahlung-card{background:var(--surface);border:1px solid var(--border-s);border-radius:var(--r);padding:10px 14px}
.zahlung-card.amber{border-color:var(--amber-b)}
.zahlung-card.grau{border-color:var(--border);opacity:.5}
.zahlung-card-label{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.zahlung-card-val{font-size:22px;font-weight:700;color:var(--accent)}
.zahlung-card-val.amber{color:#b87010}
.zahlung-card-val.grau{color:var(--hint)}
.zahlung-card-sub{font-size:11px;color:var(--muted);margin-top:2px}
.total-box{background:var(--green-d);border-radius:var(--r);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.total-label{font-size:13px;font-weight:600;color:rgba(255,255,255,.85)}
.total-val{font-size:26px;font-weight:700;color:white}
.befreiung-row{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface2);border-radius:8px;cursor:pointer;user-select:none}
.toggle-sw{width:36px;height:20px;background:var(--border-s);border-radius:99px;position:relative;transition:background .2s;flex-shrink:0}
.toggle-sw.on{background:var(--green-d)}
.toggle-sw::after{content:'';position:absolute;width:16px;height:16px;background:white;border-radius:50%;top:2px;left:2px;transition:left .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-sw.on::after{left:18px}
.befreiung-txt{font-size:12px;color:var(--muted)}

/* ── GERÄTE ──────────────────────────────────────────────────────────────────── */
.geraet-sec{padding:14px 18px;border-bottom:1px solid var(--border)}
.geraet-list{display:flex;flex-direction:column;gap:7px}
.geraet-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--surface2);border:1.5px solid var(--border-s);border-radius:var(--r);cursor:pointer;transition:all .15s}
.geraet-item:hover{border-color:var(--accent);background:var(--blue-bg)}
.geraet-item.selected{border-color:var(--accent);background:var(--blue-bg);box-shadow:0 0 0 3px rgba(24,95,165,.10)}
.geraet-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border-s);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s}
.geraet-item.selected .geraet-radio{border-color:var(--accent);background:var(--accent)}
.geraet-item.selected .geraet-radio::after{content:'';width:6px;height:6px;border-radius:50%;background:white}
.geraet-info{flex:1;min-width:0}
.geraet-name{font-size:13px;font-weight:600;color:var(--text)}
.geraet-preis{font-size:12px;color:var(--muted);margin-top:1px}
.geraet-badges{display:flex;gap:5px;margin-top:4px;flex-wrap:wrap}
.gbadge{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:500}
.gbadge.gruen{background:var(--green-bg);color:var(--green-d);border:1px solid var(--green-b)}
.gbadge.amber{background:var(--amber-bg);color:var(--amber-t);border:1px solid var(--amber-b)}
.geraet-sum{text-align:right;flex-shrink:0}
.geraet-sum-label{font-size:10px;color:var(--hint);text-transform:uppercase;letter-spacing:.04em}
.geraet-sum-val{font-size:15px;font-weight:700;color:var(--accent)}
.modell-badge{display:inline-flex;align-items:center;gap:6px;background:var(--blue-bg);border:1px solid var(--blue-b);color:var(--blue-t);font-size:12px;font-weight:600;padding:4px 12px;border-radius:99px}
.rechenweg{padding:10px 18px;border-bottom:1px solid var(--border);background:var(--surface2)}
.rw-row{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);padding:2px 0}
.rw-row.total-row{font-size:13px;font-weight:600;color:var(--text);border-top:1px solid var(--border);margin-top:4px;padding-top:5px}
.rw-row span:last-child{font-family:monospace}
.sec-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--hint);margin-bottom:7px}
.hmv-text{font-size:12px;color:var(--muted);font-family:monospace;background:var(--surface2);padding:6px 10px;border-radius:6px;line-height:1.6}
.legs-badge{display:inline-block;font-family:monospace;font-size:13px;font-weight:600;background:var(--pdf-bg);color:var(--pdf-t);border:1px solid var(--pdf-b);padding:4px 12px;border-radius:6px;margin-top:4px}
.vertrag-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;margin-top:6px;font-size:13px;color:var(--muted)}
.pg-sec{padding:12px 18px}
.pg-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:7px}
.pgpill{font-size:12px;padding:4px 10px;border-radius:99px;background:var(--surface2);color:var(--muted);border:1px solid var(--border);cursor:pointer;transition:all .1s}
.pgpill:hover{background:var(--blue-bg);color:var(--blue-t);border-color:var(--blue-b)}
.pgpill.current{background:var(--green-bg);color:var(--green-t);border-color:var(--green-b);font-weight:600;cursor:default}
.nv-body{padding:14px 18px}
.nv-body p{font-size:13px;color:var(--muted);margin-bottom:10px}
.opt{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:9px 13px;margin-bottom:7px}
.opt:last-child{margin-bottom:0}
.opt-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--hint);margin-bottom:2px}
.opt-text{font-size:13px}
.idle{text-align:center;padding:36px 20px;color:var(--hint);font-size:14px}
.idle-icon{width:44px;height:44px;background:var(--surface2);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.stats{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;margin-bottom:0}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:99px;padding:4px 12px;font-size:12px;color:var(--muted)}
.stat strong{color:var(--text);font-weight:600}
.steps-bar{display:flex;align-items:center;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.step-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--hint)}
.step-item.active{color:var(--accent);font-weight:600}
.step-item.done{color:var(--green-d)}
.step-num{width:20px;height:20px;border-radius:50%;border:1.5px solid currentColor;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.step-arrow{color:var(--hint);font-size:14px}
