/* KAUFAUDIT 2.0 — Design-System (aus mockups/, Marken-Türkis #1799B4, Hell/Dunkel) */
:root{
  --navy:#1e2b4d; --navy-2:#26345c; --accent:#1799b4; --accent-2:#3aa9c2;
  --bg:#f4f1ea; --surface:#ffffff; --surface-2:#faf8f3; --ink:#1e2b4d;
  --muted:#6b7280; --line:#e6e1d6; --line-2:#efeae0;
  --ok:#3f7d58; --warn:#b07b2e; --danger:#a8443b;
  --shadow-sm:0 1px 2px rgba(30,43,77,.05),0 6px 16px -10px rgba(30,43,77,.12);
}
[data-theme="dark"]{
  --navy:#0c1322; --navy-2:#131d33; --accent:#27b4d2; --accent-2:#63d0e8;
  --bg:#0a0f1c; --surface:#111a30; --surface-2:#0e1729; --ink:#f1ede2;
  --muted:#94a0b8; --line:#22304f; --line-2:#1b2742;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4),0 8px 20px -12px rgba(0,0,0,.55);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Manrope',-apple-system,sans-serif;background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.5;transition:background .4s,color .4s}
h1,h2,h3{font-family:'Cormorant Garamond',serif;font-weight:700;letter-spacing:.2px}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:700}
.muted{color:var(--muted)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 18px;
  border-radius:11px;font-size:13.5px;font-weight:700;transition:.2s;border:1px solid transparent}
