/* DripBack Demo-Galerie — Brand-Tokens aus DESIGN_SYSTEM.md (2026-06-03) */
:root {
  --bg: #0A0A0B;
  --raised: #121214;
  --elev: #1A1A1D;
  --overlay: rgba(34, 34, 38, 0.5);
  --ink: #F5F5F7;
  --ink-2: #A1A1AA;
  --ink-3: #8A8A92;
  --line: rgba(255, 255, 255, 0.06);
  --accent: #2B6FFF;
  --accent-soft: rgba(43, 111, 255, 0.12);
  --accent-2: #5635A8;
  --brand-gradient: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  --signal: #FFB020;
  --emerald: #22C55E;
  --danger: #EF4444;
  --shadow-md: 0 8px 28px rgba(43, 111, 255, 0.32);
  --shadow-dialog: 0 24px 80px rgba(0, 0, 0, 0.60);
  --font-sans: 'Geist', -apple-system, system-ui, sans-serif;
  --font-mono: 'Geist Mono', ui-monospace, monospace;
  --radius-md: 12px;
  --radius-lg: 14px;
  --radius-pill: 999px;
  --topbar-h: 64px;
  --ease-smooth: cubic-bezier(0.32, 0.72, 0, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-sans);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--accent); color: #fff; padding: 10px 16px; border-radius: 0 0 8px 0;
}
.skip-link:focus { left: 0; }

:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

/* Topbar */
.topbar {
  position: sticky; top: 0; z-index: 20; height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 clamp(16px, 4vw, 40px);
  background: rgba(10, 10, 11, 0.82); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: baseline; gap: 10px; }
.brand-mark { color: var(--accent); font-size: 18px; }
.brand-name { font-weight: 700; font-size: 20px; letter-spacing: -0.02em; }
.brand-dot { color: var(--accent); }
.brand-sub { color: var(--ink-2); font-size: 13px; }
.topbar-meta { color: var(--ink-2); font-size: 13px; font-variant-numeric: tabular-nums; }

/* Hero */
.hero { padding: clamp(40px, 8vh, 88px) clamp(16px, 4vw, 40px) 24px; max-width: 880px; }
.hero h1 { font-size: clamp(28px, 5vw, 46px); line-height: 1.08; letter-spacing: -0.03em; margin: 0 0 16px; }
.hero-sub { color: var(--ink-2); font-size: clamp(15px, 2vw, 18px); max-width: 680px; }

/* Controls */
.controls { padding: 8px clamp(16px, 4vw, 40px) 16px; position: sticky; top: var(--topbar-h); z-index: 15;
  background: linear-gradient(var(--bg) 70%, transparent); }
#search {
  width: 100%; max-width: 560px; padding: 12px 16px; font-size: 15px;
  background: var(--raised); border: 1px solid var(--line); border-radius: var(--radius-pill);
  color: var(--ink); font-family: inherit;
}
#search::placeholder { color: var(--ink-3); }
.chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.chip {
  padding: 6px 14px; font-size: 12px; cursor: pointer;
  background: var(--raised); border: 1px solid var(--line); border-radius: var(--radius-pill);
  color: var(--ink-2); font-family: inherit; transition: all 0.2s var(--ease-smooth);
}
.chip:hover { color: var(--ink); border-color: var(--cat-color, var(--accent)); }
.chip[aria-pressed="true"] {
  background: color-mix(in oklch, var(--cat-color, var(--accent)) 15%, var(--elev));
  color: var(--cat-color, var(--accent));
  border-color: var(--cat-color, var(--accent));
}

/* Grid */
.grid {
  display: grid; gap: 16px; padding: 16px clamp(16px, 4vw, 40px) 64px;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
}
.loading { color: var(--ink-2); grid-column: 1 / -1; }
.sk-card {
  height: 280px; background: var(--raised); border: 1px solid var(--line); border-radius: var(--radius-lg);
  position: relative; overflow: hidden;
}
.sk-card::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.04) 50%, transparent 100%);
  animation: sk-shimmer 1.6s ease-in-out infinite;
}
@keyframes sk-shimmer { to { transform: translateX(100%); } }
@media (prefers-reduced-motion: reduce) {
  .sk-card { background: var(--elev); }
  .sk-card::after { animation: none; }
}
.card {
  display: flex; flex-direction: column; gap: 0; text-align: left;
  overflow: hidden; background: var(--raised); border: 1px solid var(--line);
  border-radius: var(--radius-lg); cursor: pointer; color: var(--ink);
  font-family: inherit; transition: transform 0.2s var(--ease-smooth), border-color 0.2s, box-shadow 0.2s;
}
.card:hover { transform: translateY(-3px); border-color: var(--cat); box-shadow: var(--shadow-md); }
.card-preview {
  display: flex; align-items: center; justify-content: center; padding: 16px;
  height: 120px; background: color-mix(in oklch, var(--cat) 8%, var(--elev));
  border-bottom: 1px solid var(--line);
}
.card-preview svg { width: 48px !important; height: 48px !important; max-width: 48px; opacity: 0.55; transition: opacity 0.2s, transform 0.2s; }
.card:hover .card-preview svg { opacity: 1; transform: scale(1.05); }
.card > :not(.card-preview) { padding-left: 16px; padding-right: 16px; }
.card > :first-of-type:not(.card-preview) { padding-top: 14px; }
.card > :last-of-type { padding-bottom: 14px; }
.card-top { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-bottom: 4px; }
.card-id { font-family: var(--font-mono); font-size: 12px; color: var(--accent); }
.badge {
  font-size: 10px; padding: 2px 8px; border-radius: var(--radius-pill);
  background: color-mix(in oklch, var(--cat) 15%, var(--elev)); color: var(--ink-2); border: 1px solid var(--line);
}
.badge.tier-LIVE { background: color-mix(in oklch, var(--emerald) 15%, var(--elev)); color: var(--emerald); border-color: var(--emerald); }
.card h2 { font-size: 16px; margin: 0; letter-spacing: -0.01em; line-height: 1.35; }
.card-pitch { color: var(--ink-2); font-size: 13px; margin: 0; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card-cat {
  display: inline-block; font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.04em;
  padding: 4px 8px; border-radius: var(--radius-sm);
  background: color-mix(in oklch, var(--cat) 10%, var(--elev));
  color: var(--cat); border: 1px solid var(--line);
  margin-top: 8px;
}
.card-cta { color: var(--accent); font-size: 12px; font-weight: 600; margin-top: 8px; }

/* Modal */
.modal-backdrop {
  position: fixed; inset: 0; z-index: 50; background: var(--overlay);
  backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center;
  padding: 16px; opacity: 0; transition: opacity 100ms ease-out;
}
.modal-backdrop[hidden] { display: none; }
.modal-backdrop.open { opacity: 1; }
.modal {
  position: relative; width: min(820px, 100%); max-height: 92vh; overflow-y: auto;
  background: var(--raised); border: 1px solid var(--line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-dialog); padding: clamp(20px, 4vw, 36px);
  opacity: 0; transform: translateY(16px) scale(0.97);
  transition: opacity 250ms var(--ease-smooth) 50ms, transform 300ms var(--ease-smooth) 50ms;
}
.modal-backdrop.open .modal { opacity: 1; transform: none; }
.before-after-bar {
  display: flex; align-items: center; gap: 12px; padding: 12px 16px; margin: 16px 0;
  background: var(--elev); border: 1px solid var(--line); border-radius: var(--radius-md);
}
.ba-col { display: flex; flex-direction: column; gap: 4px; }
.ba-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--ink-3); }
.ba-before .ba-text { color: var(--danger); font-weight: 500; }
.ba-after .ba-text { color: var(--emerald); font-weight: 500; }
.ba-arrow { color: var(--ink-3); flex-shrink: 0; }

