/* ============================================================
   Kontli — Landingpage. Warm editorial / Schweizer Handwerk.
   Markenpalette aus der App (OKLCH Terracotta / Salbei / Sand).
   ============================================================ */

:root {
  --sand:       oklch(96.5% 0.012 75);
  --sand-deep:  oklch(92.5% 0.018 70);
  --surface:    oklch(99.2% 0.006 85);
  --cream:      oklch(98% 0.01 80);
  --ink:        oklch(26% 0.022 50);
  --ink-soft:   oklch(46% 0.02 55);
  --line:       oklch(88% 0.015 72);
  --clay:       oklch(60% 0.13 40);
  --clay-deep:  oklch(52% 0.14 38);
  --clay-soft:  oklch(60% 0.13 40 / 0.12);
  --sage:       oklch(54% 0.08 158);
  --sage-deep:  oklch(44% 0.085 158);
  --night:      oklch(26% 0.03 50);
  --night-2:    oklch(22% 0.03 48);
  --gold:       oklch(76% 0.12 75);

  --font:      "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-disp: "Iowan Old Style", "Palatino Linotype", Palatino, "Hoefler Text", Georgia, serif;

  --text-hero: clamp(2.4rem, 1.4rem + 4.4vw, 5rem);
  --text-h2:   clamp(1.8rem, 1.2rem + 2.4vw, 3rem);
  --text-h3:   clamp(1.25rem, 1rem + 0.8vw, 1.6rem);
  --text-lead: clamp(1.1rem, 1rem + 0.5vw, 1.35rem);

  --maxw:   1140px;
  --maxw-narrow: 760px;
  --radius: 20px;
  --radius-sm: 12px;
  --space-section: clamp(2.5rem, 2rem + 3vw, 5rem);
  --shadow:    0 2px 6px oklch(40% 0.03 50 / 0.06), 0 18px 50px oklch(40% 0.03 50 / 0.10);
  --shadow-sm: 0 1px 2px oklch(40% 0.03 50 / 0.08), 0 6px 18px oklch(40% 0.03 50 / 0.06);
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --dur: 280ms;
}

* { box-sizing: border-box; margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *,*::before,*::after { animation-duration:.01ms!important; transition-duration:.01ms!important; } }

body {
  font-family: var(--font);
  font-size: clamp(1rem, 0.96rem + 0.2vw, 1.0625rem);
  line-height: 1.6;
  color: var(--ink);
  background: var(--sand);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1,h2,h3 { font-family: var(--font-disp); font-weight: 600; line-height: 1.08; letter-spacing: -0.015em; }
h2 { font-size: var(--text-h2); }
h3 { font-size: var(--text-h3); letter-spacing: -0.01em; }
p { text-wrap: pretty; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
.muted { color: var(--ink-soft); }
.accent { color: var(--clay-deep); }
.serif { font-family: var(--font-disp); }

.wrap { width: min(100% - 2.5rem, var(--maxw)); margin-inline: auto; }
.narrow { width: min(100% - 2.5rem, var(--maxw-narrow)); margin-inline: auto; }
section { padding-block: var(--space-section); }
/* Dezenter, zentrierter Trennstrich zwischen aufeinanderfolgenden Sektionen */
section + section { position: relative; }
section + section::before { content: ""; position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: min(100% - 2.5rem, var(--maxw)); border-top: 1px solid var(--line); }
.eyebrow {
  display:inline-block; font-size: 0.78rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--clay-deep); margin-bottom: 1rem;
}

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--clay); --fg: #fff;
  display:inline-flex; align-items:center; gap:.5rem; justify-content:center;
  font: inherit; font-weight: 600; cursor:pointer; border: 1px solid transparent;
  padding: 0.85rem 1.5rem; border-radius: 999px; background: var(--bg); color: var(--fg);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), background var(--dur) var(--ease);
  box-shadow: 0 6px 18px oklch(60% 0.13 40 / 0.32);
}
.btn:hover { transform: translateY(-2px); box-shadow: 0 12px 28px oklch(60% 0.13 40 / 0.40); }
.btn:active { transform: translateY(0); }
.btn--ghost { --bg: transparent; --fg: var(--ink); border-color: var(--line); box-shadow:none; }
.btn--ghost:hover { background: var(--surface); box-shadow: var(--shadow-sm); }
.btn--light { --bg: var(--surface); --fg: var(--clay-deep); box-shadow: var(--shadow-sm); }
.btn--lg { padding: 1rem 1.9rem; font-size: 1.05rem; }
.btn--block { width: 100%; }

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: oklch(96.5% 0.012 75 / 0.82); backdrop-filter: blur(12px);
  border-bottom: 1px solid transparent; transition: border-color var(--dur);
}
.site-header.scrolled { border-color: var(--line); }
.nav { display:flex; align-items:center; justify-content:space-between; padding-block: 0.9rem; }
.brand { display:flex; align-items:center; gap:.6rem; font-family: var(--font-disp); font-weight:600; font-size: 1.4rem; letter-spacing:-0.02em; }
.brand__mark { width: 2.1rem; height: 2.1rem; border-radius: 10px; overflow:hidden; box-shadow: var(--shadow-sm); }
.brand__mark img { width: 100%; height: 100%; display: block; }
.nav__links { display:flex; align-items:center; gap: 1.5rem; }
.nav__links a.navlink { font-weight:500; color: var(--ink-soft); transition: color var(--dur); }
.nav__links a.navlink:hover { color: var(--ink); }
@media (max-width: 960px){ .nav__links .navlink { display:none; } }