.btn-accent{background:linear-gradient(135deg,#12849c,var(--accent));color:#fff;box-shadow:var(--shadow-sm)}
.btn-accent:hover{filter:brightness(1.06);transform:translateY(-1px)}
[data-theme="dark"] .btn-accent{color:#04222b;background:linear-gradient(135deg,var(--accent),var(--accent-2))}
.btn-ghost{border-color:var(--line);color:var(--ink);background:var(--surface)}
.btn-ghost:hover{border-color:var(--accent)}
.btn-block{width:100%}

.field{margin-bottom:18px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.03em;margin-bottom:7px}
.field input,.field textarea{width:100%;padding:12px 14px;border-radius:11px;border:1px solid var(--line);
  background:var(--surface-2);color:var(--ink);font-family:inherit;font-size:14px;transition:.2s}
.field textarea{min-height:110px;resize:vertical;line-height:1.55}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:var(--surface);
  box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 16%,transparent)}

.flash{display:flex;gap:11px;padding:13px 15px;border-radius:12px;font-size:13px;margin-bottom:18px}
.flash.info{background:color-mix(in srgb,var(--accent) 9%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}
.flash.warn{background:color-mix(in srgb,var(--warn) 10%,transparent);border:1px solid color-mix(in srgb,var(--warn) 30%,transparent)}
.flash.error{background:color-mix(in srgb,var(--danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--danger) 30%,transparent)}
.flash b{color:var(--warn)}
.flash.error b{color:var(--danger)}

.divider{display:flex;align-items:center;gap:14px;color:var(--muted);font-size:12px;margin:24px 0}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}

/* theme toggle (oben rechts) */
.theme-toggle{position:fixed;top:18px;right:18px;z-index:60;display:flex;align-items:center;gap:8px;
  padding:8px 13px;border-radius:99px;background:var(--surface);border:1px solid var(--line);
  font-size:12.5px;font-weight:700;color:var(--ink);box-shadow:var(--shadow-sm)}

/* ===== Auth (Login / Registrierung) ===== */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:900px){.auth{grid-template-columns:1fr}.auth .poster{display:none}}
.auth .poster{position:relative;color:#fff;padding:56px;display:flex;flex-direction:column;
  justify-content:space-between;overflow:hidden;
  background:radial-gradient(120% 90% at 80% 10%,rgba(23,153,180,.22),transparent 55%),linear-gradient(160deg,var(--navy),#0a1120)}
.auth .poster::after{content:"";position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:44px 44px;mask:radial-gradient(80% 60% at 70% 30%,#000,transparent)}
.auth .poster .biglogo{position:relative;z-index:1;background:#fff;padding:24px 30px;border-radius:20px;
  align-self:flex-start;box-shadow:0 24px 60px -24px rgba(0,0,0,.6)}
.auth .poster .biglogo img{display:block;height:140px}
.auth .poster .lead{position:relative;z-index:1}
.auth .poster .lead h2{font-size:46px;line-height:1.05;margin-bottom:16px;font-weight:600}
.auth .poster .lead h2 em{font-style:italic;color:var(--accent-2)}
.auth .poster .lead p{color:rgba(255,255,255,.7);font-size:15px;max-width:82%}
.auth .poster .marks{position:relative;z-index:1;display:flex;gap:26px;font-size:12px;
  letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.auth .formside{display:grid;place-items:center;padding:48px}
.auth .formbox{width:100%;max-width:380px}
.auth .formbox h1{font-size:30px;margin:6px 0 4px}
.auth .formbox .sub{color:var(--muted);font-size:14px;margin-bottom:26px}
.checkline{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;margin:-2px 0 20px}
.checkline a{color:var(--accent);font-weight:700}

/* ===== App-Shell (geschützter Bereich, vorläufig) ===== */
.wrap{max-width:880px;margin:0 auto;padding:60px 28px}
.card{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px;box-shadow:var(--shadow-sm)}
.brandrow{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}
.brandrow img{height:30px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 11px;
  border-radius:99px;border:1px solid var(--accent);color:var(--accent)}

/* ===== Admin-Shell (Sidebar nach Mockup) ===== */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
@media(max-width:820px){.shell{grid-template-columns:1fr}}
.side{background:var(--surface);border-right:1px solid var(--line);padding:24px 16px;display:flex;flex-direction:column;gap:5px}
.side .brandbox{padding:2px 8px 20px}
.side .brandbox img{height:28px}
.side .sect{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);padding:16px 12px 7px;font-weight:700}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:11px;font-size:14px;font-weight:600;color:var(--muted);transition:.16s}
.nav-item:hover{background:var(--surface-2);color:var(--ink)}
.nav-item.on{background:var(--navy);color:#fff}
.side .foot{margin-top:auto;border-top:1px solid var(--line);padding-top:16px;display:flex;align-items:center;gap:11px}
.avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#04222b;display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}
.main{padding:32px 38px 56px;overflow:auto}
.topline{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:26px;flex-wrap:wrap}
.topline h1{font-size:32px;line-height:1.05}
.topline .sub{color:var(--muted);font-size:14px;margin-top:3px}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
@media(max-width:1000px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:18px;box-shadow:var(--shadow-sm)}
.stat .num{font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;line-height:1}

.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted);font-weight:700;padding:0 16px 12px}
.tbl td{padding:14px 16px;border-top:1px solid var(--line);vertical-align:middle}
.tbl tr:hover td{background:var(--surface-2)}
.who{display:flex;align-items:center;gap:11px}
.who small{display:block;color:var(--muted);font-weight:500;font-size:12px}
.chip.ok{color:var(--ok);border-color:color-mix(in srgb,var(--ok) 35%,transparent);background:color-mix(in srgb,var(--ok) 10%,transparent)}
.chip.wait{color:var(--warn);border-color:color-mix(in srgb,var(--warn) 35%,transparent);background:color-mix(in srgb,var(--warn) 10%,transparent)}
.chip.block{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 35%,transparent);background:color-mix(in srgb,var(--danger) 10%,transparent)}
.btn-sm{padding:7px 13px;font-size:12px;border-radius:9px}
.btn-danger{border:1px solid color-mix(in srgb,var(--danger) 40%,transparent);color:var(--danger);background:var(--surface)}
.btn-danger:hover{background:color-mix(in srgb,var(--danger) 10%,transparent)}
.inline-form{display:inline}

/* Dashboard-Kacheln & Pläne */
.stat .num small{font-size:18px;color:var(--muted)}
.stat .meta{font-size:12.5px;color:var(--muted);margin-top:8px}
.plan-tag{font-size:11px;font-weight:700;letter-spacing:.05em;padding:4px 10px;border-radius:7px;border:1px solid var(--accent);color:var(--accent)}
.plan-tag.pro{background:var(--navy);color:var(--accent-2);border-color:var(--navy)}
.nav-item.soon{cursor:default;justify-content:space-between}
.nav-item.soon:hover{background:none;color:var(--muted)}
.tag-soon{font-size:9px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line);border-radius:99px;padding:2px 7px;color:var(--muted)}
.section-title{display:flex;align-items:center;gap:12px;margin:30px 0 16px}
.section-title h2{font-size:22px}
.section-title .ln{flex:1;height:1px;background:var(--line)}