.demo-progress {
  height: 2px; background: var(--line); border-radius: 1px; overflow: hidden; margin: 8px 0;
}
.demo-progress-bar {
  height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-2));
  width: 0%; transition: width 300ms var(--ease-smooth);
}

.modal-close {
  position: absolute; top: 14px; right: 14px; width: 36px; height: 36px;
  background: var(--elev); border: 1px solid var(--line); border-radius: var(--radius-pill);
  color: var(--ink-2); font-size: 16px; cursor: pointer;
}
.modal-close:hover { color: var(--ink); }
.modal-head { display: flex; align-items: center; gap: 12px; margin: 0 40px 8px 0; }
.m-badge { font-family: var(--font-mono); font-size: 13px; color: var(--accent); }
.modal h2 { font-size: 24px; margin: 0; letter-spacing: -0.02em; }
.m-pitch { color: var(--ink-2); font-size: 16px; margin: 0 0 16px; }
.m-steps { color: var(--ink-2); font-size: 14px; margin: 0 0 20px; padding-left: 20px; }
.m-steps li { margin-bottom: 4px; }

.demo-stage { display: grid; grid-template-columns: 1fr auto 1fr; gap: 12px; align-items: stretch; }
.demo-col h3 { font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--ink-3); margin: 0 0 6px; }
.demo-box {
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius-md);
  padding: 14px; font-family: var(--font-mono); font-size: 12.5px; color: var(--ink);
  white-space: pre-wrap; word-break: break-word; min-height: 120px; margin: 0; overflow-x: auto;
}
.demo-box.empty { color: var(--ink-3); }
.demo-arrow { display: flex; align-items: center; color: var(--accent); font-size: 22px; }

.modal-actions { display: flex; align-items: center; gap: 14px; margin-top: 20px; }
.btn-primary {
  padding: 12px 24px; font-size: 15px; font-weight: 600; cursor: pointer;
  background: var(--brand-gradient); color: #fff; border: none; border-radius: var(--radius-pill);
  font-family: inherit; transition: transform 0.15s var(--ease-smooth), opacity 0.2s;
}
.btn-primary:hover { transform: translateY(-1px); }
.btn-primary:disabled { opacity: 0.55; cursor: progress; transform: none; }
.run-status { color: var(--ink-2); font-size: 13px; }
.run-status.done { color: var(--emerald); }
.modal-foot { color: var(--ink-3); font-size: 12px; margin: 18px 0 0; }

/* Footer */
.footer { border-top: 1px solid var(--line); padding: 32px clamp(16px, 4vw, 40px); color: var(--ink-3); font-size: 13px; }
.footer-fine { color: var(--ink-3); opacity: 0.7; margin-top: 4px; }

@media (max-width: 640px) {
  .demo-stage { grid-template-columns: 1fr; }
  .demo-arrow { transform: rotate(90deg); justify-content: center; }
  /* Topbar-Meta + ⌘K-Hint sprengen 390px — Meta ausblenden,
     Buttons nicht schrumpfen lassen (kein h-Overflow) */
  .topbar-meta { display: none; }
  .cmdk-hint, .theme-toggle { flex-shrink: 0; }
  .topbar { gap: 8px; }
}
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; scroll-behavior: auto; }
}

/* ============ Visual renderers (Demo-Mini-Programme) ============ */
.demo-mount { min-height: 220px; margin: 4px 0 8px; }
.mount-hint { color: var(--ink-3); font-size: 14px; padding: 40px 12px; text-align: center;
  border: 1px dashed var(--line); border-radius: var(--radius-md); }
.btn-ghost { margin-left: auto; padding: 8px 14px; font-size: 13px; cursor: pointer;
  background: transparent; color: var(--ink-2); border: 1px solid var(--line);
  border-radius: var(--radius-pill); font-family: inherit; }
