/* ============================================================
   OLYMP Startseite v3 — weich/rund, immersiv, dynamisch
   (Design-Sprache angelehnt an Referenz, OLYMP-Marke: Beige/Burgunder/Anthrazit)
   Eigenständiges Stylesheet (lädt OHNE style.css). scoped via body.v3
   ============================================================ */
:root{
  --canvas:#f4efe8; --canvas-2:#fbf8f3; --white:#fff;
  --ink:#211f1c; --muted:#6e6a63; --line:#e7e1d6;
  --burg:#924545; --burg-dk:#7a3838; --dark:#1c1a17; --sand:#dacdbc;
  --r-pill:999px; --r-lg:26px; --r-md:18px; --r-sm:12px;
  --fd:'Hanken Grotesk',-apple-system,sans-serif;
  --fb:'Inter',-apple-system,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --max:1200px;
}
*{box-sizing:border-box;}
html{ scroll-behavior:smooth; }
body.v3{ margin:0; font-family:var(--fb); color:var(--ink); background:var(--canvas); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
.v3 section[id], #leistungen, #kontakt, #angebote, #kaeufer-pool{ scroll-margin-top:84px; }
/* Tastatur-Fokus sichtbar (Quality-Floor) */
.v3 a:focus-visible, .v3 button:focus-visible, .v3 input:focus-visible, .v3 select:focus-visible{ outline:2px solid var(--burg); outline-offset:3px; border-radius:6px; }
.v3-ew a:focus-visible, .v3-mr a:focus-visible, .v3-cta a:focus-visible, .v3-serv__feat:focus-visible{ outline-color:#fff; }
.v3 h1,.v3 h2,.v3 h3{ font-family:var(--fd); font-weight:700; letter-spacing:-.025em; margin:0; }
.v3 img{ display:block; max-width:100%; }
.v3 :where(a){ color:inherit; text-decoration:none; }
.v3 [data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.v3 [data-reveal].is-visible{ opacity:1; transform:none; }
.wrap{ max-width:var(--max); margin:0 auto; padding:0 clamp(20px,4vw,52px); }

/* eyebrow / section heads */
.eyb{ display:inline-block; font-family:var(--fb); font-size:12px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:var(--burg); margin-bottom:14px; }
.sec{ padding:clamp(64px,10vh,128px) 0; }
.sec--canvas{ background:var(--canvas); } .sec--soft{ background:var(--canvas-2); } .sec--white{ background:var(--white); }
.sec__h{ font-size:clamp(30px,5vw,52px); line-height:1.05; color:var(--ink); }
.lead{ color:var(--muted); font-size:clamp(15px,1.4vw,18px); line-height:1.7; }
.accent-rule{ width:64px; height:3px; background:var(--burg); border-radius:var(--r-pill); margin:20px 0; }

/* buttons — alle rund */
.btn{ display:inline-flex; align-items:center; gap:10px; font-family:var(--fd); font-weight:600; font-size:15px; text-decoration:none; padding:15px 28px; border-radius:var(--r-pill); transition:all .25s var(--ease); cursor:pointer; border:1px solid transparent; }
.btn--primary{ background:var(--burg); color:#fff; box-shadow:0 12px 30px rgba(146,69,69,.28); }
.btn--primary:hover{ background:var(--burg-dk); transform:translateY(-2px); box-shadow:0 18px 38px rgba(146,69,69,.36); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ background:var(--ink); color:#fff; }
.btn--light{ background:#fff; color:var(--burg); }
.btn--on-dark{ background:rgba(255,255,255,.1); color:#fff; border-color:rgba(255,255,255,.4); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); }
.btn--on-dark:hover{ background:rgba(255,255,255,.2); }
.link-arrow{ display:inline-flex; align-items:center; gap:8px; font-family:var(--fd); font-weight:600; color:var(--burg); text-decoration:none; }
.link-arrow:hover{ gap:12px; }

/* ============ HEADER ============ */
/* Höhe 72px in beiden Zuständen (= identisch zu Unterseiten); nur Hintergrund/Transparenz unterscheidet sich */
.v3-header{ position:fixed; top:0; left:0; right:0; z-index:80; display:flex; align-items:center; justify-content:space-between; padding:11px clamp(20px,4vw,52px); transition:background .4s ease, box-shadow .4s ease, backdrop-filter .4s ease; }
.v3-header.is-scrolled{ background:rgba(251,248,243,.92); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); box-shadow:0 6px 28px rgba(33,31,28,.08); padding:11px clamp(20px,4vw,52px); }
.v3-logo{ display:flex; align-items:center; gap:11px; text-decoration:none; }
.v3-logo img{ height:36px; width:auto; filter:brightness(0) invert(1) drop-shadow(0 1px 4px rgba(0,0,0,.4)); transition:filter .4s ease; }
.is-scrolled .v3-logo img{ filter:brightness(0); }
.v3-menu-open .v3-logo img{ filter:brightness(0) invert(1); }
.v3-logo__wm{ font-family:var(--fd); font-weight:700; font-size:18px; letter-spacing:.14em; color:#fff; text-transform:uppercase; transition:color .4s ease; }
.v3-logo__wm span{ font-weight:400; letter-spacing:.2em; }
.is-scrolled .v3-logo__wm{ color:var(--ink); }
.v3-nav{ display:none; align-items:center; gap:clamp(18px,2vw,32px); }
.v3-nav__link{ font-family:var(--fd); font-size:14px; font-weight:500; color:#fff; text-decoration:none; opacity:.92; transition:opacity .2s, color .4s; }
.v3-nav__link:hover{ opacity:.6; }
.is-scrolled .v3-nav__link{ color:var(--ink); }
.v3-nav__link, .v3-nav__more, .v3-logo__wm{ text-shadow:0 1px 10px rgba(0,0,0,.45); }
.is-scrolled .v3-nav__link, .is-scrolled .v3-nav__more, .is-scrolled .v3-logo__wm{ text-shadow:none; }
.v3-burger span{ box-shadow:0 1px 4px rgba(0,0,0,.35); }
.is-scrolled .v3-burger span{ box-shadow:none; }
/* "Mehr"-Dropdown (gleiche Menüpunkte wie Unterseiten) */
.v3-nav__group{ position:relative; display:flex; align-items:center; }
.v3-nav__more{ display:inline-flex; align-items:center; gap:6px; font-family:var(--fd); font-size:14px; font-weight:500; color:#fff; background:transparent; border:none; cursor:pointer; opacity:.92; padding:0; transition:opacity .2s, color .4s; }
.v3-nav__more:hover{ opacity:.6; }
.is-scrolled .v3-nav__more{ color:var(--ink); }
.v3-nav__more svg{ width:10px; height:6px; transition:transform .25s ease; }
.v3-nav__group:hover .v3-nav__more svg{ transform:rotate(180deg); }
.v3-nav__sub{ position:absolute; top:100%; right:0; margin-top:14px; min-width:210px; background:#fff; border:1px solid #e7e1d6; border-radius:14px; box-shadow:0 18px 50px rgba(33,31,28,.18); padding:8px; display:flex; flex-direction:column; opacity:0; visibility:hidden; transform:translateY(-6px); transition:opacity .2s ease, transform .2s ease, visibility .2s; }
.v3-nav__sub::before{ content:""; position:absolute; top:-14px; left:0; right:0; height:14px; }
.v3-nav__group:hover .v3-nav__sub,.v3-nav__group:focus-within .v3-nav__sub{ opacity:1; visibility:visible; transform:none; }
.v3-nav__sub a{ font-family:var(--fd); font-size:14px; font-weight:500; color:var(--ink); text-decoration:none; padding:10px 14px; border-radius:9px; transition:background .15s ease; opacity:1; }
.v3-nav__sub a:hover{ background:#f4efe8; }
/* Mobile: "Mehr"-Punkte als kleinere Sekundärgruppe */
.v3-mobile a.v3-mobile__sub{ font-size:18px; opacity:.78; padding:9px 0; }
.v3-nav__cta{ display:inline-flex; align-items:center; height:50px; font-family:var(--fd); font-weight:700; font-size:14px; color:#fff; background:var(--burg); padding:0 24px; border-radius:var(--r-pill); text-decoration:none; box-shadow:0 8px 22px rgba(146,69,69,.3); }
.v3-burger{ display:flex; flex-direction:column; gap:5px; width:46px; height:46px; align-items:center; justify-content:center; background:transparent; border:none; cursor:pointer; }
.v3-burger span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:.3s; }
.is-scrolled .v3-burger span{ background:var(--ink); }
.v3-menu-open .v3-burger span{ background:#fff !important; }
.v3-menu-open .v3-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.v3-menu-open .v3-burger span:nth-child(2){ opacity:0; }
.v3-menu-open .v3-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu */
.v3-mobile{ position:fixed; inset:0; z-index:75; background:var(--dark); display:flex; flex-direction:column; justify-content:center; padding:0 32px; gap:4px; opacity:0; visibility:hidden; transform:translateY(-10px); transition:.4s; }
.v3-mobile.is-open{ opacity:1; visibility:visible; transform:none; }
.v3-mobile a{ font-family:var(--fd); font-weight:600; font-size:26px; color:#fff; text-decoration:none; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.1); }
.v3-mobile a.v3-mobile__cta{ margin-top:24px; background:var(--burg); border:none; border-radius:var(--r-pill); text-align:center; padding:16px; font-size:17px; }

/* ============ HERO ============ */
.v3-hero{ position:relative; min-height:92vh; min-height:90svh; display:flex; align-items:flex-end; overflow:hidden; }
.v3-hero__bg{ position:absolute; inset:-6% 0; z-index:0; }
.v3-hero__slide{ position:absolute; inset:0; background-size:cover; background-position:center 45%; opacity:0; transition:opacity 1.8s ease; animation:v3KB 32s ease-in-out infinite alternate; }
.v3-hero__slide.is-active{ opacity:1; }
/* Mobile-LCP: nur das statische Hero-Bild (Slide 1) laedt die kleinere Variante; Rotation + CMS-Swap unberuehrt. */
@media (max-width:760px){ .v3-hero__slide--static1{ background-image:url('/assets/landing/hero-1-mobile.webp') !important; } }
/* Desktop: Text ist linksbündig → Scrim LINKS (Lesbarkeit) + dezent unten; rechts/oben bleibt hell (textfrei) */
.v3-hero__ov{ position:absolute; inset:0; z-index:1; background:linear-gradient(90deg,rgba(10,8,7,.50) 0%,rgba(10,8,7,.32) 30%,rgba(10,8,7,.09) 54%,rgba(10,8,7,0) 72%),linear-gradient(180deg,rgba(8,7,6,0) 38%,rgba(8,7,6,.26) 68%,rgba(8,7,6,.58) 100%),linear-gradient(180deg,rgba(8,7,6,.18) 0%,rgba(8,7,6,.07) 7%,rgba(8,7,6,0) 17%); }
.v3-hero__inner{ position:relative; z-index:3; width:100%; max-width:var(--max); margin:0 auto; padding:120px clamp(20px,4vw,52px) clamp(40px,5vh,64px); }
.v3-hero__badge-line{ display:inline-flex; align-items:center; gap:10px; color:#fff; font-size:12px; font-weight:600; letter-spacing:.22em; text-transform:uppercase; opacity:.85; margin-bottom:22px; text-shadow:0 1px 14px rgba(0,0,0,.55); }
.v3-hero__badge-line i{ width:24px; height:1px; background:rgba(255,255,255,.6); display:inline-block; }
.v3-hero h1{ color:#fff; font-size:clamp(38px,6.4vw,76px); line-height:1.02; max-width:16ch; margin-bottom:18px; text-shadow:0 2px 30px rgba(0,0,0,.55); }
.v3-hero__sub{ color:rgba(255,255,255,.92); font-size:clamp(15px,2vw,19px); line-height:1.6; max-width:48ch; margin:0 0 30px; text-shadow:0 1px 18px rgba(0,0,0,.55); }
.v3-hero h1.v3-hero__claims{ font-size:clamp(28px,5.2vw,56px); line-height:1.08; margin-bottom:20px; max-width:none; }
.v3-hero__claims span{ display:block; }
.v3-hero__claims span:not(:first-child){ opacity:.72; font-weight:700; }
.v3-hero__cues{ display:flex; flex-wrap:wrap; align-items:center; gap:16px; }
.v3-play{ display:inline-flex; align-items:center; gap:12px; background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.45); color:#fff; padding:13px 22px; border-radius:var(--r-pill); font-family:var(--fd); font-weight:600; font-size:15px; cursor:pointer; -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); transition:.25s; }
.v3-play:hover{ background:rgba(255,255,255,.2); transform:translateY(-2px); }
.v3-play__c{ width:34px; height:34px; border-radius:50%; border:1.5px solid rgba(255,255,255,.6); display:flex; align-items:center; justify-content:center; font-size:12px; }
.v3-trust{ display:inline-flex; align-items:center; gap:10px; color:rgba(255,255,255,.85); font-size:13.5px; }
.v3-trust .stars{ color:#f0c14b; letter-spacing:1px; }

/* (runder Einwertungs-Button entfernt — ersetzt durch primären Hero-CTA .v3-hero__cta) */
.v3-hero__cta{ box-shadow:0 12px 30px rgba(146,69,69,.34); }

/* Such-Leiste (überlappt Hero-Unterkante) */
.v3-search{ position:relative; z-index:5; max-width:var(--max); margin:0 auto; padding:0 clamp(20px,4vw,52px); transform:translateY(50%); }
.v3-search__bar{ background:#fff; border-radius:var(--r-lg); box-shadow:0 24px 60px rgba(33,31,28,.16); padding:14px; display:grid; grid-template-columns:1.2fr 1fr 1.4fr auto; gap:10px; align-items:center; }
.v3-search__field{ display:flex; flex-direction:column; padding:8px 14px; border-radius:var(--r-md); }
.v3-search__field + .v3-search__field{ border-left:1px solid var(--line); }
.v3-search__lbl{ font-size:11px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:4px; }
.v3-search select,.v3-search input{ border:none; background:transparent; font-family:var(--fb); font-size:15px; color:var(--ink); outline:none; width:100%; }
.v3-search select{ -webkit-appearance:none; -moz-appearance:none; appearance:none; cursor:pointer; padding-right:22px; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23924545' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 0 center; }
.v3-search__btn{ height:100%; }

@keyframes v3KB{ from{ transform:scale(1.03);} to{ transform:scale(1.1);} }

/* spacer nach Hero (wegen überlappender Suche) */
.v3-after-hero{ height:clamp(70px,9vh,120px); background:var(--canvas); }

/* sticky social rail */
.v3-social{ position:fixed; right:14px; top:50%; transform:translateY(-50%); z-index:40; display:none; flex-direction:column; gap:10px; }
.v3-social a{ width:40px; height:40px; border-radius:50%; background:var(--burg); color:#fff; display:flex; align-items:center; justify-content:center; text-decoration:none; box-shadow:0 6px 18px rgba(33,31,28,.18); transition:transform .2s; }
.v3-social a:hover{ transform:scale(1.1); }
.v3-social svg{ width:18px; height:18px; }

/* lightbox */
.v3-lightbox{ position:fixed; inset:0; z-index:9998; display:none; align-items:center; justify-content:center; background:rgba(10,9,8,.92); padding:24px; }
.v3-lightbox.is-open{ display:flex; }
.v3-lightbox__frame{ position:relative; width:min(1000px,92vw); aspect-ratio:16/9; background:#000; border-radius:var(--r-md); overflow:hidden; }
.v3-lightbox__frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.v3-lightbox__close{ position:absolute; top:14px; right:22px; width:48px; height:48px; background:transparent; border:none; color:#fff; font-size:38px; cursor:pointer; }

@media (min-width:901px){ .v3-nav{ display:flex; } .v3-burger{ display:none; } .v3-social{ display:flex; } }
/* Header transparent solange Mobile-Menü offen (kein heller Streifen über dunklem Menü) */
.v3-menu-open .v3-header{ background:transparent !important; box-shadow:none !important; -webkit-backdrop-filter:none !important; backdrop-filter:none !important; }
.v3-menu-open .v3-logo__wm{ color:#fff !important; }

@media (max-width:760px){
  .v3-hero{ min-height:68svh; }
  /* Mobile: kräftigeres Overlay (Text sitzt höher/größer relativ zum Bild → bleibt lesbar) */
  .v3-hero__ov{ background:linear-gradient(180deg,rgba(8,7,6,.5) 0%,rgba(8,7,6,.3) 7%,rgba(8,7,6,0) 17%),linear-gradient(180deg,rgba(14,12,10,0) 0%,rgba(14,12,10,.14) 18%,rgba(12,10,9,.44) 40%,rgba(10,8,7,.66) 62%,rgba(8,7,6,.9) 100%); }
  .v3-hero__inner{ padding:84px 20px 28px; }
  .v3-hero h1{ font-size:clamp(34px,9vw,46px); }
  /* Such-Leiste auf Mobile: sauber UNTER dem Hero (kein halber Overlap-Seam mehr durch die Karte) */
  .v3-search{ transform:none; margin-top:18px; }
  .v3-search__bar{ grid-template-columns:1fr; padding:10px; gap:6px; box-shadow:0 18px 44px rgba(33,31,28,.18); }
  .v3-search__field{ padding:10px 14px; }
  .v3-search__field + .v3-search__field{ border-left:none; border-top:1px solid var(--line); }
  .v3-search__btn{ margin-top:4px; justify-content:center; padding:16px; }
  .v3-after-hero{ display:none; }
  .v3-round-cta{ display:none; }
  /* Scroller: auf Touch wird gewischt — Pfeile weg, Karte lugt rein als Hinweis
     (höhere Spezifität, da .ang-nav-Basisregel weiter unten im File steht) */
  .ang-head-actions .ang-nav{ display:none; }
}
@media (prefers-reduced-motion:reduce){ .v3-hero__slide,.v3-round-cta{ animation:none !important; } .v3 [data-reveal]{ opacity:1 !important; transform:none !important; } }

/* ============ INTRO (überlappende Komposition) ============ */
.v3-intro__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); align-items:center; }
.v3-intro__media{ position:relative; min-height:440px; }
.v3-intro__img-back{ position:absolute; left:0; bottom:0; width:62%; height:74%; background-size:cover; background-position:center; border-radius:var(--r-lg); }
.v3-intro__img-front{ position:absolute; right:0; top:0; width:72%; height:80%; object-fit:cover; border-radius:var(--r-lg); box-shadow:0 30px 70px rgba(33,31,28,.18); }
@media(max-width:840px){ .v3-intro__grid{ grid-template-columns:1fr; } .v3-intro__media{ min-height:340px; } }

/* ============ LEISTUNGEN (Service-Karten) ============ */
.v3-serv__head{ max-width:640px; margin:0 auto clamp(38px,5.5vh,58px); text-align:center; }
.v3-serv__head .lead{ margin-top:16px; }
.v3-serv__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px); }
.v3-serv__label{ display:block; font-size:11.5px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--burg); margin-bottom:10px; }
.v3-serv__go{ display:inline-flex; align-items:center; gap:8px; font-family:var(--fd); font-weight:600; font-size:14px; color:var(--burg); margin-top:auto; }
.v3-serv__go i{ font-style:normal; transition:transform .3s var(--ease); }

/* Feature-Karte (Verkaufen) — volle Breite, Anthrazit */
.v3-serv__feat{ grid-column:1 / -1; display:grid; grid-template-columns:1.15fr 1fr; min-height:300px; border-radius:var(--r-lg); overflow:hidden; background:var(--dark); color:#fff; box-shadow:0 18px 48px rgba(33,31,28,.12); }
.v3-serv__feat-img{ background-size:cover; background-position:center; min-height:240px; transition:transform .7s var(--ease); }
.v3-serv__feat:hover .v3-serv__feat-img{ transform:scale(1.05); }
.v3-serv__feat-body{ display:flex; flex-direction:column; padding:clamp(28px,3vw,46px); }
.v3-serv__feat .v3-serv__label{ color:#e3cfae; }
.v3-serv__feat-title{ font-family:var(--fd); font-weight:700; font-size:clamp(24px,2.8vw,34px); line-height:1.1; margin-bottom:14px; }
.v3-serv__feat-text{ color:rgba(255,255,255,.78); font-size:15.5px; line-height:1.65; margin-bottom:22px; }
.v3-serv__feat .v3-serv__go{ color:#e3cfae; }
.v3-serv__feat:hover .v3-serv__go i{ transform:translateX(6px); }

/* Standard-Karten */
.v3-serv__card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; box-shadow:0 12px 36px rgba(33,31,28,.06); transition:transform .35s var(--ease), box-shadow .35s var(--ease); }
.v3-serv__card:hover{ transform:translateY(-6px); box-shadow:0 26px 56px rgba(33,31,28,.14); }
.v3-serv__card-img{ display:block; height:184px; background-size:cover; background-position:center; transition:transform .7s var(--ease); }
.v3-serv__card:hover .v3-serv__card-img{ transform:scale(1.06); }
.v3-serv__card-body{ display:flex; flex-direction:column; flex:1; padding:22px 24px 26px; }
.v3-serv__card-title{ font-family:var(--fd); font-weight:700; font-size:20px; line-height:1.2; margin-bottom:10px; color:var(--ink); }
.v3-serv__card-text{ color:var(--muted); font-size:14.5px; line-height:1.6; margin-bottom:18px; }
.v3-serv__card:hover .v3-serv__go i{ transform:translateX(5px); }
@media(max-width:880px){ .v3-serv__grid{ grid-template-columns:1fr 1fr; } .v3-serv__feat{ grid-template-columns:1fr; } .v3-serv__feat-img{ min-height:200px; } }
@media(max-width:560px){ .v3-serv__grid{ grid-template-columns:1fr; } }

/* ============ Section-Head mit Seiten-Button ============ */
.v3-sechead{ display:flex; align-items:flex-end; justify-content:space-between; gap:18px; flex-wrap:wrap; margin-bottom:clamp(30px,4vh,48px); }

/* ============ Live Angebote ============ */
.ang-head-actions{ display:flex; align-items:center; gap:10px; }
.ang-nav{ width:46px; height:46px; border-radius:50%; background:#fff; border:1px solid var(--line); color:var(--ink); font-size:24px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all .2s var(--ease); }
.ang-nav:hover{ background:var(--burg); color:#fff; border-color:var(--burg); }
.ang-track{ display:flex; gap:clamp(16px,1.6vw,22px); overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth; padding:6px 2px 16px; -webkit-overflow-scrolling:touch; scrollbar-width:none; min-height:80px; }
.ang-track::-webkit-scrollbar{ display:none; }
.ang-track .ang-card{ flex:0 0 clamp(280px,30vw,340px); scroll-snap-align:start; }
.ang-grid__fallback{ color:var(--muted); }
@media(max-width:560px){ .ang-track .ang-card{ flex:0 0 82%; } }
.ang-card{ display:block; text-decoration:none; color:inherit; background:#fff; border-radius:var(--r-lg); overflow:hidden; box-shadow:0 16px 44px rgba(33,31,28,.08); transition:transform .35s var(--ease), box-shadow .35s var(--ease); }
.ang-card:hover{ transform:translateY(-6px); box-shadow:0 28px 60px rgba(33,31,28,.16); }
.ang-card__img{ position:relative; height:210px; background:var(--sand); background-size:cover; background-position:center; }
.ang-card__badge{ position:absolute; top:14px; left:14px; font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; padding:6px 13px; border-radius:var(--r-pill); color:#fff; }
.ang-card__badge--neu{ background:var(--burg); } .ang-card__badge--res{ background:#3f3a33; }
.ang-card__body{ padding:18px 22px 22px; }
.ang-card__type{ font-size:11.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:7px; }
.ang-card__title{ font-family:var(--fd); font-weight:600; font-size:17px; line-height:1.25; margin-bottom:10px; }
.ang-card__meta{ font-size:13.5px; color:var(--muted); margin-bottom:12px; }

/* ============ Marktpuls (live counts) ============ */
.mp{ background:var(--white); border-bottom:1px solid var(--line); padding:clamp(26px,4vh,40px) 0; }
.mp__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(14px,3vw,28px); text-align:center; }
.mp__stat{ display:flex; flex-direction:column; align-items:center; gap:6px; }
.mp__stat + .mp__stat{ border-left:1px solid var(--line); }
.mp__top{ display:inline-flex; align-items:center; gap:8px; }
.mp__num{ font-family:var(--fd); font-weight:800; font-size:clamp(26px,4vw,38px); line-height:1; color:var(--ink); }
.mp__lbl{ font-size:12.5px; color:var(--muted); font-weight:500; }
.mp__star{ color:#f0c14b; font-size:15px; }
.mp__dot{ width:8px; height:8px; border-radius:50%; background:#22c55e; flex:none; box-shadow:0 0 0 0 rgba(34,197,94,.5); animation:mpPulse 1.8s ease-in-out infinite; }
@keyframes mpPulse{ 0%,100%{ transform:scale(1); box-shadow:0 0 0 0 rgba(34,197,94,.5);} 50%{ transform:scale(1.15); box-shadow:0 0 0 6px rgba(34,197,94,0);} }
@media(max-width:680px){ .mp__grid{ grid-template-columns:1fr 1fr; gap:24px 14px; } .mp__stat:nth-child(odd){ border-left:none; } }

/* ============ Ticker „Zuletzt verkauft" ============ */
.tk{ background:var(--dark); padding:13px 0; overflow:hidden; display:flex; align-items:center; gap:18px; }
.tk__label{ flex:none; display:inline-flex; align-items:center; gap:8px; padding-left:clamp(20px,4vw,52px); font-size:11.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--sand); white-space:nowrap; }
.tk__mask{ flex:1; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); }
.tk__row{ display:inline-flex; gap:42px; white-space:nowrap; animation:tkMarquee 36s linear infinite; will-change:transform; }
.tk__item{ font-size:13px; color:rgba(255,255,255,.55); }
.tk__item b{ color:#fff; font-weight:600; margin-right:7px; }
@keyframes tkMarquee{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }
@media(prefers-reduced-motion:reduce){ .tk__row{ animation:none; } .mp__dot{ animation:none; } }
/* Mobil: "Zuletzt verkauft" als Label oben, Objekte laufen darunter (2-zeilig) */
@media(max-width:680px){
  .tk{ flex-direction:column; align-items:stretch; gap:9px; }
  .tk__label{ padding-left:20px; }
  .tk__mask{ width:100%; }
}

/* ============ Dual-Path (Verkäufer / Käufer) ============ */
.kp__head{ max-width:680px; margin:0 auto clamp(30px,4vh,48px); text-align:center; }
.kp__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2.4vw,26px); }
.kp__card{ display:flex; flex-direction:column; background:#fff; border:1px solid var(--line); border-radius:var(--r-lg); padding:clamp(26px,3vw,38px); box-shadow:0 12px 36px rgba(33,31,28,.06); }
.kp__card--dark{ background:linear-gradient(150deg,#2c2925,#1c1a17); border-color:transparent; color:#fff; }
.kp__badge{ align-self:flex-start; display:inline-flex; align-items:center; gap:8px; background:rgba(146,69,69,.1); color:var(--burg); font-size:12.5px; font-weight:600; padding:7px 14px; border-radius:var(--r-pill); margin-bottom:18px; }
.kp__badge b{ font-weight:800; }
.kp__badge--green{ background:rgba(34,197,94,.16); color:#7bd88f; }
.kp__card-h{ font-family:var(--fd); font-weight:700; font-size:clamp(22px,2.4vw,26px); margin:0 0 10px; }
.kp__card-p{ font-size:15px; line-height:1.6; color:var(--muted); margin:0 0 22px; flex:1; }
.kp__card--dark .kp__card-p{ color:rgba(255,255,255,.72); }
.kp__teaser{ display:flex; flex-direction:column; gap:10px; margin-bottom:24px; }
.kp__match{ display:flex; align-items:center; gap:10px; font-size:13.5px; line-height:1.4; color:var(--ink); }
.kp__match svg{ width:15px; height:15px; flex:none; color:#16a34a; }
.kp__teaser-head{ display:inline-flex; align-items:center; gap:8px; font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:12px; }
.kp__verified{ display:flex; align-items:center; gap:8px; font-size:12.5px; font-weight:500; line-height:1.4; color:#4a443c; margin:2px 0 22px; }
.kp__verified svg{ width:16px; height:16px; flex:none; color:#16a34a; }
.kp__benefits{ list-style:none; margin:0 0 24px; padding:0; display:flex; flex-direction:column; gap:10px; }
.kp__benefits li{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:rgba(255,255,255,.85); }
.kp__benefits svg{ width:15px; height:15px; flex:none; color:#7bd88f; }
.kp__card .btn{ align-self:flex-start; }
@media(max-width:780px){ .kp__grid{ grid-template-columns:1fr; } }

/* ============ Einwertung — Live-Wertrechner ============ */
.v3-ew{ background:var(--dark); padding:clamp(64px,10vh,128px) 0; }
.v3-ew__head{ text-align:center; max-width:620px; margin:0 auto clamp(28px,4vh,44px); }
.v3-ew__head .eyb i.mp__dot{ margin-right:8px; vertical-align:middle; }
.v3-ewc{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(18px,3vw,32px); align-items:stretch; max-width:980px; margin:0 auto; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16); border-radius:var(--r-lg); padding:clamp(22px,3vw,36px); }
.v3-ewc__controls{ display:flex; flex-direction:column; gap:24px; }
.v3-ewc__group{ display:flex; flex-direction:column; }
.v3-ewc__lbl{ font-size:12px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:rgba(255,255,255,.65); }
.v3-ewc__top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:10px; }
.v3-ewc__val{ font-family:var(--fd); font-weight:700; font-size:16px; color:#fff; }
.v3-ewc__chips{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-top:10px; }
.v3-ewc__chip{ padding:11px 10px; background:rgba(255,255,255,.1); border:1.5px solid rgba(255,255,255,.24); border-radius:var(--r-sm); color:rgba(255,255,255,.85); font-family:var(--fd); font-size:13.5px; font-weight:600; cursor:pointer; transition:all .2s var(--ease); }
.v3-ewc__chip:hover{ background:rgba(255,255,255,.18); }
.v3-ewc__chip.is-active{ background:#fff; border-color:#fff; color:var(--burg); }
.v3-ewc input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:var(--r-pill); background:rgba(255,255,255,.22); outline:none; }
.v3-ewc input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:26px; height:26px; border-radius:50%; background:#fff; border:3px solid var(--burg); box-shadow:0 3px 10px rgba(0,0,0,.3); cursor:pointer; }
.v3-ewc input[type=range]::-moz-range-thumb{ width:26px; height:26px; border-radius:50%; background:#fff; border:3px solid var(--burg); cursor:pointer; }
.v3-ewc__result{ display:flex; flex-direction:column; justify-content:center; text-align:center; background:linear-gradient(150deg,rgba(255,255,255,.14),rgba(255,255,255,.04)); border:1px solid rgba(255,255,255,.2); border-radius:var(--r-md); padding:clamp(24px,3vw,32px); }
.v3-ewc__result-lbl{ font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-bottom:12px; }
.v3-ewc__range{ font-family:var(--fd); font-weight:800; font-size:clamp(22px,3vw,32px); line-height:1.15; color:#fff; letter-spacing:-.02em; }
.v3-ewc__hint{ display:inline-flex; align-items:center; justify-content:center; gap:7px; margin:14px 0 22px; font-size:12.5px; color:rgba(255,255,255,.62); }
.v3-ewc__hint svg{ width:13px; height:13px; }
/* CTA-Aufmerksamkeit: lenkt zum echten Einwertungsformular (Atem-Glow + Sheen-Sweep + Pfeil-Nudge) */
.v3-ewc__cta{ position:relative; overflow:hidden; animation:ewBreathe 2.8s ease-in-out infinite; }
.v3-ewc__cta-arr{ display:inline-block; animation:ewArrow 2.8s ease-in-out infinite; }
.v3-ewc__cta:hover{ animation-play-state:paused; }
.v3-ewc__cta:hover .v3-ewc__cta-arr{ animation:none; transform:translateX(4px); }
.v3-ewc__cta::after{ content:""; position:absolute; inset:0; background:linear-gradient(100deg,transparent 35%,rgba(146,69,69,.22) 50%,transparent 65%); transform:translateX(-120%); animation:ewSheen 3.4s ease-in-out infinite; pointer-events:none; }
@keyframes ewBreathe{ 0%,100%{ box-shadow:0 6px 18px rgba(0,0,0,.3); } 50%{ box-shadow:0 0 0 4px rgba(227,207,174,.16), 0 12px 34px rgba(227,207,174,.42); } }
@keyframes ewArrow{ 0%,100%{ transform:translateX(0); } 50%{ transform:translateX(5px); } }
@keyframes ewSheen{ 0%{ transform:translateX(-120%); } 55%,100%{ transform:translateX(120%); } }
@media(prefers-reduced-motion:reduce){ .v3-ewc__cta,.v3-ewc__cta-arr{ animation:none; } .v3-ewc__cta::after{ display:none; } }
@media(max-width:680px){ .v3-ewc{ grid-template-columns:1fr; } }

/* ============ Was anders (editorial) ============ */
.v3-row{ display:grid; grid-template-columns:1fr 1.08fr; gap:clamp(28px,5vw,72px); align-items:center; padding:clamp(40px,6vh,76px) 0; border-top:1px solid var(--line); }
.v3-row__body{ order:1; } .v3-row__media{ order:2; }
.v3-row--rev .v3-row__body{ order:2; } .v3-row--rev .v3-row__media{ order:1; }
.v3-row__label{ display:inline-block; font-size:12px; font-weight:600; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--burg); padding-bottom:8px; margin-bottom:20px; }
.v3-row__title{ font-size:clamp(26px,3.6vw,42px); line-height:1.05; margin-bottom:16px; }
.v3-row__media img{ width:100%; height:clamp(280px,40vw,480px); object-fit:cover; border-radius:var(--r-lg); }
@media(max-width:840px){ .v3-row{ grid-template-columns:1fr; gap:20px; } .v3-row--rev .v3-row__body{ order:1; } .v3-row--rev .v3-row__media{ order:2; } .v3-row__media img{ height:clamp(220px,55vw,320px); } }

/* ============ Mini-Rechner ============ */
.v3-mr{ background:var(--dark); padding:clamp(64px,9vh,120px) 0; }
.v3-mr__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,72px); align-items:center; }
.v3-mr__lead{ color:rgba(255,255,255,.75); font-size:16px; line-height:1.6; margin:14px 0 24px; }
.v3-mr__calc{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-lg); padding:clamp(24px,3vw,36px); }
.v3-mr__field{ margin-bottom:22px; }
.v3-mr__top{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:10px; }
.v3-mr__field label{ font-size:14px; color:rgba(255,255,255,.8); }
.v3-mr__val{ font-family:var(--fd); font-weight:600; font-size:16px; color:#fff; }
.v3-mr__calc input[type=range]{ -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:var(--r-pill); background:rgba(255,255,255,.18); outline:none; }
.v3-mr__calc input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; appearance:none; width:28px; height:28px; border-radius:50%; background:var(--burg); border:3px solid #fff; box-shadow:0 3px 10px rgba(0,0,0,.35); cursor:pointer; transition:transform .15s var(--ease); }
.v3-mr__calc input[type=range]::-webkit-slider-thumb:active{ transform:scale(1.12); }
.v3-mr__calc input[type=range]::-moz-range-thumb{ width:28px; height:28px; border-radius:50%; background:var(--burg); border:3px solid #fff; box-shadow:0 3px 10px rgba(0,0,0,.35); cursor:pointer; }
.v3-mr__result{ display:flex; flex-direction:column; margin:24px 0 14px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12); }
.v3-mr__rate{ font-family:var(--fd); font-weight:700; font-size:clamp(36px,5vw,52px); color:#fff; line-height:1; }
.v3-mr__rate-lbl{ font-size:13.5px; color:rgba(255,255,255,.6); margin-top:8px; }
.v3-mr__note{ font-size:12px; color:rgba(255,255,255,.45); line-height:1.5; margin:0; }
@media(max-width:840px){ .v3-mr__grid{ grid-template-columns:1fr; } }

/* ============ Referenzen ============ */
.v3-ref__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:clamp(18px,2vw,26px); }
.v3-refcard{ border-radius:var(--r-lg); overflow:hidden; box-shadow:0 16px 44px rgba(33,31,28,.1); transition:transform .35s var(--ease), box-shadow .35s var(--ease); }
.v3-refcard:hover{ transform:translateY(-6px); box-shadow:0 28px 60px rgba(33,31,28,.16); }
/* 5:3 = exakt das Quellformat der Fotos (1280×768) → der eingebrannte „Verkauft"-Ribbon
   wird nie angeschnitten. Pill-Badge entfernt: das Foto trägt die Verkauft-Markierung. */
.v3-refcard__img{ position:relative; aspect-ratio:5 / 3; background-size:cover; background-position:center; }
.v3-refcard__b{ background:#fff; padding:20px 22px; }
.v3-refcard__loc{ display:block; font-size:11.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:6px; }
.v3-refcard__t{ font-family:var(--fd); font-weight:600; font-size:18px; }

/* ============ Zahlen ============ */
.v3-stats{ background:var(--dark); padding:clamp(58px,8vh,100px) 0; }
.v3-stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,40px); }
.v3-stat{ text-align:center; border-top:2px solid var(--burg); padding-top:18px; }
.v3-stat__n{ display:block; font-family:var(--fd); font-weight:700; font-size:clamp(32px,4.5vw,56px); color:#fff; line-height:1; }
.v3-stat__l{ font-size:13px; color:rgba(255,255,255,.6); margin-top:10px; display:block; }
@media(max-width:680px){ .v3-stats__grid{ grid-template-columns:1fr 1fr; gap:28px 20px; } }

/* ============ Kundenstimmen ============ */
.v3-stim__grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.v3-stim{ background:#fff; border-radius:var(--r-lg); padding:30px 28px; margin:0; box-shadow:0 12px 36px rgba(33,31,28,.06); }
.v3-stim blockquote{ margin:0 0 18px; font-size:16px; line-height:1.6; }
.v3-stim figcaption b{ font-family:var(--fd); display:block; }
.v3-stim figcaption span{ font-size:13px; color:var(--muted); }

/* ============ Presse ============ */
.v3-press__row{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:clamp(20px,4vw,52px); margin-top:22px; }
.v3-press__row a{ font-family:var(--fd); font-weight:600; font-size:clamp(16px,2vw,22px); color:#4a443c; opacity:.8; text-decoration:none; }
.v3-press__row a.ntv{ font-weight:800; }
.v3-press__dekra{ font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--burg); }
/* Publikationen — Artikel-Screenshots */
.v3-press__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,26px); margin-top:32px; max-width:780px; margin-left:auto; margin-right:auto; }
.v3-press__card{ display:block; border-radius:14px; overflow:hidden; background:#fff; border:1px solid #ece6db; box-shadow:0 10px 30px rgba(33,31,28,.10); transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.v3-press__card:hover{ transform:translateY(-6px); box-shadow:0 22px 48px rgba(33,31,28,.16); }
.v3-press__card img{ display:block; width:100%; height:auto; aspect-ratio:1000/1257; object-fit:cover; object-position:top center; }
@media (max-width:860px){ .v3-press__grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:460px){ .v3-press__grid{ grid-template-columns:1fr; max-width:330px; margin-left:auto; margin-right:auto; } }
/* Instagram-Feed */
.v3-ig__h{ font-family:var(--fd); font-weight:700; font-size:clamp(26px,3.4vw,40px); line-height:1.1; margin-top:8px; }
.v3-ig__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(8px,1.4vw,16px); margin-top:30px; }
.v3-ig__item{ position:relative; display:block; aspect-ratio:1; overflow:hidden; border-radius:12px; background:#ece6db; }
.v3-ig__item img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .4s var(--ease); }
.v3-ig__item:hover img{ transform:scale(1.06); }
.v3-ig__play{ position:absolute; right:9px; top:8px; color:#fff; font-size:13px; text-shadow:0 1px 5px rgba(0,0,0,.55); }
.v3-ig__more{ display:inline-flex; margin-top:26px; }
@media (max-width:720px){ .v3-ig__grid{ grid-template-columns:repeat(2,1fr); } }

/* ============ Team ============ */
.v3-team__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,48px); }
.v3-teamcard{ display:flex; gap:22px; align-items:flex-start; }
.v3-teamcard__img{ flex:none; width:clamp(150px,22vw,240px); border-radius:var(--r-lg); overflow:hidden; }
.v3-teamcard__img img{ width:100%; height:auto; aspect-ratio:1; object-fit:cover; border-radius:var(--r-lg); filter:grayscale(100%) contrast(1.02); transition:filter .6s var(--ease), transform .6s var(--ease); }
.v3-teamcard:hover .v3-teamcard__img img{ filter:grayscale(0) contrast(1); transform:scale(1.04); }
@media(prefers-reduced-motion:reduce){ .v3-teamcard__img img{ transition:filter .3s linear; } .v3-teamcard:hover .v3-teamcard__img img{ transform:none; } }
.v3-teamcard__b h3{ font-size:22px; }
.v3-teamcard__role{ display:block; color:var(--burg); font-weight:600; font-size:13px; margin:4px 0 12px; }
.v3-teamcard__b p{ color:var(--muted); font-size:15px; line-height:1.6; margin:0; }
@media(max-width:840px){ .v3-team__grid{ grid-template-columns:1fr; } }

/* ============ Abschluss-CTA ============ */
.v3-cta{ background:var(--burg); padding:clamp(64px,11vh,140px) 0; text-align:center; }
.v3-cta__wrap{ max-width:680px; margin:0 auto; }
.v3-cta p{ color:#f3e6e0; font-size:clamp(15px,1.6vw,18px); margin:14px 0 30px; }
.v3-cta__btns{ display:flex; flex-wrap:wrap; gap:14px; justify-content:center; }

/* ============ Footer ============ */
.v3-footer{ background:var(--dark); color:#cfc4b4; padding:clamp(52px,8vh,80px) 0 40px; }
.v3-footer__grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.1fr 1fr; gap:32px; }
.v3-footer__logo{ height:64px; margin-bottom:14px; }
.v3-footer p{ font-size:14px; line-height:1.7; color:#938a7c; max-width:260px; margin:0; }
.v3-footer h4{ font-family:var(--fd); font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:#7d756a; margin:0 0 14px; }
.v3-footer__grid a, .v3-footer__grid span{ display:block; font-size:14.5px; color:#cfc4b4; text-decoration:none; margin-bottom:9px; }
.v3-footer__grid a:hover{ color:#fff; }
.v3-footer__grid a.v3-footer__box{ display:inline-block; width:max-content; margin-top:4px; padding:6px 14px; border:1px solid rgba(255,255,255,.28); border-radius:8px; color:#e8e0d4; font-weight:600; }
.v3-footer__grid a.v3-footer__box:hover{ border-color:var(--burg); background:rgba(146,69,69,.28); color:#fff; }
.v3-footer__social{ display:flex; gap:12px; margin-top:16px; }
.v3-footer__grid .v3-footer__social a{ display:inline-flex; width:36px; height:36px; margin:0; border-radius:50%; border:1px solid rgba(255,255,255,.18); align-items:center; justify-content:center; color:#cfc4b4; }
.v3-footer__grid .v3-footer__social a:hover{ border-color:var(--burg); color:#fff; background:rgba(146,69,69,.22); }
.v3-footer__bottom{ margin-top:44px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1); font-size:12.5px; color:#7d756a; }
@media(max-width:760px){ .v3-footer__grid{ grid-template-columns:1fr 1fr; } }

/* ============ Angebote-Karte: Film-Badge + Preis-Overlay (v5-Port) ============ */
.ang-film{ position:absolute; top:12px; left:12px; display:inline-flex; align-items:center; gap:6px; background:rgba(26,24,22,.78); color:#fff; font-size:11px; font-weight:600; padding:5px 11px; border-radius:var(--r-pill); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); }
.ang-film__play{ width:0; height:0; border-left:7px solid #fff; border-top:4px solid transparent; border-bottom:4px solid transparent; }
.ang-card__price-ov{ position:absolute; bottom:12px; right:12px; background:#fff; color:var(--ink); font-family:var(--fd); font-weight:700; font-size:15px; padding:6px 12px; border-radius:var(--r-sm); box-shadow:0 4px 14px rgba(33,31,28,.18); }

/* ============ Mobile Sticky-CTA ============ */
.v3-sticky{ position:fixed; left:0; right:0; bottom:0; z-index:60; display:none; gap:10px; padding:11px 14px calc(11px + env(safe-area-inset-bottom)); background:rgba(251,248,243,.96); -webkit-backdrop-filter:blur(12px); backdrop-filter:blur(12px); border-top:1px solid var(--line); box-shadow:0 -8px 30px rgba(33,31,28,.1); transform:translateY(130%); transition:transform .4s var(--ease); }
.v3-sticky.is-on{ transform:translateY(0); }
.v3-sticky__main{ flex:1; display:flex; align-items:center; justify-content:center; font-family:var(--fd); font-weight:700; font-size:15px; color:#fff; background:var(--burg); padding:15px; border-radius:var(--r-sm); text-decoration:none; }
.v3-sticky__call{ flex:none; width:54px; display:flex; align-items:center; justify-content:center; background:#efe7db; border-radius:var(--r-sm); color:var(--burg); text-decoration:none; }
.v3-sticky__call svg{ width:20px; height:20px; }
@media(max-width:900px){ .v3-sticky{ display:flex; } }

/* Live Ad-Stream (Reichweite-Zeile) — Wand echter Anzeigen, zwei gegenläufige Spalten,
   deren Position ans Scrollen gekoppelt ist (Transform via v3.js). Kacheln klickbar -> Lightbox. */
.v3-adwall{ position:relative; height:clamp(380px,46vw,520px); overflow:hidden; border-radius:18px; display:grid; grid-template-columns:1fr 1fr; gap:12px;
  -webkit-mask-image:linear-gradient(180deg,transparent 0,#000 11%,#000 89%,transparent 100%);
  mask-image:linear-gradient(180deg,transparent 0,#000 11%,#000 89%,transparent 100%); }
.v3-adwall__col{ display:block; will-change:transform; }
.v3-adwall__tile{ display:block; width:100%; aspect-ratio:1; margin-bottom:12px; border:none; padding:0; -webkit-appearance:none; appearance:none; cursor:pointer; background-color:#ece6db; background-size:cover; background-position:center; border-radius:12px; box-shadow:0 10px 26px rgba(28,26,23,.16); transition:transform .28s var(--ease), box-shadow .28s var(--ease); }
.v3-adwall__tile:hover{ transform:scale(1.035); box-shadow:0 18px 40px rgba(28,26,23,.28); position:relative; z-index:2; }
.v3-adwall__tile:focus-visible{ outline:3px solid #fff; outline-offset:3px; }
.v3-adwall__live{ position:absolute; left:14px; bottom:14px; z-index:3; pointer-events:none; display:inline-flex; align-items:center; gap:8px; background:rgba(28,26,23,.82); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); color:#fff; font:700 11px/1 var(--fd); letter-spacing:.09em; text-transform:uppercase; padding:8px 13px; border-radius:var(--r-pill); box-shadow:0 6px 18px rgba(0,0,0,.28); }
.v3-adwall__live i{ width:8px; height:8px; border-radius:50%; background:#3ec77a; animation:v3AdPulse 1.8s ease-out infinite; }
@keyframes v3AdPulse{ 0%{box-shadow:0 0 0 0 rgba(62,199,122,.55)} 70%{box-shadow:0 0 0 9px rgba(62,199,122,0)} 100%{box-shadow:0 0 0 0 rgba(62,199,122,0)} }
@media(prefers-reduced-motion:reduce){ .v3-adwall__live i{ animation:none; } }

/* Lightbox für Anzeigen-Detailansicht */
.v3-adlb{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; padding:clamp(16px,4vw,40px); background:rgba(16,12,10,.86); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s; }
.v3-adlb.is-open{ opacity:1; visibility:visible; }
.v3-adlb__img{ max-width:min(94vw,640px); max-height:88vh; width:auto; height:auto; border-radius:16px; box-shadow:0 36px 90px rgba(0,0,0,.55); transform:scale(.96); transition:transform .28s var(--ease); }
.v3-adlb.is-open .v3-adlb__img{ transform:scale(1); }
.v3-adlb__close{ position:absolute; top:clamp(12px,3vw,24px); right:clamp(14px,3vw,28px); width:46px; height:46px; border:none; border-radius:50%; background:rgba(255,255,255,.14); color:#fff; font-size:30px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.v3-adlb__close:hover{ background:rgba(255,255,255,.28); }
.v3-adlb__close:focus-visible{ outline:2px solid #fff; outline-offset:2px; }

/* Pull-Quote in den "Was anders"-Zeilen (z.B. Paul F. an der Ad-Wand) */
.v3-row__quote{ margin:22px 0 0; padding:6px 0 6px 18px; border-left:3px solid var(--burg); font-family:var(--fd); font-size:clamp(15px,1.4vw,17px); line-height:1.55; color:var(--ink); }
.v3-row__quote cite{ display:block; margin-top:8px; font-size:13px; font-weight:600; font-style:normal; color:var(--burg); letter-spacing:.02em; }

/* Google-Bewertungen (live) */
.v3-grev__head{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 16px;margin-top:14px;font-size:1.02rem;color:var(--muted)}
.v3-grev__head b{font-family:var(--fd);font-weight:800;font-size:1.5rem;color:var(--ink)}
.v3-grev__stars{color:#f5a623;letter-spacing:2px;font-size:1.15rem}
.v3-grev__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;max-width:1080px;margin:0 auto}
@media(max-width:880px){.v3-grev__grid{grid-template-columns:1fr;max-width:560px}}
.v3-grev__card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:26px;box-shadow:0 10px 30px rgba(28,26,23,.06);display:flex;flex-direction:column;gap:13px}
.v3-grev__ctop{display:flex;align-items:center;gap:12px}
.v3-grev__av{position:relative;overflow:hidden;width:44px;height:44px;border-radius:50%;background:#ece6db;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;color:#fff}
.v3-grev__av img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.v3-grev__name{font-family:var(--fd);font-weight:700;color:var(--ink);line-height:1.2}
.v3-grev__when{font-size:.82rem;color:var(--muted)}
.v3-grev__rt{color:#f5a623;letter-spacing:1px;font-size:.95rem}
.v3-grev__g{margin-left:auto;flex-shrink:0}
.v3-grev__text{color:var(--muted);line-height:1.62;font-size:.96rem;margin:0}

/* ── M3: iOS-Auto-Zoom verhindern — Formularfelder mind. 16px auf Mobile (2026-06-24) ── */
@media (max-width: 768px) {
  input:not([type=checkbox]):not([type=radio]),
  select,
  textarea { font-size: 16px !important; }
}
