/* ==========================================================================
   MARMOR NOORI — Natursteinsanierung · Entwurf 2026
   Design: Editorial Luxury · warme Stein-Neutraltöne + Brand-Blau #1B87EA
   Fonts: Fraunces (Display) + Plus Jakarta Sans (Body)
   ========================================================================== */

/* ---------- Design Tokens ---------- */
:root {
  /* Brand */
  --blue:        #1B87EA;
  --blue-600:    #1570cf;
  --blue-700:    #0f59a8;
  --blue-ink:    #0c3f78;
  --blue-tint:   #e9f3fe;
  --blue-tint-2: #d4e8fc;

  /* Stone neutrals (warm) */
  --paper:       #f6f2ec;  /* page base */
  --paper-2:     #efe9e0;  /* alt section */
  --sand:        #e7ddcf;
  --stone:       #ccc0ad;
  --card:        #fffdf9;  /* card surface */
  --card-2:      #fbf7f0;

  /* Ink (warm near-black like polished granite) */
  --ink:         #17140f;
  --ink-2:       #2a261f;
  --text:        #3c372f;  /* body text */
  --muted:       #6b6458;  /* secondary text */
  --line:        #e2d9cb;  /* hairlines */
  --line-strong: #d2c6b3;

  /* Accents */
  --gold:        #c89c4f;  /* stars / fine detail */
  --whatsapp:    #25d366;
  --whatsapp-d:  #1da851;

  /* Typography */
  --font-display: "Cormorant Garamond", "Georgia", serif;
  --font-body:    "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;

  /* Radii (nav = 0 per Vorgabe) */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 22px;
  --r-xl: 30px;
  --r-pill: 999px;

  /* Shadows — soft, diffused, never harsh */
  --sh-xs: 0 1px 2px rgba(23,20,15,.05);
  --sh-sm: 0 4px 14px -6px rgba(23,20,15,.12);
  --sh-md: 0 18px 40px -22px rgba(23,20,15,.28);
  --sh-lg: 0 40px 80px -40px rgba(23,20,15,.36);
  --sh-blue: 0 16px 34px -14px rgba(27,135,234,.55);
  --inset-hi: inset 0 1px 0 rgba(255,255,255,.6);

  /* Motion */
  --ease: cubic-bezier(.32,.72,0,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  /* Layout */
  --container: 1240px;
  --container-tight: 1080px;
  --gut: clamp(1.1rem, 4vw, 2.4rem);

  /* z-scale */
  --z-nav: 100;
  --z-overlay: 200;
  --z-fab: 150;
  --z-lightbox: 300;
  --z-grain: 1;
  --nav-h: 88px;

  /* Beige-Marmor-Hintergrund (Sichtbarkeit fein justierbar) */
  --marble-veil: .62;   /* Marmor-Ton auf allen Seiten (Hauptton) */
}

/* ---------- Reset ---------- */
*,*::before,*::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *,*::before,*::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}
body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--text);
  line-height: 1.65;
  font-size: 1.0625rem;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img,svg,video { display: block; max-width: 100%; }