.btn-ghost:hover { color: var(--ink); border-color: var(--accent); }
.raw-json { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 12px; }
.raw-json[hidden] { display: none; }

.viz { border: 1px solid var(--line); border-radius: var(--radius-md); overflow: hidden; background: var(--bg); }
.viz-bar { display: flex; align-items: center; gap: 10px; padding: 9px 14px;
  background: var(--elev); border-bottom: 1px solid var(--line); }
.viz-dots { display: inline-flex; gap: 5px; }
.viz-dots i { width: 9px; height: 9px; border-radius: 50%; background: #3a3a40; display: block; }
.viz-dots i:nth-child(1){ background:#ff5f57 } .viz-dots i:nth-child(2){ background:#febc2e } .viz-dots i:nth-child(3){ background:#28c840 }
.viz-title { font-size: 13px; font-weight: 600; color: var(--ink); }
.viz-sub { font-size: 11px; color: var(--ink-3); margin-left: 4px; }
.viz-body { padding: 16px; min-height: 150px; }

.result-card { margin-top: 14px; padding: 14px 16px; border: 1px solid var(--accent);
  background: var(--accent-soft); border-radius: var(--radius-md); opacity: 0; transform: translateY(8px);
  transition: opacity .4s var(--ease-smooth), transform .4s var(--ease-smooth); }
.result-card.in { opacity: 1; transform: none; }
.rc-head { display: flex; align-items: center; gap: 8px; font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: .05em; color: var(--ink); margin-bottom: 8px; }
.rc-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--emerald); box-shadow: 0 0 8px var(--emerald); }
.rc-row { display: flex; justify-content: space-between; gap: 12px; padding: 4px 0; font-size: 14px; border-top: 1px solid var(--line); }
.rc-row:first-of-type { border-top: none; }
.rc-k { color: var(--ink-2); } .rc-v { color: var(--ink); font-weight: 600; text-align: right; }