/* zweispaltige Layouts (Profil, Kunde bearbeiten) */
.cols-2{display:grid;grid-template-columns:1.4fr 1fr;gap:20px;align-items:start}
@media(max-width:1000px){.cols-2{grid-template-columns:1fr}}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.field select{width:100%;padding:12px 14px;border-radius:11px;border:1px solid var(--line);background:var(--surface-2);color:var(--ink);font-family:inherit;font-size:14px}
.field select:focus{outline:none;border-color:var(--accent)}
.setrow{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.setrow:first-of-type{border-top:none}
.tg{width:42px;height:24px;border-radius:99px;background:var(--line);position:relative;flex-shrink:0;border:none;cursor:pointer;transition:.25s}
.tg.on{background:var(--accent)}
.tg::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.25s}
.tg.on::after{left:20px}
.logo-box{height:120px;border:2px dashed var(--line);border-radius:14px;display:grid;place-items:center;color:var(--muted);background:var(--surface-2);overflow:hidden}
.logo-box img{max-height:108px;max-width:90%}
.key-input{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line);border-radius:11px;padding:6px 6px 6px 14px;font-family:ui-monospace,monospace;font-size:13px}
.key-input span{flex:1;letter-spacing:.5px}

/* KI-/Audit-Ladeoverlay (geteilt von _ki_overlay.html und _audit_overlay.html) */
.kiov{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(12,17,30,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.kiov.show{display:flex;animation:kiovIn .25s ease}
@keyframes kiovIn{from{opacity:0}to{opacity:1}}
.kiov-card{width:min(440px,92vw);background:#fff;border-radius:18px;padding:32px 30px;text-align:center;box-shadow:0 30px 80px -20px rgba(0,0,0,.5);font-family:'Manrope',system-ui,sans-serif}
.kiov-title{font-size:17px;font-weight:800;color:#1e2b4d;margin-bottom:22px}
.kiov-path{display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.kiov-node{width:44px;height:44px;border-radius:50%;background:#eef4f6;color:#9bb3bd;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:.35s}
.kiov-node svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.kiov-node.done{background:#1799b4;color:#fff}
.kiov-node.active{background:#1799b4;color:#fff;transform:scale(1.14);box-shadow:0 0 0 5px rgba(23,153,180,.18)}
.kiov-seg{width:30px;height:3px;background:#e1eaed;transition:.35s}
.kiov-seg.done{background:#1799b4}
.kiov-msg{font-size:13.5px;font-weight:600;color:#1e2b4d;min-height:20px;transition:opacity .25s}
.kiov-bar{height:7px;border-radius:99px;background:#eceef3;overflow:hidden;margin:16px 0 12px}
.kiov-fill{height:100%;width:4%;border-radius:99px;background:#1799b4;transition:width .6s cubic-bezier(.22,.61,.36,1)}
.kiov-hint{font-size:11px;color:#8a93a6}