/* ---------- Hero ---------- */
.hero { padding-top: clamp(2.5rem, 2rem + 3vw, 5rem); position: relative; }
.hero__grid { display:grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(2rem,2vw,4rem); align-items:center; }
@media (max-width: 900px){ .hero__grid { grid-template-columns: 1fr; } }
.hero h1 { font-size: var(--text-hero); }
.hero h1 .hl { color: var(--clay-deep); position: relative; white-space: nowrap; }
.hero__lead { font-size: var(--text-lead); color: var(--ink-soft); margin-top: 1.4rem; max-width: 34ch; }
.hero__cta { display:flex; gap: 0.8rem; margin-top: 2rem; flex-wrap: wrap; }
.price-anchor { margin-top: 1.6rem; font-size: 0.95rem; color: var(--ink-soft); display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.price-anchor s { opacity:.7; }
.price-anchor b { color: var(--clay-deep); }
.hero__note { margin-top: .9rem; font-size: 0.85rem; color: var(--ink-soft); }

/* Phone mockup */
.phone {
  width: min(290px, 78vw); margin-inline:auto; aspect-ratio: 9/19; border-radius: 38px;
  background: var(--night); padding: 11px; box-shadow: 0 30px 80px oklch(40% 0.03 50 / 0.28); position: relative;
  rotate: 2.5deg; transition: rotate var(--dur) var(--ease);
}
.hero__visual:hover .phone { rotate: 0deg; }
.phone__screen { width:100%; height:100%; border-radius: 28px; background: var(--sand); overflow:hidden; display:flex; flex-direction:column; }
.phone__bar { background: var(--surface); padding: .7rem .9rem; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:.5rem; }
.phone__bar .dot { width:.55rem;height:.55rem;border-radius:50%;background:var(--clay); }
.phone__bar small { font-family:var(--font-disp); font-weight:600; }
.phone__body { padding: .8rem; display:flex; flex-direction:column; gap:.55rem; overflow:hidden; }
.mini-row { background: var(--surface); border:1px solid var(--line); border-radius: 10px; padding:.55rem .65rem; display:flex; align-items:center; gap:.55rem; font-size:.72rem; box-shadow: var(--shadow-sm); }
.mini-row .ic { width:1.5rem;height:1.5rem;border-radius:7px;display:grid;place-items:center;flex:none;font-size:.8rem; }
.ic--in { background: oklch(54% 0.08 158 / 0.16); }
.ic--out { background: var(--clay-soft); }
.mini-row .amt { margin-left:auto; font-weight:700; font-variant-numeric: tabular-nums; }
.mini-row .amt.pos { color: var(--sage-deep); }
.mini-cam { margin-top:.2rem; background: var(--clay); color:#fff; border-radius: 11px; padding:.6rem; text-align:center; font-size:.72rem; font-weight:600; box-shadow: 0 6px 16px oklch(60% .13 40 /.35); }
.float-badge { position:absolute; background: var(--surface); border:1px solid var(--line); border-radius: 12px; padding:.5rem .7rem; box-shadow: var(--shadow); font-size:.76rem; font-weight:600; display:flex; align-items:center; gap:.4rem; }
.float-badge .b-dot { width:.5rem;height:.5rem;border-radius:50%; }
.fb-1 { top: 12%; left: -8%; }
.fb-2 { bottom: 14%; right: -6%; }
@media (max-width:480px){ .fb-1{left:-2%} .fb-2{right:-2%} }

/* ---------- Trust bar ---------- */
.trust { padding-block: 1.5rem; border-block:1px solid var(--line); background: var(--cream); }
.trust__row { display:flex; flex-wrap:wrap; gap: 1rem 2.2rem; align-items:center; justify-content:center; color: var(--ink-soft); font-size:.92rem; font-weight:500; }
.trust__row span { display:inline-flex; align-items:center; gap:.5rem; }
.trust__row svg { width:1.1rem;height:1.1rem; color: var(--sage-deep); }

/* ---------- Section heads ---------- */
.shead { max-width: 56ch; margin-bottom: clamp(2rem,3vw,3.5rem); }
.shead.center { margin-inline:auto; text-align:center; }
.shead p { font-size: var(--text-lead); color: var(--ink-soft); margin-top: .9rem; }

/* ---------- Problem → Lösung ---------- */
.pl-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
@media (max-width:760px){ .pl-grid{ grid-template-columns:1fr; } }
.pl-card { border-radius: var(--radius); padding: clamp(1.5rem,2vw,2.2rem); }
.pl-card h3 { margin-bottom: 1rem; }
.pl-card ul { list-style:none; padding:0; display:flex; flex-direction:column; gap:.7rem; }
.pl-card li { display:flex; gap:.7rem; align-items:flex-start; }
.pl-card li svg { width:1.3rem;height:1.3rem;flex:none;margin-top:.15rem; }
.pl--pain { background: var(--surface); border:1px solid var(--line); }
.pl--pain li svg { color: var(--clay); opacity:.8; }
.pl--gain { background: linear-gradient(160deg, var(--clay) 0%, var(--clay-deep) 100%); color:#fff; box-shadow: var(--shadow); }
.pl--gain .muted { color: oklch(100% 0 0 / 0.78); }
.pl--gain li svg { color: var(--gold); }

/* ---------- Bento features ---------- */
.bento { display:grid; grid-template-columns: repeat(6, 1fr); gap: 1.1rem; }
.feat { background: var(--surface); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(1.4rem,1.8vw,2rem); box-shadow: var(--shadow-sm); transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.feat:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.feat__ic { width: 3rem; height:3rem; border-radius: 14px; display:grid; place-items:center; margin-bottom: 1.1rem; background: var(--clay-soft); color: var(--clay-deep); }
.feat__ic svg { width:1.5rem;height:1.5rem; }
.feat h3 { margin-bottom: .5rem; }
.feat p { color: var(--ink-soft); font-size: .98rem; }
.feat--wide { grid-column: span 3; }
.feat--third { grid-column: span 2; }
.feat--hero-feat { grid-column: span 6; display:grid; grid-template-columns: 1.1fr 1fr; gap: 2rem; align-items:center; background: linear-gradient(150deg, var(--night) 0%, var(--night-2) 100%); color:#fff; }
.feat--hero-feat .feat__ic { background: oklch(76% .12 75 / .18); color: var(--gold); }
.feat--hero-feat p { color: oklch(100% 0 0 / 0.75); }
.feat--full { grid-column: 1 / -1; display:grid; grid-template-columns: 1.1fr 1fr; gap: 2rem; align-items:center; background: linear-gradient(150deg, var(--clay) 0%, var(--clay-deep) 100%); color:#fff; }
.feat--full .feat__ic { background: oklch(100% 0 0 / .18); color:#fff; }
.feat--full p { color: oklch(100% 0 0 / 0.85); }
.tag-row { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.1rem; }
.tag { font-size:.78rem; font-weight:600; padding:.35rem .75rem; border-radius:999px; background: oklch(100% 0 0 / 0.1); border:1px solid oklch(100% 0 0 /.16); }
@media (max-width: 900px){ .feat--wide,.feat--third{ grid-column: span 3; } .feat--hero-feat,.feat--full{ grid-template-columns:1fr; } }
@media (max-width: 620px){ .bento{ grid-template-columns:1fr; } .feat,.feat--wide,.feat--third,.feat--hero-feat{ grid-column: span 1; } }

/* ---------- Steps ---------- */
.steps { display:grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; counter-reset: step; }
@media (max-width:760px){ .steps{ grid-template-columns:1fr; } }
.step { position:relative; padding-top: 1rem; }
.step__n { font-family:var(--font-disp); font-size: 3rem; color: var(--clay); opacity:.35; line-height:1; }
.step h3 { margin:.4rem 0 .5rem; }
.step p { color: var(--ink-soft); }

/* ---------- Branchen ---------- */
.chips { display:flex; flex-wrap:wrap; gap:.7rem; justify-content:center; }
.chip { display:inline-flex; align-items:center; gap:.55rem; background: var(--surface); border:1px solid var(--line); border-radius:999px; padding:.65rem 1.15rem; font-weight:600; box-shadow: var(--shadow-sm); transition: transform var(--dur) var(--ease), border-color var(--dur); }
.chip svg { width:1em; height:1em; color: var(--clay); flex:none; }
.chip:hover { transform: translateY(-3px); border-color: var(--clay); }

/* ---------- Pricing ---------- */
.price-grid { display:grid; grid-template-columns: repeat(3,1fr); gap: 1.3rem; align-items:stretch; max-width: 980px; margin-inline:auto; }
@media (max-width:880px){ .price-grid{ grid-template-columns:1fr; max-width:460px; margin-inline:auto; } }
.selfhost-note { text-align:center; margin-top:1.4rem; font-size:.95rem; color:var(--ink-soft); }
.selfhost-note a { color:var(--clay-deep); font-weight:600; text-underline-offset:2px; }
.price-card { background: var(--surface); border:1px solid var(--line); border-radius: var(--radius); padding: clamp(1.6rem,2vw,2.2rem); box-shadow: var(--shadow-sm); position:relative; display:flex; flex-direction:column; }
.price-card.featured { border-color: var(--clay); box-shadow: var(--shadow); }
@media (max-width:880px){ .price-card.featured{ transform:none; } }
.price-card .ribbon { position:absolute; top:-.8rem; left: 50%; translate:-50% 0; background: var(--clay); color:#fff; font-size:.72rem; font-weight:700; letter-spacing:.05em; text-transform:uppercase; padding:.3rem .8rem; border-radius:999px; }
.price-card h3 { margin-bottom:.3rem; }
.price-card .ptag { color: var(--ink-soft); font-size:.92rem; min-height: 2.6em; }
.price-card .amount { font-family:var(--font-disp); font-size: 2.8rem; font-weight:600; margin:.6rem 0 0; letter-spacing:-.02em; }
.price-card .amount small { font-size: 1rem; color: var(--ink-soft); font-family:var(--font); }
.price-card .per { color: var(--ink-soft); font-size:.85rem; margin-bottom: 1.3rem; }
.price-card ul { list-style:none; padding:0; margin: 0 0 1.6rem; display:flex; flex-direction:column; gap:.6rem; font-size:.95rem; }
.price-card li { display:flex; gap:.55rem; align-items:flex-start; }
.price-card li svg { width:1.15rem;height:1.15rem;color:var(--sage-deep);flex:none;margin-top:.18rem; }
.price-card .btn { margin-top:auto; }
.vs-line { text-align:center; margin-top: 2.5rem; font-size:1.05rem; color: var(--ink-soft); }
.vs-line b { color: var(--clay-deep); }
.src-note { display:block; margin-top:.7rem; font-size:.8rem; color: var(--ink-soft); opacity:.85; }

/* ---------- Dark data section ---------- */
.data { background: linear-gradient(165deg, var(--night) 0%, var(--night-2) 100%); color:#fff; border-radius: clamp(20px,3vw,36px); padding: clamp(2.5rem,4vw,4.5rem); }
.data__grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: 2.5rem; align-items:center; }
@media (max-width:820px){ .data__grid{ grid-template-columns:1fr; } }
.data h2 { color:#fff; }
.data p { color: oklch(100% 0 0 / 0.76); margin-top:1rem; font-size: var(--text-lead); }
.data__list { list-style:none; padding:0; margin-top:1.6rem; display:flex; flex-direction:column; gap:1rem; }
.data__list li { display:flex; gap:.8rem; align-items:flex-start; }
.data__list svg { width:1.4rem;height:1.4rem;color:var(--gold);flex:none;margin-top:.15rem; }
.data__card { background: oklch(100% 0 0 / 0.06); border:1px solid oklch(100% 0 0 /.12); border-radius: var(--radius); padding: 1.8rem; }
.data__card .row { display:flex; justify-content:space-between; padding:.7rem 0; border-bottom:1px solid oklch(100% 0 0 /.1); font-size:.95rem; }
.data__card .row:last-child{ border-bottom:none; }
.data__card .row b { color: var(--gold); }

/* ---------- Treuhänder ---------- */
.th { background: var(--surface); border:1px solid var(--line); border-radius: clamp(20px,3vw,36px); padding: clamp(2rem,4vw,4rem); box-shadow: var(--shadow-sm); display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(2rem,4vw,3.5rem); align-items:center; }
@media (max-width:820px){ .th{ grid-template-columns:1fr; } }
.th__text .eyebrow { color: var(--sage-deep); }
.th__list { list-style:none; padding:0; margin:1.6rem 0 2rem; display:flex; flex-direction:column; gap:1.1rem; }
.th__list li { display:flex; gap:.8rem; align-items:flex-start; font-size:1.02rem; }
.th__list svg { width:1.4rem;height:1.4rem;color:var(--clay);flex:none;margin-top:.2rem; }
.th__note { margin-top:1rem; font-size:.85rem; color:var(--ink-soft); }
.th__cockpit { background: linear-gradient(160deg, var(--night) 0%, var(--night-2) 100%); border-radius: var(--radius); padding:1.5rem; box-shadow: var(--shadow); color:#fff; }
.th__cockpit-head { display:flex; align-items:center; gap:.5rem; font-family:var(--font-disp); font-weight:600; font-size:1.05rem; margin-bottom:1.1rem; }
.th__cockpit-head svg { width:1.2rem;height:1.2rem;color:var(--gold); }
.th__client { display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:.7rem .9rem; margin-bottom:.5rem; background: oklch(100% 0 0 /.06); border:1px solid oklch(100% 0 0 /.1); border-radius: var(--radius-sm); font-size:.92rem; font-variant-numeric:tabular-nums; }
.th__client:last-child { margin-bottom:0; }
.th__client .branch { color: oklch(100% 0 0 /.6); font-size:.8rem; }
.th__client .pos { color: var(--sage); font-weight:700; }
.th__client .neg { color: oklch(72% 0.14 40); font-weight:700; }

/* ---------- FAQ ---------- */
.faq { display:flex; flex-direction:column; gap:.8rem; }
.faq details { background: var(--surface); border:1px solid var(--line); border-radius: var(--radius-sm); padding: .4rem 1.3rem; box-shadow: var(--shadow-sm); }
.faq summary { cursor:pointer; font-weight:600; font-family:var(--font-disp); font-size:1.1rem; padding:1rem 0; list-style:none; display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after { content:"+"; font-size:1.5rem; color:var(--clay); font-family:var(--font); transition: transform var(--dur); }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p { padding-bottom:1.1rem; color:var(--ink-soft); }

/* ---------- Final CTA ---------- */
.final { text-align:center; }
.final-card { background: linear-gradient(160deg, var(--clay) 0%, var(--clay-deep) 100%); color:#fff; border-radius: clamp(20px,3vw,36px); padding: clamp(2.8rem,5vw,5rem) clamp(1.5rem,3vw,3rem); box-shadow: var(--shadow); }
.final-card h2 { color:#fff; max-width: 18ch; margin-inline:auto; }
.final-card p { color: oklch(100% 0 0 / 0.85); margin: 1.1rem auto 0; max-width: 44ch; font-size: var(--text-lead); }
.final-card .btn { margin-top: 2rem; }
.final-card .fine { margin-top:1rem; font-size:.85rem; color: oklch(100% 0 0 /.7); }

/* ---------- Footer (hell, zentriert) ---------- */
.site-footer {
  background: var(--cream);
  border-top: 1px solid var(--line);
  padding-block: clamp(2.6rem, 2rem + 2.4vw, 4.2rem);
}
.footer-inner { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 1.7rem; }
.footer-social { display: flex; justify-content: center; gap: .7rem; }
.footer-social span, .footer-social a {
  width: 2.55rem; height: 2.55rem; border-radius: 999px; display: grid; place-items: center; flex: none;
  background: var(--surface); border: 1px solid var(--line); color: var(--ink-soft); box-shadow: var(--shadow-sm);
}
.footer-social a { transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), border-color var(--dur), color var(--dur); }
.footer-social a:hover { background: var(--clay); border-color: var(--clay); color: #fff; transform: translateY(-3px); }
.footer-social svg { width: 1.2rem; height: 1.2rem; }
.footer-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: .8rem 1.8rem; max-width: 56rem; }
.footer-nav a { color: var(--ink-soft); font-weight: 500; transition: color var(--dur); }
.footer-nav a:hover { color: var(--clay-deep); }
.footer-meta { color: var(--ink-soft); font-size: .9rem; line-height: 1.7; }
.footer-meta .name { display: block; }

/* reveal */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in { opacity:1; transform:none; }

/* ============================================================
   Rechtsseiten (Impressum / Datenschutz / AGB)
   Ruhiger Lesefluss, gleiche Markenpalette wie die Landingpage.
   ============================================================ */
.legal-head { padding-block: clamp(2.5rem, 2rem + 3vw, 4.5rem) 0; }
.legal-head .eyebrow { margin-bottom: .6rem; }
.legal-head h1 { font-family: var(--font-disp); font-size: var(--text-h2); letter-spacing: -0.02em; }
.legal-head .stand { color: var(--ink-soft); font-size: .9rem; margin-top: .9rem; }

.legal { padding-block: clamp(2rem, 1.5rem + 2vw, 3.2rem) var(--space-section); }
.legal > .lead { font-size: var(--text-lead); color: var(--ink-soft); margin-bottom: 2.2rem; max-width: 60ch; }

.legal h2 {
  font-size: clamp(1.4rem, 1.15rem + 1vw, 1.95rem); font-family: var(--font-disp);
  margin: 2.6rem 0 .9rem; padding-top: 1.8rem; border-top: 1px solid var(--line);
  scroll-margin-top: 5rem;
}
.legal h2:first-of-type { border-top: none; padding-top: 0; margin-top: 0; }
.legal h3 { font-size: var(--text-h3); margin: 1.7rem 0 .5rem; }
.legal p { margin-bottom: 1rem; }
.legal ul, .legal ol { margin: 0 0 1.2rem; padding-left: 1.35rem; display:flex; flex-direction:column; gap: .5rem; }
.legal li { padding-left: .2rem; }
.legal a { color: var(--clay-deep); text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1px; }
.legal a:hover { color: var(--clay); }
.legal strong { font-weight: 600; }

/* Kontakt-/Hinweis-Karte */
.legal__card {
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 1.4rem 1.6rem; margin: 1.3rem 0 1.8rem; box-shadow: var(--shadow-sm);
}
.legal__card p { margin-bottom: .25rem; }
.legal__card p:last-child { margin-bottom: 0; }

/* Inhaltsverzeichnis */
.legal__toc { background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: 1.3rem 1.6rem; margin-bottom: 2.6rem; }
.legal__toc strong { display:block; font-family: var(--font-disp); font-weight: 600; margin-bottom: .7rem; }
.legal__toc ol { margin: 0; padding-left: 1.2rem; gap: .35rem; font-size: .95rem; }
.legal__toc a { color: var(--ink-soft); text-decoration: none; }
.legal__toc a:hover { color: var(--clay-deep); }

/* Schlüssel-Wert-Tabelle (Kontaktdaten, Verarbeiter) */
.legal .kv { border-collapse: collapse; width: 100%; margin: .6rem 0 1.6rem; }
.legal .kv td { padding: .55rem .9rem; border-bottom: 1px solid var(--line); vertical-align: top; font-size: .95rem; }
.legal .kv tr:last-child td { border-bottom: none; }
.legal .kv td:first-child { color: var(--ink-soft); width: 34%; font-weight: 500; }

.legal__back { display:inline-flex; align-items:center; gap: .45rem; margin-top: 2.8rem; font-weight: 600; color: var(--clay-deep); }
.legal__back:hover { gap: .7rem; }
.legal__back svg { width: 1.1rem; height: 1.1rem; transition: transform var(--dur) var(--ease); }

/* ===================== CTA: Exit-Intent-Modal + Sticky-Bar ===================== */
.cta-modal {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center; padding: 1.2rem;
  background: oklch(26% 0.022 50 / 0.5);
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
  opacity: 0; transition: opacity 300ms ease;
}
.cta-modal.open { opacity: 1; }
.cta-modal__card {
  position: relative; width: 100%; max-width: 27rem;
  background: var(--surface); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 2.4rem 2rem 1.6rem; text-align: center;
  transform: scale(.96) translateY(8px); transition: transform 320ms cubic-bezier(.16,1,.3,1);
}
.cta-modal.open .cta-modal__card { transform: none; }
.cta-modal__ic {
  width: 3.4rem; height: 3.4rem; margin: 0 auto 1.1rem;
  display: grid; place-items: center; border-radius: 16px;
  background: var(--clay-soft); color: var(--clay-deep);
}
.cta-modal__ic svg { width: 1.7rem; height: 1.7rem; }
.cta-modal__card h2 { font-size: 1.7rem; margin-bottom: .6rem; }
.cta-modal__card > p { color: var(--ink-soft); max-width: 30ch; margin: 0 auto 1.5rem; line-height: 1.5; }
.cta-modal__card .btn { margin-bottom: 1.2rem; }
.cta-modal__pts {
  list-style: none; display: flex; flex-direction: column; gap: .5rem;
  font-size: .9rem; color: var(--ink-soft); text-align: left; max-width: 19rem; margin: 0 auto;
}
.cta-modal__pts li { display: flex; align-items: center; gap: .55rem; }
.cta-modal__pts svg { width: 1.1rem; height: 1.1rem; color: var(--sage-deep); flex: none; }
.cta-modal__close {
  position: absolute; top: .8rem; right: 1rem; background: none; border: 0; cursor: pointer;
  font-size: 1.6rem; line-height: 1; color: var(--ink-soft); padding: .2rem; transition: color 200ms;
}
.cta-modal__close:hover { color: var(--ink); }
.cta-modal__no {
  display: block; margin: 1.1rem auto 0; background: none; border: 0; cursor: pointer;
  font-size: .85rem; color: var(--ink-soft); transition: color 200ms;
}
.cta-modal__no:hover { color: var(--ink); text-decoration: underline; }

/* Sticky-Bar — nur Mobile */
.cta-bar {
  position: fixed; left: 0; right: 0; bottom: 0; z-index: 150;
  display: none; align-items: center; gap: .8rem;
  padding: .7rem .9rem calc(.7rem + env(safe-area-inset-bottom));
  background: var(--surface); box-shadow: 0 -2px 12px oklch(40% 0.03 50 / 0.12);
  transform: translateY(110%); transition: transform 320ms cubic-bezier(.16,1,.3,1);
}
.cta-bar.in { transform: none; }
.cta-bar__txt { display: flex; flex-direction: column; line-height: 1.25; min-width: 0; flex: 1 1 0; overflow: hidden; }
.cta-bar__txt strong { font-size: .88rem; color: var(--ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cta-bar__txt span { font-size: .76rem; color: var(--ink-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cta-bar .btn { padding: .6rem 1.1rem; font-size: .9rem; flex: none; }
.cta-bar__close { background: none; border: 0; cursor: pointer; font-size: 1.3rem; color: var(--ink-soft); padding: 0 .2rem; flex: none; }
@media (max-width: 768px) { .cta-bar { display: flex; } }

/* FIX: hidden-Attribut respektieren — sonst überdeckt das unsichtbare Modal-Overlay die Seite und blockiert alle Klicks */
.cta-modal[hidden], .cta-bar[hidden] { display: none !important; }
.cta-modal:not(.open) { pointer-events: none; }
.cta-modal.open { pointer-events: auto; }

/* ---------- Newsletter ---------- */
#newsletter { padding-block: var(--space-section); }
.nl-card { background: var(--cream); border: 1px solid var(--line); border-radius: var(--radius); padding: clamp(1.8rem, 4vw, 3rem); max-width: 720px; margin-inline: auto; text-align: center; box-shadow: var(--shadow-sm); }
.nl-card .eyebrow { color: var(--clay-deep); }
.nl-card h2 { margin: .5rem 0 .6rem; font-size: var(--text-h3); }
.nl-lead { color: var(--ink-soft); max-width: 46ch; margin: 0 auto; }
.nl-form { margin-top: 1.6rem; }
.nl-row { display: flex; gap: .6rem; max-width: 440px; margin-inline: auto; }
.nl-row input[type=email] { flex: 1; min-width: 0; padding: .8rem 1rem; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--surface); font: inherit; color: var(--ink); }
.nl-row input[type=email]:focus-visible { outline: 2px solid var(--clay); outline-offset: 1px; border-color: var(--clay); }
.nl-row button { flex: none; padding: .8rem 1.5rem; border: 0; border-radius: var(--radius-sm); background: var(--clay); color: #fff; font-weight: 600; cursor: pointer; transition: background var(--dur) var(--ease); }
.nl-row button:hover { background: var(--clay-deep); }
.nl-row button:disabled { opacity: .6; cursor: default; }
.nl-hp { position: absolute !important; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.nl-vh { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
.nl-note { font-size: .82rem; color: var(--ink-soft); margin-top: .9rem; }
.nl-note a { color: var(--clay-deep); text-decoration: underline; text-underline-offset: 2px; }
.nl-feedback { margin-top: 1.1rem; font-weight: 500; padding: .75rem 1rem; border-radius: var(--radius-sm); }
.nl-feedback.ok { background: var(--clay-soft); color: var(--ink); }
.nl-feedback.err { background: oklch(62% 0.16 28 / .14); color: oklch(46% 0.16 28); }
@media (max-width: 520px) { .nl-row { flex-direction: column; } .nl-row button { width: 100%; } }