/* inbox */
.mail-row { display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 10px 12px; border: 1px solid var(--line); border-radius: 10px; margin-bottom: 8px; font-size: 13px; color: var(--ink-2); }
.mail-row.ghost { opacity: .5; }
.mail-row.target { border-color: var(--accent); color: var(--ink); position: relative; }
.mail-row.target.hit { box-shadow: var(--shadow-sm); }
.mail-meta b { display: block; font-size: 14px; } .mail-meta span { font-size: 12px; color: var(--ink-3); }
.mail-chip { font-size: 11px; padding: 3px 10px; border-radius: var(--radius-pill); background: var(--elev); color: var(--ink-3); white-space: nowrap; }
.mail-chip.done { background: var(--brand-gradient); color: #fff; }
.scanbeam { height: 2px; background: linear-gradient(90deg, transparent, var(--accent), transparent); width: 0; margin: 2px 0 8px; }
.scanbeam.run { animation: scan 1s var(--ease-smooth) forwards; }
@keyframes scan { to { width: 100%; } }
.draft { margin-top: 6px; padding: 12px; border-radius: 10px; background: var(--raised); border: 1px solid var(--line);
  opacity: 0; max-height: 0; overflow: hidden; transition: opacity .4s, max-height .5s var(--ease-smooth); }
.draft.in { opacity: 1; max-height: 120px; }
.draft-h { font-size: 12px; color: var(--accent); margin-bottom: 8px; }
.draft-l { height: 8px; background: var(--line); border-radius: 4px; margin: 6px 0; } .draft-l.short { width: 55%; }

/* chat-voice */
.viz-body.chat { display: flex; flex-direction: column; gap: 10px; }
.bubble { max-width: 78%; padding: 10px 14px; border-radius: 14px; font-size: 14px; opacity: 0; transform: translateY(6px); transition: .35s var(--ease-smooth); }
.bubble.in { opacity: 1; transform: none; }
.bubble.user { align-self: flex-end; background: var(--brand-gradient); color: #fff; border-bottom-right-radius: 4px; }
.bubble.agent { align-self: flex-start; background: var(--elev); color: var(--ink); border: 1px solid var(--line); border-bottom-left-radius: 4px; }
.bubble.typing { display: inline-flex; gap: 4px; }
.bubble.typing i { width: 7px; height: 7px; border-radius: 50%; background: var(--ink-3); animation: blink 1s infinite; }
.bubble.typing i:nth-child(2){ animation-delay: .2s } .bubble.typing i:nth-child(3){ animation-delay: .4s }
@keyframes blink { 0%,100%{ opacity:.3 } 50%{ opacity:1 } }

/* gauge-audit */
.viz-body.gauge-wrap { display: grid; grid-template-columns: 130px 1fr; align-items: center; gap: 18px; position: relative; }
.gauge { width: 120px; height: 120px; transform: rotate(-90deg); }
.g-track { fill: none; stroke: var(--line); stroke-width: 10; }
.g-fill { fill: none; stroke: url(#g) ; stroke: var(--accent); stroke-width: 10; stroke-linecap: round; transition: stroke-dashoffset 1.1s var(--ease-smooth); }
.g-num { position: absolute; left: 65px; top: 50%; transform: transl(-50%,-50%); font-size: 30px; font-weight: 700; transform: translateX(-50%) translateY(-50%); }
.findings { list-style: none; margin: 0; padding: 0; }
.findings li { font-size: 13px; color: var(--ink-2); padding: 4px 0 4px 18px; position: relative; opacity: 0; transform: translateX(8px); transition: .3s var(--ease-smooth); }
.findings li.in { opacity: 1; transform: none; }
.findings li::before { content: "✓"; color: var(--emerald); position: absolute; left: 0; }

/* lead-score */
.lead-card { text-align: center; padding: 8px; }
.lead-who { font-size: 15px; font-weight: 600; margin-bottom: 12px; }
.bar { height: 12px; background: var(--elev); border-radius: var(--radius-pill); overflow: hidden; }
.bar span { display: block; height: 100%; background: var(--brand-gradient); width: 0; transition: width 1s var(--ease-smooth); }
.lead-score { font-size: 38px; font-weight: 700; margin: 10px 0; }
.stamp { display: inline-block; padding: 6px 16px; border: 2px solid var(--emerald); color: var(--emerald);
  border-radius: 8px; font-weight: 700; letter-spacing: .08em; opacity: 0; transform: scale(1.4) rotate(-6deg); transition: .3s var(--ease-spring); }
.stamp.in { opacity: 1; transform: rotate(-6deg); }
.stamp.green { border-color: var(--emerald); color: var(--emerald); }

/* doc-sheet / invoice / typing */
.doc-sheet { background: #fff; color: #1a1a1a; border-radius: 8px; padding: 18px; box-shadow: var(--shadow-md); position: relative; }
.doc-h { font-weight: 700; font-size: 15px; margin-bottom: 10px; color: #111; }
.doc-line { height: 9px; background: #e3e3e8; border-radius: 4px; margin: 7px 0; }
.doc-line.w40{width:40%} .doc-line.w60{width:60%} .doc-line.w70{width:70%}
.typed { font-size: 13px; line-height: 1.6; color: #2a2a2a; min-height: 64px; white-space: pre-wrap; }
.sign { margin-top: 10px; font-style: italic; color: #888; font-size: 12px; }
.amount { font-size: 30px; font-weight: 800; color: #0a7f3f; margin: 8px 0; font-variant-numeric: tabular-nums; }
.invoice .stamp { position: absolute; right: 16px; top: 16px; }

/* behoerden-formular */
.form-card { padding: 6px; }
.f-row { display: flex; justify-content: space-between; gap: 10px; padding: 7px 0; border-bottom: 1px solid var(--line); font-size: 13px; }
.f-row span { color: var(--ink-3); } .f-row b { color: var(--ink); }
.f-status { margin: 10px 0; font-size: 13px; color: var(--ink-3); }
.f-status.ok { color: var(--emerald); font-weight: 600; }
.checklist { list-style: none; margin: 0; padding: 0; }
.checklist li { font-size: 13px; color: var(--ink-2); padding: 5px 0 5px 20px; position: relative; opacity: 0; transform: translateX(8px); transition: .3s var(--ease-smooth); }
.checklist li.in { opacity: 1; transform: none; }
.checklist li::before { content: "☑"; color: var(--accent); position: absolute; left: 0; }

/* dispatch-route */
.route { width: 100%; height: 130px; }
.r-path { fill: none; stroke: var(--accent); stroke-width: 3; stroke-linecap: round; transition: stroke-dashoffset 1.4s var(--ease-smooth); }
.r-stop { fill: var(--raised); stroke: var(--ink-2); stroke-width: 2; }
.r-veh { fill: var(--signal); filter: drop-shadow(0 0 6px var(--signal)); }

/* table-report */
.rep-head { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--ink-3); margin-bottom: 8px; }
.rep ul { list-style: none; margin: 0; padding: 0; }
.rep li { font-size: 13px; color: var(--ink); padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px;
  margin-bottom: 6px; background: var(--raised); opacity: 0; transform: translateY(6px); transition: .3s var(--ease-smooth); }
.rep li.in { opacity: 1; transform: none; }

/* pipeline */
.viz-body.pipe { padding: 26px 14px; }
.pipe-track { display: flex; align-items: center; }
.node { display: flex; flex-direction: column; align-items: center; gap: 8px; flex: 0 0 auto; opacity: .4; transition: opacity .3s; }
.node.on { opacity: 1; }
.node .dot { width: 30px; height: 30px; border-radius: 50%; background: var(--elev); border: 2px solid var(--line); transition: .3s var(--ease-spring); }
.node.on .dot { background: var(--brand-gradient); border-color: var(--accent); box-shadow: var(--shadow-sm); transform: scale(1.12); }
.node .lbl { font-size: 11px; color: var(--ink-2); max-width: 88px; text-align: center; }
.conn { flex: 1; height: 3px; background: var(--line); position: relative; }
.conn.on::after { content: ""; position: absolute; inset: 0; background: var(--accent); animation: fillc .3s var(--ease-smooth) forwards; transform-origin: left; }
@keyframes fillc { from { transform: scaleX(0) } to { transform: scaleX(1) } }

@media (max-width: 560px) {
  .raw-json { grid-template-columns: 1fr; }
  .viz-body.gauge-wrap { grid-template-columns: 1fr; justify-items: center; }
}
@media (prefers-reduced-motion: reduce) {
  .scanbeam, .result-card, .bubble, .findings li, .bar span, .stamp, .checklist li, .rep li, .r-path, .g-fill, .conn.on::after,
  .card, .card-preview svg, .card:hover, .chip, .modal-backdrop, .modal, .sk-card, .card-preview svg {
    transition: none !important; animation: none !important; opacity: 1 !important; transform: none !important;
  }
  .bar span { width: var(--w, 100%); }
  .sk-card { background: var(--elev); }
}

/* Modul-Cover: volles Mini-Fenster statt Icon (48px-Kappe gilt nur für Icons) */
.card-preview--cover { padding: 0; height: 150px; }
.card-preview--cover svg.cover { width: 100% !important; height: 100% !important; max-width: none; opacity: 1; display: block; }
.card:hover .card-preview--cover svg.cover { transform: none; }

/* DripBack Demo-Galerie v2 — Referenz-Niveau (lädt NACH styles.css, überschreibt). */

/* --- Light-Mode --- */
:root { --grad-text: linear-gradient(135deg, var(--ink) 0%, var(--accent) 60%, var(--accent-2) 100%); color-scheme: dark; }
[data-theme="light"] {
  --bg: #FAFAFB; --raised: #FFFFFF; --elev: #F1F2F4; --overlay: rgba(20,20,28,0.35);
  --ink: #16171B; --ink-2: #4A4D57; --ink-3: #6B6F7A; --line: rgba(10,10,20,0.10);
  --shadow-md: 0 8px 28px rgba(43,111,255,0.15); --shadow-dialog: 0 24px 80px rgba(0,0,0,0.22);
  color-scheme: light;
}
[data-theme="light"] .topbar { background: rgba(250,250,251,0.85); }
[data-theme="light"] .doc-sheet, [data-theme="light"] .invoice-sheet { background:#fff; color:#1a1a1a; }

/* --- Hero --- */
.hero h1 { background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-stat { display: inline-flex; gap: 6px; align-items: baseline; margin-top: 18px; font-size: 15px; color: var(--ink-2); }
.hero-stat b { font-size: 30px; font-weight: 800; color: var(--ink); font-variant-numeric: tabular-nums; }

/* --- Theme toggle --- */
.theme-toggle { width: 38px; height: 38px; border-radius: var(--radius-pill); background: var(--elev);
  border: 1px solid var(--line); color: var(--ink-2); cursor: pointer; font-size: 15px; }
.theme-toggle:hover { color: var(--ink); border-color: var(--accent); }

/* --- Command palette --- */
.cmdk-hint { font-size: 12px; color: var(--ink-3); border: 1px solid var(--line); border-radius: 6px; padding: 2px 7px; }
.cmdk-back { position: fixed; inset: 0; z-index: 60; background: var(--overlay); backdrop-filter: blur(6px);
  display: flex; align-items: flex-start; justify-content: center; padding-top: 12vh; }
.cmdk-back[hidden] { display: none; }
.cmdk { width: min(560px, 92%); background: var(--raised); border: 1px solid var(--line);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-dialog); overflow: hidden; }
.cmdk input { width: 100%; padding: 16px 18px; font-size: 16px; background: transparent; border: none;
  border-bottom: 1px solid var(--line); color: var(--ink); font-family: inherit; outline: none; }
.cmdk-list { max-height: 50vh; overflow-y: auto; padding: 6px; }
.cmdk-group { font-size: 11px; text-transform: uppercase; letter-spacing: .06em; color: var(--ink-3); padding: 10px 12px 4px; }
.cmdk-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 8px; cursor: pointer; font-size: 14px; }
.cmdk-item .ci-id { font-family: var(--font-mono); font-size: 12px; color: var(--accent); }
.cmdk-item .ci-cat { margin-left: auto; font-size: 12px; color: var(--ink-3); }
.cmdk-item.active, .cmdk-item:hover { background: var(--accent-soft); }

/* --- Card upgrade: thumbnail + category color --- */
.card { position: relative; overflow: hidden; }
.card-thumb { height: 96px; border-radius: 10px; margin: -4px 0 4px; display: flex; align-items: center; justify-content: center;
  background: radial-gradient(120% 120% at 30% 20%, var(--cat, var(--accent-soft)), transparent 70%), var(--elev); border: 1px solid var(--line); }
.card-thumb svg { width: 56px; height: 56px; opacity: .92; }
.card::after { content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  box-shadow: inset 0 0 0 1px transparent; transition: box-shadow .25s; }
.card:hover::after { box-shadow: inset 0 0 0 1px var(--cat, var(--accent)), 0 0 32px -8px var(--cat, var(--accent)); }
.card:hover .card-thumb svg { transform: scale(1.08); transition: transform .3s var(--ease-spring); }
.chip[data-cat] { border-left: 3px solid var(--cat, var(--line)); }

/* --- Skeleton --- */
.sk-card { height: 190px; border-radius: var(--radius-lg); background: var(--raised); border: 1px solid var(--line); overflow: hidden; position: relative; }
.sk-card::after { content: ""; position: absolute; inset: 0; transform: translateX(-100%);
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.06), transparent); animation: shimmer 1.3s infinite; }
@keyframes shimmer { 100% { transform: translateX(100%); } }

/* --- Empty state --- */
.empty-state { grid-column: 1/-1; text-align: center; padding: 60px 20px; color: var(--ink-2); }
.empty-state .es-icon { font-size: 40px; opacity: .5; }

/* --- App frames --- */
.demo-mount { display: flex; flex-direction: column; align-items: stretch; gap: 12px; }
.frame-phone { align-self: center; }
.frame-browser { width: 100%; border-radius: 12px; overflow: hidden; border: 1px solid var(--line); box-shadow: 0 8px 32px rgba(0,0,0,0.4); background: var(--bg); }
.frame-chrome { height: 38px; background: var(--elev); display: flex; align-items: center; gap: 10px; padding: 0 12px; border-bottom: 1px solid var(--line); }
.frame-dots { display: flex; gap: 6px; } .frame-dots i { width: 10px; height: 10px; border-radius: 50%; background: var(--line); }
.frame-dots i:nth-child(1){background:#FF5F57} .frame-dots i:nth-child(2){background:#FFBD2E} .frame-dots i:nth-child(3){background:#28CA41}
.frame-urlbar { flex: 1; background: var(--bg); border-radius: 6px; font-size: 12px; color: var(--ink-3); padding: 5px 10px; font-family: var(--font-mono); }
.frame-act { color: var(--ink-3); }
.frame-phone { width: 240px; border: 2px solid var(--line); border-radius: 30px; overflow: hidden; background: var(--bg); box-shadow: 0 14px 48px rgba(0,0,0,0.5); }
.frame-notch { height: 26px; background: var(--elev); display: flex; align-items: center; justify-content: center; }
.frame-notch::after { content: ""; width: 70px; height: 16px; background: var(--bg); border-radius: 10px; }
.frame-home { height: 22px; display: flex; align-items: center; justify-content: center; background: var(--elev); }
.frame-home::after { content: ""; width: 90px; height: 4px; background: var(--ink-3); border-radius: 2px; opacity: .5; }
.screen-bar { display: flex; align-items: center; gap: 8px; padding: 8px 12px; font-size: 12px; color: var(--ink-2); border-bottom: 1px solid var(--line); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.live-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--emerald); box-shadow: 0 0 0 0 var(--emerald); animation: pulse 1.8s infinite; }
@keyframes pulse { 0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)} 70%{box-shadow:0 0 0 8px rgba(34,197,94,0)} 100%{box-shadow:0 0 0 0 rgba(34,197,94,0)} }
.frame-body { padding: 14px; min-height: 150px; }
.demo-mount .result-card { width: 100%; }

/* --- before/after + progress --- */
.before-after-bar { display: flex; align-items: center; gap: 12px; padding: 12px 16px; border-radius: var(--radius-md); background: var(--elev); border: 1px solid var(--line); margin: 14px 0; }
.before-after-bar[hidden] { display: none; }
.ba-col { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.ba-label { font-size: 10px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink-3); }
.ba-before .ba-text { color: var(--danger); font-size: 13px; } .ba-after .ba-text { color: var(--emerald); font-size: 13px; }
.ba-arrow { color: var(--ink-3); }
.demo-progress { height: 2px; background: var(--line); border-radius: 1px; overflow: hidden; margin: 8px 0; }
.demo-progress-bar { height: 100%; background: var(--brand-gradient); width: 0; transition: width .3s var(--ease-smooth); }

/* --- result reveal --- */
.result-card { opacity: 0; transform: translateY(12px) scale(.98); transition: opacity .4s var(--ease-cinematic), transform .4s var(--ease-smooth); border-left: 3px solid transparent; border-image: linear-gradient(180deg, var(--emerald), var(--accent-2)) 1; }
.result-card.in { opacity: 1; transform: none; }

/* --- shared bits --- */
.ava { width: 30px; height: 30px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 11px; font-weight: 700; color: #fff; flex: 0 0 auto; }
.typing-dot { display: inline-flex; gap: 3px; } .typing-dot span { width: 5px; height: 5px; background: var(--ink-3); border-radius: 50%; animation: tb 1.2s infinite; }
.typing-dot span:nth-child(2){animation-delay:.2s} .typing-dot span:nth-child(3){animation-delay:.4s}
@keyframes tb { 0%,80%,100%{transform:translateY(0)} 40%{transform:translateY(-4px)} }

/* inbox */
.mail-row { display: flex; align-items: center; gap: 10px; padding: 9px 8px; border-radius: 10px; margin-bottom: 6px; }
.mail-row.ghost { opacity: .45; } .mail-row.target.hit { background: var(--accent-soft); }
.mail-meta b { display: block; font-size: 13px; color: var(--ink); } .mail-meta span { font-size: 11px; color: var(--ink-3); }
.mail-chip { margin-left: auto; font-size: 11px; padding: 3px 9px; border-radius: var(--radius-pill); background: var(--elev); color: var(--ink-3); }
.mail-chip.done { background: var(--brand-gradient); color: #fff; }
.draft { margin-top: 6px; padding: 10px; border-radius: 10px; background: var(--elev); opacity: 0; max-height: 0; overflow: hidden; transition: opacity .4s, max-height .5s var(--ease-smooth); }
.draft.in { opacity: 1; max-height: 130px; } .draft-h { font-size: 12px; color: var(--accent); display: flex; gap: 8px; margin-bottom: 8px; }
.sent { color: var(--emerald); opacity: 0; transform: scale(1.4); transition: .3s var(--ease-spring); } .sent.show { opacity: 1; transform: none; }
.draft-l { height: 7px; background: var(--line); border-radius: 4px; margin: 6px 0; } .draft-l.short { width: 55%; }

/* chat */
.chatwin { display: flex; flex-direction: column; gap: 9px; } .wave { display: flex; align-items: flex-end; gap: 2px; height: 26px; margin-bottom: 4px; opacity: .5; }
.wave i { width: 3px; background: var(--accent); border-radius: 2px; } .bubble { max-width: 82%; padding: 9px 13px; border-radius: 14px; font-size: 13px; opacity: 0; transform: translateY(6px); transition: .35s var(--ease-smooth); }
.bubble.in { opacity: 1; transform: none; } .bubble.user { align-self: flex-end; background: var(--brand-gradient); color: #fff; border-bottom-right-radius: 4px; }
.bubble.agent { align-self: flex-start; background: var(--elev); color: var(--ink); border-bottom-left-radius: 4px; }

/* gauge */
.gauge-wrap { text-align: center; } .gauge-box { position: relative; display: inline-block; }
.gauge-svg { width: 200px; height: 116px; } .gauge-svg .track { stroke: var(--line); stroke-width: 9; }
.gauge-svg .fill { stroke-width: 9; stroke-linecap: round; transition: stroke-dashoffset 1.2s var(--ease-cinematic); }
.g-num { position: absolute; left: 0; right: 0; bottom: 4px; font-size: 34px; font-weight: 800; }
.findings { list-style: none; margin: 14px 0 0; padding: 0; text-align: left; }
.findings li { font-size: 13px; color: var(--ink-2); padding: 4px 0 4px 20px; position: relative; opacity: 0; transform: translateX(8px); transition: .3s var(--ease-smooth); }
.findings li.in { opacity: 1; transform: none; } .findings li::before { content: "✓"; color: var(--emerald); position: absolute; left: 0; }

/* lead */
.lead-card { padding: 4px; } .lead-top { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; font-weight: 600; }
.bant { display: grid; grid-template-columns: 78px 1fr; align-items: center; gap: 10px; margin: 7px 0; font-size: 12px; color: var(--ink-2); }
.bant .bar { height: 8px; background: var(--elev); border-radius: var(--radius-pill); overflow: hidden; }
.bant .bar i { display: block; height: 100%; width: 0; background: var(--brand-gradient); transition: width .8s var(--ease-smooth); }
.lead-foot { display: flex; align-items: center; gap: 14px; margin-top: 14px; } .lead-score { font-size: 34px; font-weight: 800; }
.tier-pill { padding: 4px 14px; border-radius: var(--radius-pill); font-weight: 700; font-size: 12px; letter-spacing: .06em; opacity: 0; transform: scale(1.3); transition: .3s var(--ease-spring); }
.tier-pill.in { opacity: 1; transform: none; } .t-heiss { background: rgba(239,68,68,.15); color: var(--danger); } .t-warm { background: rgba(255,176,32,.15); color: var(--signal); } .t-kalt { background: var(--accent-soft); color: var(--accent); }

/* invoice */
.invoice-sheet { background: #fff; color: #1a1a1a; border-radius: 8px; padding: 16px; position: relative; box-shadow: var(--shadow-md); }
.inv-head { display: flex; gap: 14px; margin-bottom: 14px; } .inv-logo { width: 44px; height: 44px; border-radius: 8px; background: var(--brand-gradient); }
.inv-to { flex: 1; display: flex; flex-direction: column; gap: 6px; justify-content: center; } .inv-rows { display: flex; flex-direction: column; gap: 8px; }
.doc-line { height: 8px; background: #e3e3e8; border-radius: 4px; } .w50{width:50%}.w60{width:60%}.w70{width:70%}.w80{width:80%}
.inv-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; border-top: 1px solid #eee; padding-top: 12px; }
.inv-iban { font-family: var(--font-mono); font-size: 11px; color: #888; } .amount { font-size: 26px; font-weight: 800; color: #0a7f3f; font-variant-numeric: tabular-nums; }
.stamp.paid { position: absolute; right: 16px; top: 14px; border: 2px solid var(--emerald); color: var(--emerald); padding: 4px 12px; border-radius: 7px; font-weight: 800; letter-spacing: .08em; opacity: 0; transform: scale(1.5) rotate(-8deg); transition: .35s var(--ease-spring); }
.stamp.paid.in { opacity: 1; transform: rotate(-8deg); }

/* doc */
.docproc .dp-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.dp-badge { font-size: 10px; font-weight: 700; letter-spacing: .08em; padding: 3px 9px; border-radius: var(--radius-pill); background: var(--elev); color: var(--ink-3); }
.dp-badge.done { background: var(--emerald); color: #042; } .dp-prog { flex: 1; height: 4px; background: var(--elev); border-radius: 2px; overflow: hidden; } .dp-prog i { display: block; height: 100%; width: 0; background: var(--brand-gradient); transition: width .15s linear; }
.doc-sheet { background: #fff; color: #1a1a1a; border-radius: 8px; padding: 16px; box-shadow: var(--shadow-md); } .doc-sheet.ruled { background-image: repeating-linear-gradient(#fff 0 27px, #eef 27px 28px); }
.doc-h { font-weight: 700; margin-bottom: 8px; } .typed { font-size: 13px; line-height: 1.65; color: #2a2a2a; min-height: 60px; white-space: pre-wrap; } .sign { font-style: italic; color: #999; font-size: 12px; margin-top: 8px; }

/* form */
.form-card { padding: 4px; } .f-row { display: flex; justify-content: space-between; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 13px; }
.f-row span { color: var(--ink-3); } .f-val { color: var(--ink); font-weight: 600; } .f-row.filled { animation: glow .5s var(--ease-smooth); }
@keyframes glow { 0%{background:var(--accent-soft)} 100%{background:transparent} }
.f-submit { margin: 12px 0; padding: 8px 12px; border-radius: 8px; background: var(--accent-soft); color: var(--emerald); font-weight: 600; font-size: 13px; opacity: 0; transition: .3s; } .f-submit.in { opacity: 1; }
.checklist { list-style: none; margin: 0; padding: 0; } .checklist li { font-size: 13px; color: var(--ink-2); padding: 5px 0 5px 22px; position: relative; opacity: 0; transform: translateX(8px); transition: .3s var(--ease-smooth); }
.checklist li.in { opacity: 1; transform: none; } .checklist li::before { content: "☑"; color: var(--accent); position: absolute; left: 0; }

/* route */
.route { width: 100%; height: 140px; } .r-path { stroke: var(--accent); stroke-width: 3; stroke-linecap: round; transition: stroke-dashoffset 1.4s var(--ease-smooth); }
.r-stop { fill: var(--raised); stroke: var(--ink-3); stroke-width: 2; transition: .2s; } .r-stop.on { fill: var(--accent); stroke: var(--accent); filter: drop-shadow(0 0 6px var(--accent)); }
.r-veh { fill: var(--signal); filter: drop-shadow(0 0 7px var(--signal)); }

/* table */
table.rep { width: 100%; border-collapse: collapse; font-size: 13px; } .rep th { text-align: left; padding: 8px 10px; color: var(--ink-3); font-size: 11px; text-transform: uppercase; letter-spacing: .05em; border-bottom: 1px solid var(--line); }
.rep td { padding: 9px 10px; border-bottom: 1px solid var(--line); color: var(--ink); } .rep tbody tr { opacity: 0; transform: translateY(6px); transition: .3s var(--ease-smooth); } .rep tbody tr.in { opacity: 1; transform: none; }
.rep tbody tr:hover { background: var(--accent-soft); } .rep tbody tr:nth-child(even) { background: rgba(127,127,140,.04); }

/* pipeline */
.pipe .pipe-track { display: flex; align-items: center; padding: 18px 6px; } .node { display: flex; flex-direction: column; align-items: center; gap: 8px; opacity: .4; transition: opacity .3s; }
.node.on, .node.run { opacity: 1; } .node .dot { width: 32px; height: 32px; border-radius: 50%; background: var(--elev); border: 2px solid var(--line); display: flex; align-items: center; justify-content: center; transition: .3s var(--ease-spring); position: relative; }
.node.on .dot { background: var(--brand-gradient); border-color: var(--accent); box-shadow: var(--shadow-sm); } .node .lbl { font-size: 11px; color: var(--ink-2); max-width: 84px; text-align: center; }
.node .spin { width: 14px; height: 14px; border: 2px solid var(--accent); border-top-color: transparent; border-radius: 50%; display: none; } .node.run .spin { display: block; animation: sp .7s linear infinite; }
.node .chk { color: #fff; font-size: 14px; display: none; } .node.on .chk { display: block; } @keyframes sp { to { transform: rotate(360deg); } }
.conn { flex: 1; height: 3px; background: var(--line); position: relative; } .conn.on::after { content: ""; position: absolute; inset: 0; background: var(--accent); transform-origin: left; animation: fillc .3s var(--ease-smooth) forwards; }
@keyframes fillc { from{transform:scaleX(0)} to{transform:scaleX(1)} }

@media (prefers-reduced-motion: reduce) {
  .sk-card::after, .live-dot, .typing-dot span, .node .spin { animation: none !important; }
  .result-card, .bubble, .findings li, .checklist li, .rep tbody tr, .tier-pill, .stamp.paid, .draft, .sent { transition: none !important; opacity: 1 !important; transform: none !important; }
}

/* v3 — echte axe-core- + Lighthouse-Fixes (lädt nach styles2.css). */

/* Kontrast: Accent als KLEINER Text braucht >=4.5:1. --accent (#2B6FFF) auf
   --raised = nur 4.29:1 -> eigener helleren Text-Token. */
:root { --accent-text: #6BA1FF; }            /* auf dunkel: ~6:1 */
[data-theme="light"] { --accent-text: #1B5BD0; } /* auf hell: dunkler */
.m-badge, .card-id, .card-cta, .cmdk-item .ci-id, .draft-h, .dp-badge:not(.done),
.frame-urlbar { color: var(--accent-text) !important; }

/* ba-label (winziges uppercase) im Light-Mode war 4.48:1 -> --ink-2 (dunkler). */
.ba-label { color: var(--ink-2) !important; }

/* Emerald/Danger/Signal als TEXT: auf hell zu blass (2.0-3.4:1) -> dunklere
   Text-Token nur fürs Light-Theme; dunkel bleibt kräftig. */
:root { --emerald-text: #22C55E; --danger-text: #EF4444; --signal-text: #FFB020; }
[data-theme="light"] { --emerald-text: #066B30; --danger-text: #B01818; --signal-text: #875400; }
.ba-after .ba-text, .sent, .f-status.ok, .f-submit, .run-status.done, .rc-head { color: var(--emerald-text) !important; }
.findings li::before, .checklist li::before { color: var(--emerald-text); }
.ba-before .ba-text, .t-heiss { color: var(--danger-text) !important; }
.t-warm { color: var(--signal-text) !important; }
.t-kalt { color: var(--accent-text) !important; }

/* "Papier"-Flächen (Rechnung/Dokument) sind IMMER weiss -> feste dunkle Farben,
   theme-unabhängig (sonst emerald/grau zu blass auf #fff). */
.inv-iban, .sign { color: #6B6B6B !important; }
.stamp.paid, .stamp.green { color: #097A3A !important; border-color: #097A3A !important; }
.amount { color: #0A6B34 !important; }

/* Lighthouse-Perf/LCP: 103 Karten -> offscreen-Rendering überspringen. */
.card { content-visibility: auto; contain-intrinsic-size: auto 200px; }

/* Hero-Gradient-Text: Fallback-Farbe, falls background-clip nicht greift (kein
   unsichtbarer LCP-Text). */
@supports not ((-webkit-background-clip: text) or (background-clip: text)) {
  .hero h1 { color: var(--ink); -webkit-text-fill-color: currentColor; }
}

/* CLS: Layout-Platz reservieren, damit Skeleton->Karten + Chips-Erscheinen + Meta
   keinen Versatz erzeugen (Lighthouse CLS war 0,133 -> Ziel <=0,1). */
.controls { min-height: 118px; }
.chips { min-height: 34px; }
#katalog { min-height: 72vh; }
.sk-card { height: 210px; }
.hero-stat { min-height: 36px; }
.topbar-meta { display: inline-block; min-width: 190px; text-align: right; }
/* Mobile: Meta-Zeile weg — überschreibt die inline-block-Regel oben,
   sonst 190px-min-width = h-Overflow @390 (Bundle-Konkat-Reihenfolge) */
@media (max-width: 640px) { .topbar-meta { display: none; } }

/* Mail-Absender-Zeile auf hervorgehobener (.target.hit) Zeile: ink-3 war 4.12:1
   auf accent-soft-light -> ink-2 (dunkler). */
.mail-meta span { color: var(--ink-2) !important; }

/* Clip-Fixes (Judge R1): Mail-Chip/Absender im Phone-Frame nicht ueberlaufen. */
.mail-chip { max-width: 46%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; flex: 0 1 auto; }
.mail-meta { min-width: 0; }
.mail-meta b, .mail-meta span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: block; }
.rc-v { overflow: hidden; text-overflow: ellipsis; max-width: 60%; }

/* Pipeline-Layout (Judge R3): Icons auf einer Baseline, Labels 2-zeilig geklammert
   (keine schiefen Icons / abgeschnittenen "Dis..."-Labels), Konnektoren auf Icon-Hoehe. */
.pipe .pipe-track { align-items: flex-start; }
.pipe .node { justify-content: flex-start; }
.pipe .node .lbl { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.7em; line-height: 1.3; max-width: 86px; }
.pipe .conn { margin-top: 15px; align-self: flex-start; }