img { height: auto; }
svg { flex: none; }                        /* Icons nie strecken */
:where(a, button, .eyebrow, li, span) > svg { display: inline-block; vertical-align: middle; }
[id] { scroll-margin-top: 112px; }          /* Anker nicht unter Sticky-Nav (größeres Logo) */
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; border: none; background: none; }
input,textarea,select { font: inherit; }
ul { list-style: none; padding: 0; }
:focus-visible { outline: 2.5px solid var(--blue); outline-offset: 3px; border-radius: 3px; }
::selection { background: var(--blue); color: #fff; }
.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:fixed; left:1rem; top:-4rem; z-index:400; background:var(--ink); color:#fff; padding:.7rem 1.1rem; border-radius:var(--r-sm); box-shadow:var(--sh-md); transition:top .25s var(--ease); }
.skip-link:focus { top:1rem; outline:2.5px solid #fff; }
#main:focus { outline:none; }

/* Film-grain / paper texture overlay (fixed, non-interactive) */
body::before {
  content: "";
  position: fixed; inset: 0;
  z-index: var(--z-grain);
  pointer-events: none;
  opacity: .035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}

/* Beige-Marmor-Veil: fester, warmer Marmor-Ton hinter allen Inhalten (Hauptton) */
body::after {
  content: "";
  position: fixed; inset: 0;
  z-index: -1;
  pointer-events: none;
  background: url("../img/marble-bg.webp") center center / cover no-repeat;
  opacity: var(--marble-veil);
}

/* ---------- Typography ---------- */
h1,h2,h3,h4 {
  font-family: var(--font-display);
  color: var(--ink);
  font-weight: 700;
  line-height: 1.08;
  letter-spacing: -0.008em;
  font-optical-sizing: auto;
}
.display {
  font-size: clamp(3rem, 7vw, 6rem);
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: -0.014em;
}
h2.section-title { font-size: clamp(2.3rem, 5vw, 3.9rem); font-weight: 700; }
h3 { font-size: clamp(1.4rem, 2.2vw, 1.8rem); }
p { text-wrap: pretty; }
.lead { font-size: clamp(1.12rem, 1.6vw, 1.35rem); color: var(--text); line-height: 1.6; }
em, .italic { font-style: italic; }
.ital-accent { font-style: italic; color: var(--blue-700); }

/* Eyebrow */
.eyebrow {
  display: inline-flex; align-items: center; gap: .55em;
  font-family: var(--font-body);
  font-size: .72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .22em;
  color: var(--blue-700);
  padding: .42em 1em;
  background: var(--blue-tint);
  border: 1px solid var(--blue-tint-2);
  border-radius: var(--r-pill);
}
.eyebrow::before { content:""; width: 6px; height: 6px; border-radius: 50%; background: var(--blue); }
.eyebrow.on-dark { color: #bcdcfb; background: rgba(27,135,234,.14); border-color: rgba(27,135,234,.3); }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--gut); }
.container.tight { max-width: var(--container-tight); }
.section { padding-block: clamp(4.5rem, 9vw, 8.5rem); position: relative; }
.section.pad-sm { padding-block: clamp(3rem, 6vw, 5rem); }
.section-head { max-width: 720px; margin-bottom: clamp(2.4rem, 5vw, 4rem); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head .eyebrow { margin-bottom: 1.1rem; }
.section-head p { margin-top: 1.1rem; color: var(--muted); font-size: 1.12rem; }

.bg-alt { background: var(--paper-2); }
.bg-ink { background: var(--ink); color: #d9d2c6; }
.bg-ink h1,.bg-ink h2,.bg-ink h3 { color: #fbf8f2; }
.bg-sand { background: linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); }

/* Marmor-Feature-Band: kräftigere Beige-Marmorisierung (z. B. hinter Referenzen) */
.bg-marble { position: relative; isolation: isolate; background: var(--paper); }
.bg-marble::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: url("../img/marble-bg.webp") center center / cover no-repeat;
  opacity: .92;
}
.bg-marble::after {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(246,242,236,.30), rgba(246,242,236,.14) 22%, rgba(246,242,236,.14) 78%, rgba(246,242,236,.30));
  pointer-events: none;
}

/* Decorative blue rule */
.rule { width: 54px; height: 3px; background: var(--blue); border-radius: 2px; }

/* ---------- Buttons ---------- */
.btn {
  --bg: var(--ink); --fg: #fff;
  position: relative;
  display: inline-flex; align-items: center; gap: .7rem;
  padding: .95rem 1.1rem .95rem 1.55rem;
  background: var(--bg); color: var(--fg);
  border-radius: var(--r-pill);
  font-weight: 600; font-size: .98rem; letter-spacing: -0.01em;
  box-shadow: var(--sh-sm);
  transition: transform .4s var(--ease), background .3s var(--ease), box-shadow .4s var(--ease);
  white-space: nowrap;
}
.btn:active { transform: scale(.975); }
.btn .ico {
  display: grid; place-items: center;
  width: 2.05rem; height: 2.05rem; border-radius: 50%;
  background: rgba(255,255,255,.16);
  transition: transform .45s var(--ease), background .3s var(--ease);
}
.btn .ico svg { width: 1.05rem; height: 1.05rem; }
.btn:hover { box-shadow: var(--sh-md); }
.btn:hover .ico { transform: translate(2px,-2px) scale(1.06); }

.btn--primary { --bg: var(--blue); --fg: #fff; box-shadow: var(--sh-blue); }
.btn--primary:hover { --bg: var(--blue-600); }
.btn--ink { --bg: var(--ink); --fg: #fff; }
.btn--ink:hover { --bg: #000; }
.btn--ghost { --bg: transparent; --fg: var(--ink); box-shadow: none; border: 1.5px solid var(--line-strong); padding-left: 1.55rem; }
.btn--ghost .ico { background: var(--blue-tint); color: var(--blue-700); }
.btn--ghost:hover { border-color: var(--blue); background: var(--blue-tint); box-shadow: none; }
.btn--whatsapp { --bg: var(--whatsapp); --fg: #04361b; }
.btn--whatsapp:hover { --bg: var(--whatsapp-d); --fg:#fff; }
.btn--lg { padding: 1.15rem 1.2rem 1.15rem 1.85rem; font-size: 1.05rem; }
.btn--lg .ico { width: 2.3rem; height: 2.3rem; }
.btn--block { display: flex; width: 100%; justify-content: center; }
.btn.on-dark.btn--ghost { --fg: #f3ede3; border-color: rgba(255,255,255,.22); }
.btn.on-dark.btn--ghost:hover { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.4); }

.text-link { display:inline-flex; align-items:center; gap:.5rem; font-weight:600; color: var(--blue-700);
  border-bottom: 1.5px solid transparent; transition: gap .3s var(--ease), border-color .3s var(--ease); }
.text-link svg { width: 1.05rem; height: 1.05rem; transition: transform .3s var(--ease); }
.text-link:hover { gap: .8rem; border-color: var(--blue); }
.text-link:hover svg { transform: translateX(3px); }

/* ---------- Header / Nav (border-radius: 0 per Vorgabe) ---------- */
.nav {
  position: sticky; top: 0; z-index: var(--z-nav);
  border-radius: 0;                      /* hard requirement */
  background: rgba(246,242,236,.72);
  backdrop-filter: saturate(160%) blur(16px);
  -webkit-backdrop-filter: saturate(160%) blur(16px);
  border-bottom: 1px solid transparent;
  transition: background .4s var(--ease), border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.nav.scrolled {
  background: rgba(246,242,236,.92);
  border-bottom-color: var(--line);
  box-shadow: 0 10px 30px -24px rgba(23,20,15,.5);
}
.nav__inner {
  max-width: var(--container); margin-inline: auto;
  padding: .7rem var(--gut);
  display: flex; align-items: center; gap: 1.1rem;
  min-height: 80px;
}
.nav__logo { display: flex; align-items: center; }
.nav__logo img { height: 86px; width: auto; }   /* Logo um 50% vergrößert (vorher 57px) */
.nav__links { display: flex; align-items: center; gap: .25rem; margin-left: auto; }
.nav__link {
  position: relative; padding: .55rem .72rem; border-radius: var(--r-sm);
  font-weight: 500; font-size: .95rem; color: var(--ink-2); white-space: nowrap;
  transition: color .25s var(--ease), background .25s var(--ease);
}
.nav__link::after {
  content:""; position:absolute; left: .85rem; right: .85rem; bottom: .34rem;
  height: 2px; background: var(--blue); border-radius: 2px;
  transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ease);
}
.nav__link:hover { color: var(--ink); }
.nav__link:hover::after, .nav__link[aria-current="page"]::after { transform: scaleX(1); }
.nav__link[aria-current="page"] { color: var(--ink); }

/* dropdown for Leistungen */
.nav__has-sub { position: relative; }
.nav__has-sub > .nav__link { display: inline-flex; align-items: center; gap: .3rem; }
.nav__has-sub > .nav__link svg { width: .9rem; height: .9rem; transition: transform .3s var(--ease); }
.nav__has-sub:hover > .nav__link svg { transform: rotate(90deg); }
.nav__sub {
  position: absolute; top: calc(100% + .4rem); left: 0;
  min-width: 256px; padding: .5rem;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-md); box-shadow: var(--sh-md);
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
}
.nav__has-sub:hover .nav__sub, .nav__has-sub:focus-within .nav__sub { opacity:1; visibility:visible; transform: translateY(0); }
.nav__sub a { display:flex; align-items:center; gap:.7rem; padding:.6rem .7rem; border-radius:var(--r-sm); font-size:.93rem; font-weight:500; color: var(--ink-2); transition: background .2s; }
.nav__sub a:hover { background: var(--blue-tint); color: var(--blue-700); }
.nav__sub a .dot { width:7px; height:7px; border-radius:50%; background: var(--blue); flex:none; }

.nav__cta { display: flex; align-items: center; gap: .6rem; margin-left: .6rem; }
.nav__phone { display:inline-flex; align-items:center; gap:.5rem; font-weight:600; font-size:.95rem; padding:.5rem .4rem; color: var(--ink); white-space: nowrap; }
.nav__phone svg { width:1.05rem; height:1.05rem; color: var(--blue); }
.nav__burger { display:none; }

/* Mobile overlay menu */
.nav__burger {
  width: 46px; height: 46px; border-radius: var(--r-sm);
  display: none; place-items: center; margin-left: auto;
  background: var(--card); border: 1px solid var(--line);
}
.burger-box { position: relative; width: 22px; height: 14px; }
.burger-box span { position:absolute; left:0; width:100%; height:2px; background: var(--ink); border-radius:2px; transition: transform .45s var(--ease), opacity .3s var(--ease), top .45s var(--ease); }
.burger-box span:nth-child(1){ top:0; }
.burger-box span:nth-child(2){ top:6px; }
.burger-box span:nth-child(3){ top:12px; }
body.menu-open .burger-box span:nth-child(1){ top:6px; transform: rotate(45deg); }
body.menu-open .burger-box span:nth-child(2){ opacity:0; }
body.menu-open .burger-box span:nth-child(3){ top:6px; transform: rotate(-45deg); }

.mobile-menu {
  position: fixed; inset: 0; z-index: var(--z-overlay);
  background: rgba(246,242,236,.96);
  backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  display: flex; flex-direction: column; padding: 1.2rem var(--gut) 2rem;
  opacity: 0; visibility: hidden; transform: translateY(-12px);
  transition: opacity .4s var(--ease), transform .4s var(--ease), visibility .4s;
  overflow-y: auto;
}
body.menu-open .mobile-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.mobile-menu__top { display:flex; align-items:center; justify-content:space-between; min-height:68px; }
.mobile-menu__close { width:46px; height:46px; border-radius:var(--r-sm); background:var(--card); border:1px solid var(--line); display:grid; place-items:center; color:var(--ink); transition:background .25s var(--ease); }
.mobile-menu__close:hover { background:var(--blue-tint); color:var(--blue-700); }
.mobile-menu__close svg { width:1.3rem; height:1.3rem; }
.mobile-menu__top img { height: 54px; }
.mobile-menu__links { display:flex; flex-direction:column; gap:.2rem; margin-top: 1.5rem; }
.mobile-menu__links a {
  font-family: var(--font-display); font-size: clamp(1.7rem,7vw,2.4rem); font-weight: 500; color: var(--ink);
  padding: .35rem 0; border-bottom: 1px solid var(--line);
  opacity: 0; transform: translateY(18px);
  transition: opacity .6s var(--ease), transform .6s var(--ease);
}
body.menu-open .mobile-menu__links a { opacity:1; transform: translateY(0); }
body.menu-open .mobile-menu__links a:nth-child(1){ transition-delay:.08s; }
body.menu-open .mobile-menu__links a:nth-child(2){ transition-delay:.13s; }
body.menu-open .mobile-menu__links a:nth-child(3){ transition-delay:.18s; }
body.menu-open .mobile-menu__links a:nth-child(4){ transition-delay:.23s; }
body.menu-open .mobile-menu__links a:nth-child(5){ transition-delay:.28s; }
body.menu-open .mobile-menu__links a:nth-child(6){ transition-delay:.33s; }
body.menu-open .mobile-menu__links a:nth-child(7){ transition-delay:.38s; }
.mobile-menu__cta { margin-top: auto; padding-top: 2rem; display:flex; flex-direction:column; gap:.7rem; }
.mobile-menu__meta { margin-top:1.4rem; color: var(--muted); font-size:.92rem; display:flex; flex-direction:column; gap:.3rem; }

/* ---------- Hero (Editorial Split) ---------- */
.hero { position: relative; padding-block: clamp(2.5rem, 6vw, 5rem) clamp(3.5rem, 7vw, 6rem); }
.hero__grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 4vw, 4rem); align-items: center; }
.hero__content { max-width: 620px; }
.hero h1 { margin: 1.4rem 0 0; }
.hero h1 .blue { color: var(--blue); }
.hero__sub { margin-top: 1.5rem; max-width: 30ch; }
.hero__usp { display:flex; flex-wrap:wrap; gap:.5rem .55rem; margin-top: 1.7rem; }
.hero__usp li { display:inline-flex; align-items:center; gap:.5rem; font-size:.9rem; font-weight:600; color: var(--ink-2);
  background: var(--card); border: 1px solid var(--line); padding:.5rem .9rem; border-radius: var(--r-pill); box-shadow: var(--sh-xs); }
.hero__usp svg { width: 1rem; height: 1rem; color: var(--blue); flex:none; }
.hero__actions { display:flex; flex-wrap:wrap; gap:.8rem; margin-top: 2rem; }
.hero__trust { display:flex; align-items:center; gap:1rem; margin-top: 2.1rem; }
.hero__stars { display:flex; gap:.15rem; color: var(--gold); }
.hero__stars svg { width:1.05rem; height:1.05rem; }
.hero__trust-txt { font-size:.9rem; color: var(--muted); }
.hero__trust-txt strong { color: var(--ink); }

/* Hero media — double-bezel + floating before/after teaser */
.hero__media { position: relative; }
.bezel {
  position: relative; padding: 8px;
  background: linear-gradient(160deg, rgba(255,255,255,.7), rgba(231,221,207,.5));
  border: 1px solid rgba(255,255,255,.6);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
}
.bezel::after { content:""; position:absolute; inset:0; border-radius: inherit; box-shadow: var(--inset-hi); pointer-events:none; }
.bezel__inner { border-radius: calc(var(--r-xl) - 8px); overflow: hidden; position: relative; }
.hero__img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.hero__badge {
  position: absolute; z-index: 3;
  display:flex; align-items:center; gap:.7rem;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-md); padding: .7rem .95rem; box-shadow: var(--sh-md);
}
.hero__badge--tl { top: -18px; left: -14px; }
.hero__badge--br { bottom: -18px; right: -10px; }
.hero__badge .num { font-family: var(--font-display); font-size: 1.7rem; font-weight: 600; color: var(--blue); line-height: 1; }
.hero__badge .lbl { font-size: .76rem; color: var(--muted); line-height: 1.2; max-width: 13ch; }
.hero__badge .yico { width:2.2rem; height:2.2rem; border-radius:50%; background: var(--blue-tint); color: var(--blue-700); display:grid; place-items:center; }
.hero__badge .yico svg { width:1.2rem; height:1.2rem; }

/* Open-status pill */
.status {
  display:inline-flex; align-items:center; gap:.4rem; font-weight:600; font-size:.8rem;
  color: var(--ink-2);                       /* eigene dunkle Textfarbe (erbt sonst Weiß im Hero) */
  padding:.24rem .68rem; border-radius: var(--r-pill); background: var(--card); border:1px solid var(--line);
}
.status__dot { width:9px; height:9px; border-radius:50%; background: var(--muted); position:relative; }
.status.is-open .status__dot { background: var(--whatsapp); }
.status.is-open .status__dot::after { content:""; position:absolute; inset:-4px; border-radius:50%; background: var(--whatsapp); opacity:.35; animation: ping 1.8s var(--ease) infinite; }
.status.is-closed .status__dot { background: #d98b5f; }
@keyframes ping { 0%{transform:scale(1);opacity:.4} 80%,100%{transform:scale(2.4);opacity:0} }

/* ---------- Marquee (stone types) ---------- */
.marquee { overflow: hidden; border-block: 1px solid var(--line); background: var(--card-2); padding-block: 1.15rem; }
.marquee__track { display:flex; gap: 3.2rem; width: max-content; animation: marquee 32s linear infinite; }
.marquee:hover .marquee__track { animation-play-state: paused; }
.marquee__item { display:inline-flex; align-items:center; gap:.7rem; font-family: var(--font-display); font-size: 1.35rem; color: var(--ink-2); font-weight: 500; font-style: italic; }
.marquee__item::before { content:""; width:7px; height:7px; border-radius:50%; background: var(--blue); }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- Stats / Count-up ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem,2.5vw,2rem); }
.stat { text-align: left; }
.stat__num { font-family: var(--font-display); font-size: clamp(2.6rem,5vw,3.9rem); font-weight: 580; color: var(--ink); line-height: 1; letter-spacing: -0.02em; }
.bg-ink .stat__num { color: #fff; }
.stat__num .suffix { color: var(--blue); }
.stat__label { margin-top:.6rem; color: var(--muted); font-weight:500; font-size:.97rem; }
.bg-ink .stat__label { color: #b3aa9b; }
.stat__ph { font-size:.72rem; color: #6db4f5; }

/* ---------- Service cards (double-bezel) ---------- */
.cards { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.1rem,2.2vw,1.8rem); }
.card {
  position: relative; background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sh-sm); transition: transform .55s var(--ease), box-shadow .55s var(--ease), border-color .4s var(--ease);
  display:flex; flex-direction: column;
}
.card:hover { transform: translateY(-6px); box-shadow: var(--sh-md); border-color: var(--line-strong); }
.card__media { position: relative; overflow: hidden; aspect-ratio: 16/11; }
.card__media img { width:100%; height:100%; object-fit: cover; transition: transform 1s var(--ease); }
.card:hover .card__media img { transform: scale(1.06); }
/* 5 Leistungs-Karten: keine leere Lücke in der letzten Reihe – 3 oben, 2 mittig darunter (Desktop) */
@media (min-width: 1025px) {
  #leistungen .cards { grid-template-columns: repeat(6, 1fr); }
  #leistungen .cards > .card { grid-column: span 2; }
  #leistungen .cards > .card:nth-child(4) { grid-column: 2 / span 2; }
  #leistungen .cards > .card:nth-child(5) { grid-column: 4 / span 2; }
}
/* Tablet (2 Spalten): letzte einzelne Karte mittig statt links */
@media (min-width: 561px) and (max-width: 1024px) {
  #leistungen .cards { grid-template-columns: repeat(4, 1fr); }
  #leistungen .cards > .card { grid-column: span 2; }
  #leistungen .cards > .card:nth-child(5) { grid-column: 2 / span 2; }
}
.card__num { position:absolute; top: .9rem; left: .9rem; z-index:2; font-family: var(--font-display); font-size:.95rem; font-weight:600; color:#fff;
  background: rgba(23,20,15,.45); backdrop-filter: blur(6px); border:1px solid rgba(255,255,255,.2); width:2.3rem; height:2.3rem; border-radius:50%; display:grid; place-items:center; }
.card__body { padding: 1.5rem 1.5rem 1.6rem; display:flex; flex-direction:column; flex:1; }
.card__body h3 { color: var(--ink); }
.card__body p { margin-top:.6rem; color: var(--muted); font-size:.97rem; flex:1; }
.card__link { margin-top: 1.2rem; }

/* generic feature list with check icons */
.checks { display:flex; flex-direction:column; gap:.7rem; margin-top: 1.4rem; }
.checks li { display:flex; gap:.75rem; align-items:flex-start; font-size:.99rem; color: var(--text); }
.checks li svg { width:1.35rem; height:1.35rem; flex:none; color: var(--blue); margin-top:.05rem; }
.bg-ink .checks li { color:#cfc8bb; }

/* ---------- Before / After slider ---------- */
.ba-wrap { display:grid; grid-template-columns: 1.15fr .85fr; gap: clamp(1.6rem,3vw,3rem); align-items:center; }
.ba {
  position: relative; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-lg);
  aspect-ratio: 4/3; user-select: none; touch-action: pan-y; background: var(--ink);
}
.ba img { position:absolute; inset:0; width:100%; height:100%; object-fit: cover; pointer-events:none; }
.ba__after { clip-path: inset(0 0 0 0); }
.ba__before { z-index:2; }                       /* before shown on left, clipped by handle */
.ba__before-wrap { position:absolute; inset:0; z-index:2; overflow:hidden; width:50%; will-change: width; }
.ba__before-wrap img { width: var(--ba-w, 100%); max-width:none; }
.ba__handle {
  position:absolute; top:0; bottom:0; left:50%; z-index:4; width:3px; margin-left:-1.5px;
  background: rgba(255,255,255,.9); box-shadow: 0 0 0 1px rgba(23,20,15,.15);
}
.ba__grip {
  position:absolute; top:50%; left:50%; transform: translate(-50%,-50%);
  width:52px; height:52px; border-radius:50%; background: var(--card); box-shadow: var(--sh-md);
  display:grid; place-items:center; cursor: ew-resize; color: var(--blue-700);
  border:1px solid var(--line);
}
.ba__grip svg { width:1.4rem; height:1.4rem; }
.ba__tag { position:absolute; bottom:1rem; z-index:5; font-size:.72rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  padding:.4rem .8rem; border-radius: var(--r-pill); color:#fff; background: rgba(23,20,15,.55); backdrop-filter: blur(6px); }
.ba__tag--before { left:1rem; }
.ba__tag--after { right:1rem; background: rgba(27,135,234,.8); }
.ba__hint { position:absolute; top:1rem; left:50%; transform:translateX(-50%); z-index:5; font-size:.74rem; color:#fff;
  background:rgba(23,20,15,.5); padding:.35rem .8rem; border-radius:var(--r-pill); backdrop-filter:blur(6px);
  display:flex; align-items:center; gap:.4rem; opacity:1; transition:opacity .5s; }
.ba.touched .ba__hint { opacity:0; }
.ba-thumbs { display:flex; gap:.6rem; flex-wrap:wrap; margin-top:1.4rem; }
.ba-thumb { width:64px; height:48px; border-radius:var(--r-sm); overflow:hidden; border:2px solid transparent; opacity:.6; transition:opacity .3s, border-color .3s; }
.ba-thumb img { width:100%; height:100%; object-fit:cover; }
.ba-thumb.active { opacity:1; border-color: var(--blue); }
.ba-copy h3 { margin-bottom:1rem; }

/* ---------- Reviews carousel ---------- */
.reviews { position: relative; }
.reviews__viewport { overflow: hidden; }
.reviews__track { display:flex; transition: transform .7s var(--ease); }
.review {
  flex: 0 0 100%; padding: clamp(.4rem,1vw,1rem);
}
@media (min-width:760px){ .review { flex-basis: 50%; } }
@media (min-width:1080px){ .review { flex-basis: 33.333%; } }
.review__card {
  height:100%; background: var(--card); border:1px solid var(--line); border-radius: var(--r-lg);
  padding: 1.8rem 1.7rem; box-shadow: var(--sh-sm); display:flex; flex-direction:column; gap:1rem;
}
.review__stars { display:flex; gap:.15rem; color: var(--gold); }
.review__stars svg { width:1.1rem; height:1.1rem; }
.review__text { font-size:1.05rem; color: var(--ink-2); line-height:1.6; flex:1; }
.review__text::before { content:"\201C"; font-family: var(--font-display); }
.review__who { display:flex; align-items:center; gap:.85rem; }
.review__avatar { width:2.7rem; height:2.7rem; border-radius:50%; background: var(--blue-tint); color: var(--blue-700);
  display:grid; place-items:center; font-family: var(--font-display); font-weight:600; font-size:1.05rem; flex:none; }
.review__name { font-weight:700; color: var(--ink); font-size:.97rem; }
.review__meta { font-size:.82rem; color: var(--muted); }
.reviews__nav { display:flex; align-items:center; justify-content:space-between; margin-top:1.6rem; gap:1rem; }
.reviews__dots { display:flex; gap:.45rem; }
.reviews__dots button { width:9px; height:9px; border-radius:50%; background: var(--stone); transition: width .35s var(--ease), background .3s; }
.reviews__dots button.active { width:26px; border-radius:var(--r-pill); background: var(--blue); }
.reviews__arrows { display:flex; gap:.5rem; }
.arrow-btn { width:48px; height:48px; border-radius:50%; background:var(--card); border:1px solid var(--line); display:grid; place-items:center; color:var(--ink); transition: background .3s, color .3s, transform .3s var(--ease); }
.arrow-btn:hover { background: var(--blue); color:#fff; }
.arrow-btn svg { width:1.2rem; height:1.2rem; }

/* placeholder ribbon */
.ph-note { display:inline-flex; align-items:center; gap:.45rem; font-size:.72rem; font-weight:600; color: var(--blue-700);
  background: var(--blue-tint); border:1px dashed var(--blue-tint-2); padding:.3rem .7rem; border-radius: var(--r-pill); }
.ph-note svg{ width:.9rem; height:.9rem; }

/* ---------- Referenzen / Gallery (bento) ---------- */
.gallery { display:grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 200px; gap: clamp(.7rem,1.4vw,1.1rem); }
.gallery__item { position:relative; overflow:hidden; border-radius: var(--r-md); cursor: zoom-in; background: var(--sand); box-shadow: var(--sh-xs); padding:0; width:100%; display:block; font:inherit; color:inherit; }
.gallery__item img { width:100%; height:100%; object-fit:cover; transition: transform .9s var(--ease); }
.gallery__item:hover img { transform: scale(1.07); }
.gallery__item::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 55%, rgba(23,20,15,.45)); opacity:0; transition:opacity .4s; }
.gallery__item:hover::after { opacity:1; }
.gallery__zoom { position:absolute; right:.7rem; bottom:.7rem; z-index:2; width:2.1rem; height:2.1rem; border-radius:50%;
  background: rgba(255,255,255,.92); display:grid; place-items:center; color: var(--ink); opacity:0; transform: translateY(6px); transition: all .4s var(--ease); }
.gallery__item:hover .gallery__zoom { opacity:1; transform: translateY(0); }
.gallery__zoom svg{ width:1.05rem; height:1.05rem; }
.gallery__item.tall { grid-row: span 2; }
.gallery__item.wide { grid-column: span 2; }

/* Lightbox */
.lightbox { position: fixed; inset:0; z-index: var(--z-lightbox); background: rgba(15,13,10,.92); backdrop-filter: blur(8px);
  display:grid; place-items:center; padding: 2rem; opacity:0; visibility:hidden; transition: opacity .35s var(--ease), visibility .35s; }
.lightbox.open { opacity:1; visibility:visible; }
.lightbox img { max-width: min(92vw, 1100px); max-height: 86vh; border-radius: var(--r-md); box-shadow: var(--sh-lg); }
.lightbox__close, .lightbox__prev, .lightbox__next { position:absolute; width:52px; height:52px; border-radius:50%; background: rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.2); color:#fff; display:grid; place-items:center; backdrop-filter: blur(8px); transition: background .3s; }
.lightbox__close:hover,.lightbox__prev:hover,.lightbox__next:hover { background: rgba(255,255,255,.25); }
.lightbox__close { top:1.4rem; right:1.4rem; }
.lightbox__prev { left:1.4rem; top:50%; transform:translateY(-50%); }
.lightbox__next { right:1.4rem; top:50%; transform:translateY(-50%); }
.lightbox svg { width:1.4rem; height:1.4rem; }

/* ---------- Process timeline ---------- */
.process { display:grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.1rem,2.4vw,2rem); position:relative; }
.step { position:relative; }
.step__n { font-family: var(--font-display); font-size: 3.2rem; font-weight:600; color: var(--blue); line-height:1; opacity:.9; }
.step__n small { font-size: 1rem; color: var(--stone); }
.step h3 { margin-top:.6rem; }
.step p { margin-top:.6rem; color: var(--muted); }
.step__line { position:absolute; top: 1.4rem; left: 3.4rem; right: -1rem; height:2px;
  background: repeating-linear-gradient(90deg, var(--stone) 0 6px, transparent 6px 14px); }
.process .step:last-child .step__line { display:none; }

/* ---------- Split feature (image + text) ---------- */
.split { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.8rem,4vw,4.5rem); align-items:center; }
.split.rev .split__media { order: 2; }
.split__media .bezel { box-shadow: var(--sh-md); }
.split__media img { width:100%; aspect-ratio: 5/4; object-fit: cover; }
.split__media.tall img { aspect-ratio: 4/5; }

/* ---------- CTA band ---------- */
.cta-band { position:relative; overflow:hidden; border-radius: var(--r-xl); background: var(--ink); color:#e9e2d6; padding: clamp(2.4rem,5vw,4.5rem); }
.cta-band__bg { position:absolute; inset:0; z-index:0; opacity:.22; object-fit:cover; width:100%; height:100%; }
.cta-band::after { content:""; position:absolute; inset:0; background: linear-gradient(110deg, rgba(23,20,15,.92) 35%, rgba(23,20,15,.55)); z-index:1; }
.cta-band__inner { position:relative; z-index:2; max-width: 640px; }
.cta-band h2 { color:#fff; }
.cta-band p { margin-top:1rem; color:#c9c1b4; }
.cta-band__actions { display:flex; flex-wrap:wrap; gap:.8rem; margin-top:1.8rem; }
.cta-band__phone { display:inline-flex; align-items:baseline; gap:.6rem; margin-top:1.6rem; }
.cta-band__phone .lbl { font-size:.8rem; text-transform:uppercase; letter-spacing:.15em; color:#9c9384; }
.cta-band__phone a { font-family:var(--font-display); font-size: clamp(1.6rem,3vw,2.2rem); color:#fff; }

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(1.6rem,3.5vw,3.2rem); align-items:start; }
.form { background: var(--card); border:1px solid var(--line); border-radius: var(--r-xl); padding: clamp(1.6rem,3vw,2.4rem); box-shadow: var(--sh-sm); }
.form__row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field { display:flex; flex-direction:column; gap:.4rem; margin-top:1rem; }
.field label { font-size:.85rem; font-weight:600; color: var(--ink-2); }
.field input, .field textarea, .field select {
  padding:.85rem 1rem; border-radius: var(--r-md); border:1.5px solid var(--line-strong); background: var(--paper);
  color: var(--ink); transition: border-color .25s, box-shadow .25s, background .25s;
}
.field input:focus, .field textarea:focus, .field select:focus { outline:none; border-color: var(--blue); background:#fff; box-shadow: 0 0 0 4px var(--blue-tint); }
.field textarea { resize: vertical; min-height: 120px; }
.field--error input, .field--error textarea { border-color:#d9663f; }
.field__err { font-size:.78rem; color:#c0512a; display:none; }
.field--error .field__err { display:block; }
.form__consent { display:flex; gap:.6rem; align-items:flex-start; margin-top:1.1rem; font-size:.85rem; color: var(--muted); }
.form__consent input { margin-top:.2rem; accent-color: var(--blue); width:1.05rem; height:1.05rem; }
.form__submit { margin-top:1.4rem; }
.form__note { margin-top:1rem; font-size:.82rem; color:var(--muted); }
.form__success { display:none; padding:1rem 1.2rem; border-radius:var(--r-md); background: rgba(37,211,102,.12); border:1px solid rgba(37,211,102,.35); color:#177a40; font-weight:600; margin-top:1rem; }
.form.sent .form__success { display:block; }

.contact-info { display:flex; flex-direction:column; gap:1rem; }
.info-card { background: var(--card); border:1px solid var(--line); border-radius: var(--r-lg); padding:1.4rem 1.5rem; box-shadow:var(--sh-xs); }
.info-card h3 { font-size:1.15rem; margin-bottom:.3rem; }
.info-row { display:flex; gap:.85rem; align-items:flex-start; padding:.55rem 0; }
.info-row + .info-row { border-top:1px solid var(--line); }
.info-row .ico { width:2.4rem; height:2.4rem; border-radius:var(--r-sm); background: var(--blue-tint); color: var(--blue-700); display:grid; place-items:center; flex:none; }
.info-row .ico svg { width:1.2rem; height:1.2rem; }
.info-row .k { font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; }
.info-row .v { font-weight:600; color: var(--ink); }
.info-row .v a:hover { color: var(--blue-700); }
.hours { display:flex; flex-direction:column; gap:.35rem; margin-top:.4rem; }
.hours__row { display:flex; justify-content:space-between; font-size:.93rem; padding:.25rem 0; }
.hours__row.today { font-weight:700; color: var(--ink); }
.hours__row.today .d { color: var(--blue-700); }
.map-embed { border-radius: var(--r-lg); overflow:hidden; border:1px solid var(--line); box-shadow:var(--sh-xs); }
.map-embed iframe { width:100%; height:240px; border:0; display:block; filter: grayscale(.2) contrast(.95); }

/* Kontakt-Hero: Intro + Formular direkt nebeneinander */
.contact-hero { padding-bottom: clamp(2.6rem,5vw,4rem); }
.contact-hero__grid { display:grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem,3.5vw,3.6rem); align-items:start; margin-top: .4rem; }
.contact-hero__intro h1 { max-width: 15ch; }
.contact-hero__intro > p { margin-top:1.2rem; max-width: 46ch; color: var(--muted); font-size:1.12rem; }
.contact-hero__intro .hero__actions { margin-top: 1.7rem; }
.contact-hero__points { margin-top: 2rem; display:flex; flex-direction:column; gap:.75rem; }
.contact-hero__points li { display:flex; align-items:center; gap:.7rem; font-weight:600; font-size:.98rem; color: var(--ink-2); }
.contact-hero__points li svg { width:1.3rem; height:1.3rem; flex:none; color: var(--blue); }
.form--hero { box-shadow: var(--sh-md); }
.form--hero .section-title { color: var(--ink); }
.contact-info-row { display:grid; grid-template-columns: 1fr 1fr 1.15fr; gap:1.2rem; align-items:stretch; }
.contact-info-row .info-card,
.contact-info-row .map-embed { height:100%; }

/* ---------- Floating action buttons ---------- */
.fab { position: fixed; right: 1.1rem; bottom: 1.1rem; z-index: var(--z-fab); display:flex; flex-direction:column; gap:.7rem; }
.fab__btn { width:56px; height:56px; border-radius:50%; display:grid; place-items:center; color:#fff; box-shadow: var(--sh-md);
  transition: transform .4s var(--ease), box-shadow .4s var(--ease); position:relative; }
.fab__btn:active { transform: scale(.93); }
.fab__btn:hover { transform: translateY(-3px); box-shadow: var(--sh-lg); }
.fab__btn svg { width:1.7rem; height:1.7rem; }
.fab__btn--wa { background: var(--whatsapp); }
.fab__btn--call { background: var(--blue); }
.fab__btn .pulse { position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5); animation: fabpulse 2.4s var(--ease) infinite; }
.fab__btn--call .pulse { box-shadow:0 0 0 0 rgba(27,135,234,.5); animation-name: fabpulseblue; }
@keyframes fabpulse { 70%{ box-shadow:0 0 0 16px rgba(37,211,102,0);} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0);} }
@keyframes fabpulseblue { 70%{ box-shadow:0 0 0 16px rgba(27,135,234,0);} 100%{box-shadow:0 0 0 0 rgba(27,135,234,0);} }
.fab__btn .tip { position:absolute; right:calc(100% + .65rem); top:50%; transform:translateY(-50%); white-space:nowrap;
  background: var(--ink); color:#fff; font-size:.8rem; font-weight:600; padding:.4rem .75rem; border-radius:var(--r-sm);
  opacity:0; pointer-events:none; transition:opacity .3s; }
.fab__btn:hover .tip { opacity:1; }

/* mobile sticky action bar */
.mobile-bar { position: fixed; left:0; right:0; bottom:0; z-index: var(--z-fab); display:none;
  grid-template-columns: 1fr 1fr; gap:1px; background: var(--line);
  border-top:1px solid var(--line); box-shadow: 0 -10px 30px -20px rgba(23,20,15,.4); }
.mobile-bar a { display:flex; align-items:center; justify-content:center; gap:.5rem; padding:.95rem; font-weight:700; font-size:.95rem; background: var(--card); color: var(--ink); }
.mobile-bar a svg { width:1.2rem; height:1.2rem; }
.mobile-bar a.wa { background: var(--whatsapp); color:#04361b; }
.mobile-bar a.call { background: var(--blue); color:#fff; }

/* back to top */
.totop { position:fixed; right:1.1rem; bottom:5.4rem; z-index: var(--z-fab); width:46px; height:46px; border-radius:50%;
  background: var(--card); border:1px solid var(--line); color: var(--ink); display:grid; place-items:center;
  box-shadow: var(--sh-sm); opacity:0; visibility:hidden; transform: translateY(8px); transition: all .4s var(--ease); }
.totop.show { opacity:1; visibility:visible; transform: translateY(0); }
.totop svg { width:1.2rem; height:1.2rem; }

/* ---------- Footer ---------- */
.footer { background: var(--ink); color:#b6ad9e; padding-top: clamp(3.5rem,7vw,5.5rem); position:relative; }
.footer a:hover { color:#fff; }
.footer__grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: clamp(1.6rem,3vw,2.6rem); padding-bottom: 3rem; border-bottom:1px solid rgba(255,255,255,.09); }
.footer__brand img { height:42px; margin-bottom:1.1rem; }
.footer__brand p { color:#9b9384; font-size:.95rem; max-width: 34ch; }
.footer__social { display:flex; gap:.6rem; margin-top:1.3rem; }
.footer__social a { width:42px; height:42px; border-radius:var(--r-sm); background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); display:grid; place-items:center; color:#cfc7b8; transition: background .3s, color .3s; }
.footer__social a:hover { background: var(--blue); color:#fff; }
.footer__social svg { width:1.2rem; height:1.2rem; }
.footer__col h4 { color:#fff; font-family: var(--font-body); font-size:.82rem; text-transform:uppercase; letter-spacing:.14em; font-weight:700; margin-bottom:1.1rem; }
.footer__col ul { display:flex; flex-direction:column; gap:.65rem; }
.footer__col a { color:#b6ad9e; font-size:.95rem; transition: color .25s; }
.footer__contact .row { display:flex; gap:.65rem; align-items:flex-start; margin-bottom:.8rem; font-size:.95rem; }
.footer__contact svg { width:1.1rem; height:1.1rem; color: var(--blue); flex:none; margin-top:.2rem; }
.footer__bottom { display:flex; flex-wrap:wrap; gap:1rem; justify-content:space-between; align-items:center; padding-block: 1.6rem; font-size:.85rem; color:#857d6f; }
.footer__bottom a { color:#9b9384; }
.footer__bottom .legal { display:flex; gap:1.2rem; flex-wrap:wrap; }
.footer__credit { font-size:.8rem; }
.footer__credit a { color: #bcdcfb; font-weight:600; }

/* ---------- Scroll reveal ---------- */
.reveal { opacity:0; transform: translateY(26px); filter: blur(6px); transition: opacity .9s var(--ease-out), transform .9s var(--ease-out), filter .9s var(--ease-out); }
.reveal.in { opacity:1; transform: none; filter: none; }
.reveal[data-d="1"]{ transition-delay:.08s; } .reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; } .reveal[data-d="4"]{ transition-delay:.32s; }
.reveal[data-d="5"]{ transition-delay:.4s; }

/* ---------- Page hero (sub pages) ---------- */
.pagehero { padding-block: clamp(2.6rem,5vw,4rem) clamp(2rem,4vw,3.2rem); position:relative; }
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.85rem; color: var(--muted); margin-bottom:1.3rem; flex-wrap:wrap; }
.breadcrumb a:hover { color: var(--blue-700); }
.breadcrumb svg { width:.85rem; height:.85rem; opacity:.6; }
.pagehero h1 { font-size: clamp(2.3rem,5vw,4rem); max-width: 16ch; }
.pagehero p { margin-top:1.2rem; max-width: 56ch; color: var(--muted); font-size:1.12rem; }

/* prose for legal pages */
.prose { max-width: 760px; }
.prose h2 { font-size: clamp(1.4rem,2.6vw,1.9rem); margin: 2.2rem 0 .8rem; }
.prose h3 { font-size:1.15rem; margin:1.6rem 0 .5rem; }
.prose p, .prose li { color: var(--text); font-size:1.02rem; line-height:1.75; }
.prose p { margin-bottom: 1rem; }
.prose ul { list-style: disc; padding-left:1.3rem; margin-bottom:1rem; display:flex; flex-direction:column; gap:.4rem; }
.prose a { color: var(--blue-700); border-bottom:1px solid var(--blue-tint-2); }
.prose strong { color: var(--ink); }

/* FAQ accordion */
.faq { max-width: 820px; margin-inline:auto; display:flex; flex-direction:column; gap:.8rem; }
.faq__item { background: var(--card); border:1px solid var(--line); border-radius: var(--r-md); overflow:hidden; transition: box-shadow .3s; }
.faq__item[open] { box-shadow: var(--sh-sm); }
.faq__q { display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.15rem 1.4rem; cursor:pointer; font-weight:600; color: var(--ink); font-size:1.05rem; list-style:none; }
.faq__q::-webkit-details-marker { display:none; }
.faq__q .pm { width:1.6rem; height:1.6rem; flex:none; position:relative; color: var(--blue); transition: transform .4s var(--ease); }
.faq__item[open] .faq__q .pm { transform: rotate(45deg); }
.faq__q .pm::before,.faq__q .pm::after { content:""; position:absolute; background: currentColor; border-radius:2px; }
.faq__q .pm::before { top:50%; left:2px; right:2px; height:2px; transform:translateY(-50%); }
.faq__q .pm::after { left:50%; top:2px; bottom:2px; width:2px; transform:translateX(-50%); }
.faq__a { padding: 0 1.4rem 1.3rem; color: var(--muted); }

/* trust logos / sectors */
.sectors { display:flex; flex-wrap:wrap; gap:.7rem; }
.sectors li { display:inline-flex; align-items:center; gap:.55rem; padding:.6rem 1.1rem; background:var(--card); border:1px solid var(--line); border-radius: var(--r-pill); font-weight:600; font-size:.92rem; color: var(--ink-2); }
.sectors li svg { width:1.1rem; height:1.1rem; color: var(--blue); }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__media { max-width: 540px; margin-inline:auto; order:-1; }
  .cards { grid-template-columns: repeat(2,1fr); }
  .stats { grid-template-columns: repeat(2,1fr); row-gap:2.2rem; }
  .gallery { grid-template-columns: repeat(3,1fr); }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
/* Nav kollabiert früher zum Burger, damit das größere Logo nie mit den Links kollidiert */
@media (max-width: 1180px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: grid; }
  .nav__logo img { height: 66px; }
}
@media (max-width: 860px) {
  .ba-wrap, .split, .split.rev { grid-template-columns: 1fr; }
  .split.rev .split__media { order:0; }
  .process { grid-template-columns: 1fr; gap:1.6rem; }
  .step__line { display:none; }
  .contact-grid { grid-template-columns: 1fr; }
  .contact-hero__grid { grid-template-columns: 1fr; gap: 1.8rem; }
  .contact-hero__intro h1, .contact-hero__intro > p { max-width: none; }
  .contact-info-row { grid-template-columns: 1fr; }
  .mobile-bar { display:grid; }
  .mobile-bar a { padding-bottom: calc(.95rem + env(safe-area-inset-bottom)); }
  .fab { display:none; }                 /* Mobile: Bar deckt beide Aktionen ab */
  .totop { bottom: calc(66px + env(safe-area-inset-bottom)); }
  body { padding-bottom: calc(70px + env(safe-area-inset-bottom)); }
}
@media (max-width: 560px) {
  .cards { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2,1fr); }
  .gallery { grid-template-columns: repeat(2,1fr); grid-auto-rows: 150px; grid-auto-flow: dense; }
  .gallery__item.tall, .gallery__item.wide { grid-row: auto; grid-column: auto; }
  .form__row { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; }
  .hero__badge--tl { top:-12px; left:50%; transform: translateX(-50%); }
  .hero__badge--br { right:8px; }
  .reviews__nav { flex-direction: column-reverse; align-items: stretch; gap:1.2rem; }
  .reviews__arrows { justify-content:center; }
}


/* ============================================================
   FULL-BLEED HERO — Slideshow (Crossfade) + Ken Burns
   ============================================================ */

/* Nav: transparent über dem Hero, solide beim Scrollen */
.nav__logo-light { display: none; }
.nav--overlay:not(.scrolled) {
  background: transparent;
  backdrop-filter: none; -webkit-backdrop-filter: none;
  border-bottom-color: transparent;
  box-shadow: none;
}
.nav--overlay:not(.scrolled) .nav__logo-dark { display: none; }
.nav--overlay:not(.scrolled) .nav__logo-light { display: block; }
.nav--overlay:not(.scrolled) .nav__link { color: rgba(255,255,255,.92); }
.nav--overlay:not(.scrolled) .nav__link:hover { color: #fff; }
.nav--overlay:not(.scrolled) .nav__phone { color: #fff; }
.nav--overlay:not(.scrolled) .nav__phone svg { color: #fff; }
.nav--overlay:not(.scrolled) .nav__link,
.nav--overlay:not(.scrolled) .nav__phone { text-shadow: 0 1px 14px rgba(0,0,0,.45); }
.nav--overlay:not(.scrolled) .nav__has-sub > .nav__link svg { color: #fff; }
.nav--overlay:not(.scrolled) .nav__burger { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.28); }
.nav--overlay:not(.scrolled) .burger-box span { background: #fff; }

.hero-full {
  position: relative;
  min-height: 100svh;
  margin-top: calc(-1 * var(--nav-h));
  padding-top: var(--nav-h);
  display: flex; align-items: center;
  overflow: hidden;
  background: var(--ink);
  isolation: isolate;
}
.hero-slides { position: absolute; inset: 0; z-index: 0; background: var(--ink) url("../img/hero/hero-video-poster.webp") center/cover no-repeat; }
.hero-video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-video--mobile { display: none; }
@media (max-width: 768px) {
  .hero-video--desktop { display: none; }
  .hero-video--mobile { display: block; }
}
.hero-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 1.5s ease-in-out; }
.hero-slide.is-active { opacity: 1; }
.hero-slide__img {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transform: scale(1.06);
  animation: kenburns 22s ease-in-out infinite alternate;
  will-change: transform;
}
.hero-slide:nth-child(2n) .hero-slide__img { animation-name: kenburns2; }
.hero-slide:nth-child(3n) .hero-slide__img { animation-name: kenburns3; }
@keyframes kenburns  { from { transform: scale(1.06) translate(0,0); }      to { transform: scale(1.2) translate(-2.5%,-1.5%); } }
@keyframes kenburns2 { from { transform: scale(1.2) translate(2%,1.5%); }   to { transform: scale(1.06) translate(0,0); } }
@keyframes kenburns3 { from { transform: scale(1.08) translate(-1.5%,1%); } to { transform: scale(1.2) translate(1.5%,-1%); } }

.hero-full__overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to bottom, rgba(11,9,6,.5) 0%, rgba(11,9,6,.12) 13%, rgba(11,9,6,0) 24%),
    linear-gradient(100deg, rgba(11,9,6,.86) 0%, rgba(11,9,6,.58) 42%, rgba(11,9,6,.28) 76%, rgba(11,9,6,.48) 100%),
    linear-gradient(to top, rgba(11,9,6,.72) 0%, rgba(11,9,6,0) 40%);
}
.hero-full__inner { position: relative; z-index: 2; width: 100%; padding-block: clamp(2.5rem,7vh,6rem); }
.hero-full__content { max-width: 660px; color: #fff; }
.hero-full__content h1 { color: #fff; margin: 1.4rem 0 0; text-shadow: 0 2px 30px rgba(0,0,0,.3); }
.hero-full__content h1 .blue { color: #4aa6f5; }
.hero-full__sub { margin-top: 1.5rem; max-width: 40ch; color: rgba(255,255,255,.9); }
.hero-full .hero__usp { margin-top: 1.7rem; }
.hero-full .hero__usp li {
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.22);
  color: #fff; box-shadow: none; backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.hero-full .hero__usp svg { color: #7cc0ff; }
.hero-full__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.hero-full__trust { display: flex; align-items: center; gap: 1rem; margin-top: 2rem; flex-wrap: wrap; }
.hero-full__trust .hero__stars { display: flex; gap: .15rem; color: var(--gold); }
.hero-full__trust .hero__stars svg { width: 1.05rem; height: 1.05rem; }
.hero-full__trust-txt { font-size: .9rem; color: rgba(255,255,255,.85); }
.hero-full__trust-txt strong { color: #fff; }

.hero-full__scroll {
  position: absolute; left: 50%; bottom: 1.5rem; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: .35rem;
  color: rgba(255,255,255,.75); font-size: .68rem; text-transform: uppercase; letter-spacing: .22em; font-weight: 600;
}
.hero-full__scroll svg { width: 1.4rem; height: 1.4rem; animation: scrollbob 2s var(--ease) infinite; }
@keyframes scrollbob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(5px); } }

@media (max-width: 560px) {
  .hero-full__scroll { display: none; }
  .hero-full__content h1 { margin-top: 1rem; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-slide { transition: none; }
  .hero-slide__img { animation: none; transform: scale(1.03); }
  .hero-full__scroll svg { animation: none; }
  .hero-video { display: none; }
}

/* ============================================================
   REFERENZEN — Marquee-Galerie (3 Reihen, Drag, Fade) + Lightbox
   ============================================================ */
.rgallery {
  position: relative;
  display: grid; gap: 14px;
  padding: 16px 0;
  margin-top: clamp(2rem, 4vw, 3.2rem);
  touch-action: pan-y;
  overflow-x: clip;          /* Marquee horizontal clippen, Hover-Lift bleibt sichtbar */
}
.rgallery__row {
  display: flex; gap: 14px;
  width: max-content;
  will-change: transform;
  animation: rg-marquee 90s linear infinite;
  cursor: grab;
  user-select: none; -webkit-user-select: none;
}
.rgallery__row[data-speed="slow"] { animation-duration: 130s; }
.rgallery__row--right { animation-direction: reverse; }
.rgallery__row:hover { animation-play-state: paused; }   /* nur die Reihe unter der Maus pausiert */
.rgallery__row.is-manual { animation: none !important; }
.rgallery__row.is-dragging { cursor: grabbing; }
.rgallery__row.is-resetting { transition: transform .6s var(--ease); }
.rgallery__row.is-dragging .rgallery__item img { pointer-events: none; }
@keyframes rg-marquee {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-50%, 0, 0); }
}
.rgallery__item {
  flex: 0 0 auto;
  height: 280px;
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--sand);
  cursor: zoom-in;
  position: relative;
  padding: 0; width: auto; border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
  transition: transform .35s var(--ease), box-shadow .35s ease;
}
.rgallery__item:hover { transform: translateY(-3px); box-shadow: var(--sh-md); }
.rgallery__item img {
  height: 100%; width: auto; display: block;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
  -webkit-user-drag: none; user-drag: none;
}
.rgallery__item:hover img { transform: scale(1.05); }
.rgallery__fade {
  position: absolute; top: 0; bottom: 0; width: clamp(48px, 7vw, 130px); z-index: 2;
  pointer-events: none;
}
.rgallery__fade--l { left: 0;  background: linear-gradient(90deg,  var(--paper) 0%, transparent 100%); }
.rgallery__fade--r { right: 0; background: linear-gradient(270deg, var(--paper) 0%, transparent 100%); }
/* Über dem Marmor-Band: Ränder als weicher Elfenbein-Verlauf statt Papierstreifen */
.bg-marble .rgallery__fade--l { background: linear-gradient(90deg, #f2ecdf 0%, rgba(242,236,223,.5) 45%, transparent 100%); }
.bg-marble .rgallery__fade--r { background: linear-gradient(270deg, #f2ecdf 0%, rgba(242,236,223,.5) 45%, transparent 100%); }

@media (max-width: 1024px) {
  .rgallery__item { height: 230px; }
  .rgallery__row { animation-duration: 70s; }
  .rgallery__row[data-speed="slow"] { animation-duration: 100s; }
}
@media (max-width: 640px) {
  .rgallery { gap: 10px; padding: 10px 0; }
  .rgallery__row { gap: 10px; animation-duration: 55s; }
  .rgallery__row[data-speed="slow"] { animation-duration: 80s; }
  .rgallery__item { height: 185px; border-radius: var(--r-sm); }
}
@media (prefers-reduced-motion: reduce) {
  .rgallery__row { animation: none; }
}

/* ============================================================
   BEWERTUNGEN — durchlaufendes Endlos-Band (rAF), Drag-Scrub
   ============================================================ */
.rmarquee {
  position: relative;
  overflow-x: clip;
  padding: 18px 0;
  margin-top: clamp(2rem, 4vw, 3rem);
  touch-action: pan-y;
}
.rmarquee__track {
  display: flex; gap: 1.4rem;
  width: max-content;
  will-change: transform;
  cursor: grab;
  user-select: none; -webkit-user-select: none;
  align-items: stretch;
}
.rmarquee__track.is-dragging { cursor: grabbing; }
.rmarquee__track.is-dragging .rcard { pointer-events: none; }

.rcard {
  flex: 0 0 clamp(290px, 82vw, 400px);
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 1.7rem 1.6rem;
  box-shadow: var(--sh-sm);
  display: flex; flex-direction: column; gap: 1rem;
}
.rcard .review__stars { display: flex; gap: .15rem; color: var(--gold); }
.rcard .review__stars svg { width: 1.05rem; height: 1.05rem; }
.rcard__text { font-size: 1.02rem; color: var(--ink-2); line-height: 1.6; flex: 1; }
.rcard__text::before { content: "\201C"; font-family: var(--font-display); }
.rcard__who { display: flex; align-items: center; gap: .85rem; margin-top: .2rem; }
.rcard__avatar {
  width: 2.7rem; height: 2.7rem; border-radius: 50%;
  background: var(--blue-tint); color: var(--blue-700);
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 600; font-size: 1.05rem; flex: none;
}
.rcard__name { font-weight: 700; color: var(--ink); font-size: .97rem; }
.rcard__meta { font-size: .82rem; color: var(--muted); }

.rmarquee__fade {
  position: absolute; top: 0; bottom: 0; width: clamp(40px, 8vw, 130px); z-index: 2; pointer-events: none;
}
.rmarquee__fade--l { left: 0;  background: linear-gradient(90deg,  var(--paper-2) 0%, transparent 100%); }
.rmarquee__fade--r { right: 0; background: linear-gradient(270deg, var(--paper-2) 0%, transparent 100%); }

@media (max-width: 640px) {
  .rmarquee { padding: 12px 0; }
  .rmarquee__track { gap: 1rem; }
  .rcard { padding: 1.4rem 1.3rem; }
}

/* ============================================================
   DIE VERWANDLUNG — gepinnte Cinematic-Sektion (Scrub / Video)
   ============================================================ */
.verwandlung { position: relative; height: 440vh; background: var(--ink); }
.verwandlung__sticky {
  position: sticky; top: 0; height: 100svh; overflow: hidden;
  display: flex; align-items: flex-end;
}
.verwandlung__media {
  position: absolute; inset: 0; z-index: 0;
  background: var(--ink) url("../img/verwandlung/poster.webp") center/cover no-repeat;
}
.verwandlung__video, .verwandlung__canvas {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block;
}
.verwandlung__canvas { display: none; }        /* nur Desktop-Scrub via JS */
.verwandlung__overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(to top, rgba(11,9,6,.9) 0%, rgba(11,9,6,.35) 42%, rgba(11,9,6,.12) 68%, rgba(11,9,6,.5) 100%),
    linear-gradient(105deg, rgba(11,9,6,.6) 0%, rgba(11,9,6,0) 55%);
}
.verwandlung__inner { position: relative; z-index: 2; width: 100%; padding-bottom: clamp(3rem, 9vh, 6.5rem); }
.verwandlung__steps { position: relative; min-height: 260px; max-width: 640px; }
.v-step {
  position: absolute; left: 0; right: 0; bottom: 0;
  opacity: 0; transform: translateY(26px); filter: blur(4px);
  transition: opacity .7s var(--ease), transform .7s var(--ease), filter .7s var(--ease);
  pointer-events: none; color: #fff;
}
.v-step.is-active { opacity: 1; transform: none; filter: none; pointer-events: auto; }
.v-step__nr { font-family: var(--font-display); font-size: 1.15rem; color: #7cc0ff; letter-spacing: .08em; font-weight: 600; }
.v-step__nr small { color: rgba(255,255,255,.5); }
.v-step__title { color: #fff; font-size: clamp(2.5rem, 5.5vw, 4.4rem); margin: .35rem 0 .7rem; text-shadow: 0 2px 30px rgba(0,0,0,.35); }
.v-step__desc { color: rgba(255,255,255,.92); font-size: clamp(1.05rem, 1.6vw, 1.3rem); max-width: 46ch; line-height: 1.55; }
.v-step__link { margin-top: 1.2rem; color: #bcdcfb; border-color: transparent; }
.v-step__link:hover { color: #fff; border-color: #fff; }
.verwandlung__bar { position: relative; margin-top: 2.2rem; height: 3px; background: rgba(255,255,255,.18); border-radius: 2px; overflow: hidden; max-width: 640px; }
.verwandlung__bar span { display: block; height: 100%; width: 0; background: var(--blue); border-radius: 2px; transition: width .1s linear; }

@media (max-width: 768px) {
  .verwandlung { height: 380vh; }
  .verwandlung__steps { min-height: 300px; }
}

/* Statisch bei reduzierter Bewegung: kein Pin, kein Video, Standbild + alle Schritte */
@media (prefers-reduced-motion: reduce) {
  .verwandlung { height: auto; }
  .verwandlung__sticky { position: static; height: auto; display: block; }
  .verwandlung__media { position: relative; height: 56vh; }
  .verwandlung__video, .verwandlung__canvas { display: none; }
  .verwandlung__inner { padding-block: clamp(2.5rem,6vw,4rem); }
  .verwandlung__steps { min-height: 0; display: flex; flex-direction: column; gap: 2.2rem; }
  .v-step { position: static; opacity: 1; transform: none; filter: none; pointer-events: auto; }
  .verwandlung__bar { display: none; }
}

/* ============================================================
   EINZUGSGEBIET-HUB + Footer-Standorte (bundesweite Städte)
   ============================================================ */
/* Einzugsgebiet: volles Hero-Bild (16:9) + 4er Streifen darunter */
.ezg-hero { position: relative; width: 100%; aspect-ratio: 16/9; overflow: hidden; margin-block: clamp(2rem, 4vw, 3rem); background: var(--card-2); }
.ezg-hero img { width: 100%; height: 100%; object-fit: cover; object-position: center 38%; display: block; }
.ezg-hero::after { content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(23,20,15,0) 60%, rgba(23,20,15,.18) 100%); }
.ezg-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(.7rem, 1.4vw, 1.1rem); }
.ezg-strip__item { position: relative; overflow: hidden; border-radius: var(--r-lg); aspect-ratio: 4/3; border: 1px solid var(--line); box-shadow: var(--sh-sm); background: var(--card-2); }
.ezg-strip__item img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease); }
.ezg-strip__item:hover img { transform: scale(1.06); }
@media (max-width: 860px) {
  .ezg-hero { aspect-ratio: 4/3; }
  .ezg-strip { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .ezg-hero { aspect-ratio: 1/1; }
}

/* Städte-Verzeichnis: Karten je Bundesland, NRW als volle Breite mit eigener Spaltenzahl */
.ezg-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: clamp(1.1rem, 2.2vw, 1.7rem); align-items: start; }
.ezg-group { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-lg); padding: 1.5rem 1.6rem; box-shadow: var(--sh-xs); }
.ezg-group--featured { grid-column: 1 / -1; background: linear-gradient(155deg, var(--card), var(--card-2)); }
.ezg-group__head { display: flex; align-items: flex-start; justify-content: space-between; gap: .7rem; margin-bottom: 1.1rem; padding-bottom: .6rem; border-bottom: 2px solid var(--blue); }
.ezg-group__bl { font-size: 1.15rem; color: var(--ink); line-height: 1.25; }
.ezg-group__count { flex: none; white-space: nowrap; margin-top: .2rem; font-family: var(--font-body); font-size: .76rem; font-weight: 700; letter-spacing: .02em; color: var(--blue-700); background: var(--blue-tint); padding: .3em .75em; border-radius: var(--r-pill); }
.ezg-list { display: block; }
.ezg-list li { margin-bottom: .15rem; }
.ezg-list a { color: var(--ink-2); font-weight: 600; font-size: 1rem; transition: color .2s, background .2s; display: flex; align-items: center; gap: .6rem; padding: .42rem .55rem; margin-inline: -.55rem; border-radius: var(--r-sm); }
.ezg-list a::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--blue-tint-2); flex: none; transition: background .2s; }
.ezg-list a:hover { color: var(--blue-700); background: var(--blue-tint); }
.ezg-list a:hover::before { background: var(--blue); }
.ezg-list--cols2 { columns: 2; column-gap: 1.2rem; }
.ezg-list--cols2 li { break-inside: avoid; }
.ezg-group--featured .ezg-list--wide { columns: 4 160px; column-gap: 1.4rem; }
.ezg-group--featured .ezg-list--wide li { break-inside: avoid; }
@media (max-width: 700px) {
  .ezg-group--featured .ezg-list--wide { columns: 2 140px; }
}
@media (max-width: 420px) {
  .ezg-list--cols2 { columns: 1; }
}

.footer__standorte { padding: 2.2rem 0 .4rem; margin-top: 1rem; border-top: 1px solid rgba(255,255,255,.09); }
.footer__standorte h4 { color: #fff; font-family: var(--font-body); font-size: .82rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 700; margin-bottom: 1rem; }
.footer__standorte ul { display: flex; flex-wrap: wrap; gap: .55rem 1rem; align-items: center; }
.footer__standorte a { color: #b6ad9e; font-size: .92rem; transition: color .25s; }
.footer__standorte a:hover { color: #fff; }
.footer__standorte .ezg-more { color: #bcdcfb; font-weight: 600; display: inline-flex; align-items: center; gap: .35rem; }
.footer__standorte .ezg-more svg { width: 1rem; height: 1rem; }

/* ============================================================================
   Google-Ads Landingpage (natursteinsanierung.html) – conversion-optimiert
   Kein Nav-Menü, ein Ziel: WhatsApp/Anruf + schlankes Formular
   ============================================================================ */
.lp-head { position: sticky; top: 0; z-index: var(--z-nav, 100); background: rgba(246,242,236,.86);
  backdrop-filter: saturate(140%) blur(12px); -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--line); }
.lp-head__inner { max-width: var(--container); margin-inline: auto; padding: .7rem var(--gut);
  display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.lp-head__logo img { height: 38px; width: auto; display: block; }
.lp-head__phone { display: inline-flex; align-items: center; gap: .6rem; color: var(--ink);
  padding: .4rem .5rem; border-radius: var(--r-pill); transition: color .2s var(--ease); }
.lp-head__phone:hover { color: var(--blue-700); }
.lp-head__ico { display: grid; place-items: center; width: 40px; height: 40px; flex: none;
  border-radius: 50%; background: var(--blue-tint); color: var(--blue-700); }
.lp-head__ico svg { width: 20px; height: 20px; }
.lp-head__num { display: flex; flex-direction: column; line-height: 1.12; }
.lp-head__num small { font-size: .68rem; color: var(--muted); font-weight: 500; letter-spacing: .01em; }
.lp-head__num strong { font-size: 1.06rem; font-weight: 700; letter-spacing: -.01em; }

/* Hero */
.lp-hero { position: relative; padding: clamp(2.2rem, 5vw, 4.2rem) 0 clamp(2.6rem, 5vw, 4.4rem);
  background:
    radial-gradient(120% 90% at 82% 0%, rgba(27,135,234,.07), transparent 60%),
    linear-gradient(180deg, var(--card-2), var(--paper)); overflow: hidden; }
.lp-hero__inner { max-width: var(--container); margin-inline: auto; padding-inline: var(--gut);
  display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(1.6rem, 4vw, 3.6rem); align-items: center; }
.lp-hero__h1 { font-size: clamp(2.5rem, 5.6vw, 4.3rem); line-height: 1.02; letter-spacing: -.015em;
  margin: 1rem 0 .2rem; }
.lp-hero__sub { font-size: clamp(1.05rem, 1.7vw, 1.28rem); color: var(--text); max-width: 33ch; margin-top: .8rem; }
.lp-hero__offer { display: flex; align-items: flex-start; gap: .55rem; margin-top: 1.15rem;
  font-size: 1.02rem; color: var(--ink-2); }
.lp-hero__offer svg { width: 22px; height: 22px; color: var(--blue); flex: none; margin-top: 1px; }
.lp-hero__cta { display: flex; flex-wrap: wrap; gap: .75rem; margin-top: 1.7rem; }
.lp-trust { list-style: none; display: flex; flex-wrap: wrap; gap: .55rem 1.4rem; margin-top: 1.8rem;
  padding-top: 1.5rem; border-top: 1px solid var(--line); }
.lp-trust li { display: inline-flex; align-items: center; gap: .4rem; font-size: .92rem;
  font-weight: 600; color: var(--ink-2); }
.lp-trust li svg { width: 18px; height: 18px; color: var(--blue); flex: none; }
.lp-trust__stars { display: inline-flex; }
.lp-trust__stars svg { width: 16px; height: 16px; color: var(--gold); }
.lp-trust li strong { font-weight: 700; }

.lp-hero__media { position: relative; }
.lp-hero__frame { position: relative; border-radius: var(--r-xl); overflow: hidden;
  background: var(--card); padding: 8px; border: 1px solid var(--line-strong);
  box-shadow: var(--sh-lg), var(--inset-hi); }
/* Hero-Karussell (Cross-Fade) */
.lp-carousel__stage { position: relative; width: 100%; aspect-ratio: 4/3.4; overflow: hidden;
  border-radius: calc(var(--r-xl) - 8px); background: var(--card-2); }
.lp-carousel__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
  opacity: 0; transition: opacity .9s var(--ease); will-change: opacity; }
.lp-carousel__img.is-active { opacity: 1; }
.lp-carousel__dots { position: absolute; left: 0; right: 0; bottom: 14px; z-index: 2;
  display: flex; gap: .5rem; justify-content: center; }
.lp-carousel__dot { width: 9px; height: 9px; padding: 0; border: 0; border-radius: var(--r-pill);
  cursor: pointer; background: rgba(255,255,255,.55); box-shadow: 0 1px 4px rgba(23,20,15,.35);
  transition: width .35s var(--ease), background .35s var(--ease); }
.lp-carousel__dot.is-active { width: 24px; background: #fff; }
.lp-carousel__dot:hover { background: rgba(255,255,255,.85); }
@media (prefers-reduced-motion: reduce) { .lp-carousel__img { transition: none; } }
.lp-hero__badge { position: absolute; left: -14px; bottom: 26px; display: flex; align-items: center; gap: .6rem;
  background: var(--card); border: 1px solid var(--line); box-shadow: var(--sh-md);
  padding: .8rem 1.05rem; border-radius: var(--r-md); font-size: .9rem; line-height: 1.2; max-width: 62%; }
.lp-hero__badge svg { width: 26px; height: 26px; color: var(--whatsapp-d); flex: none; }
.lp-hero__badge strong { font-weight: 700; color: var(--ink); }
.lp-hero__badge span { color: var(--muted); }

/* Leistungen (Nutzen-Karten) */
.lp-servs__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2vw, 1.6rem); }
.lp-serv { display: flex; flex-direction: column; background: var(--card); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--sh-sm); }
.lp-serv__media { aspect-ratio: 16/10; overflow: hidden; }
.lp-serv__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.lp-serv:hover .lp-serv__media img { transform: scale(1.05); }
.lp-serv__body { padding: 1.3rem 1.4rem 1.5rem; display: flex; flex-direction: column; gap: .5rem; flex: 1; }
.lp-serv__body h3 { font-size: 1.5rem; }
.lp-serv__body p { color: var(--muted); font-size: .98rem; flex: 1; }
.lp-serv__tag { display: inline-flex; align-items: center; gap: .4rem; margin-top: .3rem; font-weight: 600;
  font-size: .82rem; color: var(--blue-700); }
.lp-serv__tag svg { width: 16px; height: 16px; }

/* 3 Schritte */
.lp-steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1rem, 2.4vw, 2rem); }
.lp-step { display: flex; gap: 1rem; align-items: flex-start; }
.lp-step__num { flex: none; display: grid; place-items: center; width: 46px; height: 46px; border-radius: 50%;
  background: var(--blue); color: #fff; font-family: var(--font-display); font-size: 1.5rem; font-weight: 700;
  box-shadow: var(--sh-blue); }
.lp-step h3 { font-size: 1.4rem; margin-bottom: .2rem; }
.lp-step p { color: var(--muted); font-size: .96rem; }
.lp-steps__cta { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 1rem;
  margin-top: clamp(2rem, 4vw, 3rem); }
.lp-steps__or { color: var(--muted); font-size: .9rem; }

/* FAQ (native accordion) */
.lp-faq { display: flex; flex-direction: column; gap: .7rem; }
.lp-faq__item { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-md);
  padding: 0 1.3rem; box-shadow: var(--sh-xs); transition: border-color .25s var(--ease); }
.lp-faq__item[open] { border-color: var(--blue-tint-2); }
.lp-faq__item summary { list-style: none; cursor: pointer; display: flex; align-items: center; gap: 1rem;
  justify-content: space-between; padding: 1.15rem 0; font-weight: 700; font-size: 1.08rem; color: var(--ink); }
.lp-faq__item summary::-webkit-details-marker { display: none; }
.lp-faq__item summary::after { content: ""; flex: none; width: 22px; height: 22px; position: relative;
  background:
    linear-gradient(var(--blue), var(--blue)) center/13px 2px no-repeat,
    linear-gradient(var(--blue), var(--blue)) center/2px 13px no-repeat;
  transition: transform .3s var(--ease); }
.lp-faq__item[open] summary::after { transform: rotate(135deg); }
.lp-faq__a { padding: 0 0 1.25rem; color: var(--text); }
.lp-faq__a p { max-width: 66ch; }

/* Finaler CTA + Formular (dunkle Sektion, helle Formkarte) */
.lp-final { background: var(--ink); color: #d9d2c6; }
.lp-final .section-title { color: #fbf8f2; }
.lp-final__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.6rem, 4vw, 3.4rem); align-items: center; }
.lp-final__copy p { color: #c3bcb0; margin-top: .6rem; max-width: 40ch; }
.lp-final__cta { display: flex; flex-wrap: wrap; gap: .75rem; margin: 1.5rem 0 1.6rem; }
.lp-final__checks { gap: .55rem; }
.lp-final__checks li { color: #e7e1d7; }
.lp-final__checks svg { color: var(--blue); }
.lp-form { background: var(--card); color: var(--text); border-radius: var(--r-xl);
  padding: clamp(1.5rem, 3vw, 2.3rem); box-shadow: var(--sh-lg); border: 1px solid var(--line-strong); }
.lp-form h3 { font-size: 1.7rem; }
.lp-form__sub { color: var(--muted); margin: .25rem 0 1.2rem; font-size: .95rem; }
.lp-form__opt { color: var(--muted); font-weight: 500; }
.lp-form__alt { margin-top: 1rem; text-align: center; font-size: .92rem; color: var(--muted); }
.lp-form__alt a { color: var(--blue-700); font-weight: 700; }

/* Minimaler Footer */
.lp-foot { background: var(--ink); color: #a89f90; padding: clamp(2.2rem, 4vw, 3.2rem) 0 2.2rem;
  border-top: 1px solid rgba(255,255,255,.08); }
.lp-foot__inner { display: grid; gap: 1.6rem; }
.lp-foot__brand img { height: 42px; width: auto; margin-bottom: .7rem; }
.lp-foot__brand p { max-width: 46ch; font-size: .92rem; }
.lp-foot__contact { display: flex; flex-wrap: wrap; gap: .8rem 1.6rem; }
.lp-foot__contact a { display: inline-flex; align-items: center; gap: .5rem; color: #e7e1d7; font-weight: 600; }
.lp-foot__contact a:hover { color: #fff; }
.lp-foot__contact svg { width: 18px; height: 18px; color: var(--blue); }
.lp-foot__legal { display: flex; flex-wrap: wrap; gap: .5rem 1.4rem; align-items: center;
  padding-top: 1.4rem; border-top: 1px solid rgba(255,255,255,.08); font-size: .86rem; }
.lp-foot__legal a { color: #a89f90; }
.lp-foot__legal a:hover { color: #fff; }

/* Responsive */
@media (max-width: 980px) {
  .lp-hero__inner { grid-template-columns: 1fr; }
  .lp-hero__media { order: -1; max-width: 520px; }
  .lp-hero__sub { max-width: none; }
  .lp-servs__grid { grid-template-columns: 1fr 1fr; }
  .lp-steps { grid-template-columns: 1fr; gap: 1.3rem; }
  .lp-final__grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .lp-head__num small { display: none; }
  .lp-head__phone { gap: .45rem; }
  .lp-hero__cta .btn, .lp-steps__cta .btn, .lp-final__cta .btn { flex: 1 1 100%; justify-content: center; }
  .lp-steps__or { flex: 1 1 100%; text-align: center; }
  .lp-servs__grid { grid-template-columns: 1fr; }
  .lp-hero__badge { left: 10px; }
}

.lp-main { overflow-x: clip; }

/* LP – echte-Fakten-Strip (ersetzt Platzhalter-Statistiken) */
.lp-facts__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1.2rem, 3vw, 2.6rem); }
.lp-fact { text-align: center; }
.lp-fact__num { font-family: var(--font-display); font-weight: 700; color: #fbf8f2;
  font-size: clamp(1.7rem, 3.2vw, 2.5rem); line-height: 1.05; letter-spacing: -.01em; }
.lp-fact__lbl { color: #b7afa0; margin-top: .5rem; font-size: .92rem; }
@media (max-width: 760px) { .lp-facts__grid { grid-template-columns: 1fr 1fr; gap: 1.6rem 1.2rem; } }
