/* =========================================================
   VS Immoservice GmbH – Corporate Stylesheet
   CI: Primary Dark #2C2724 / Background #F7F2EC
       Brand #B09A6E / Accent #D9C49A
   ========================================================= */

:root {
  --c-dark: #2C2724;
  --c-bg: #F7F2EC;
  --c-brand: #B09A6E;
  --c-accent: #D9C49A;
  --c-dark-soft: #3a322d;
  --c-muted: #6b605a;
  --c-line: #e6dccd;
  --c-white: #ffffff;
  --c-success: #4f7a4a;
  --c-error: #b14a3b;

  --shadow-sm: 0 2px 12px rgba(44, 39, 36, 0.06);
  --shadow-md: 0 10px 40px rgba(44, 39, 36, 0.10);
  --shadow-lg: 0 25px 70px rgba(44, 39, 36, 0.14);

  --radius-sm: 6px;
  --radius-md: 12px;
  --radius-lg: 20px;

  --font-head: "Cormorant Garamond", "Georgia", serif;
  --font-body: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --container: 1240px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.7;
  color:var(--c-dark);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block;height:auto}
a{color:var(--c-brand);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--c-dark)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{margin:0;padding:0;list-style:none}
input,textarea,select{font:inherit;color:inherit}

/* ---------- Typography ---------- */
h1,h2,h3,h4,h5{
  font-family:var(--font-head);
  font-weight:600;
  letter-spacing:-.01em;
  color:var(--c-dark);
  margin:0 0 .6em;
  line-height:1.15;
}
h1{font-size:clamp(2.4rem,5.2vw,4.4rem);font-weight:600}
h2{font-size:clamp(2rem,3.8vw,3.2rem)}
h3{font-size:clamp(1.4rem,2.2vw,1.8rem)}
h4{font-size:1.2rem}
p{margin:0 0 1.1em}
.eyebrow{
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--c-brand);
  margin-bottom:1rem;
  display:inline-block;
}
.lead{font-size:1.18rem;color:var(--c-muted);line-height:1.65;max-width:680px}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding:clamp(52px,7vw,88px) 0}
.section-tight{padding:clamp(40px,5vw,64px) 0}
.section--dark{background:var(--c-dark);color:#e7ddd0}
.section--dark h1,.section--dark h2,.section--dark h3{color:var(--c-bg)}
.section--dark .eyebrow{color:var(--c-accent)}
.section--dark .feature-list strong{color:var(--c-bg)}
.section--dark .feature-list p{color:#bdb1a0}
.section--dark .feature-list li{border-color:rgba(217,196,154,.15)}
.section--dark .feature-list .ico{background:var(--c-accent);color:var(--c-dark)}
.section--brand{background:var(--c-brand);color:var(--c-bg)}
.section--brand h1,.section--brand h2,.section--brand h3{color:var(--c-bg)}
.section--brand .eyebrow{color:var(--c-bg);opacity:.9}
.section-head{max-width:760px;margin:0 auto 56px;text-align:center}
.section-head.left{margin-left:0;text-align:left}
.grid{display:grid;gap:32px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:960px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-2{grid-template-columns:1fr}
}
@media (max-width:640px){
  .grid-3,.grid-4{grid-template-columns:1fr}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:16px 32px;
  border-radius:var(--radius-sm);
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.02em;
  transition:all .25s var(--ease);
  cursor:pointer;
  text-align:center;
  border:1.5px solid transparent;
  line-height:1;
}
.btn-primary{background:var(--c-brand);color:var(--c-bg)}
.btn-primary:hover{background:var(--c-dark);color:var(--c-bg);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-dark{background:var(--c-dark);color:var(--c-bg)}
.btn-dark:hover{background:var(--c-brand);color:var(--c-bg);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;color:var(--c-dark);border-color:var(--c-dark)}
.btn-outline:hover{background:var(--c-dark);color:var(--c-bg)}
.btn-ghost{background:transparent;color:var(--c-brand);border-color:var(--c-brand)}
.btn-ghost:hover{background:var(--c-brand);color:var(--c-bg)}
.btn-light{background:var(--c-bg);color:var(--c-dark)}
.btn-light:hover{background:var(--c-accent);color:var(--c-dark)}
.btn-arrow::after{content:"→";transition:transform .25s var(--ease)}
.btn-arrow:hover::after{transform:translateX(4px)}
.btn-sm{padding:11px 20px;font-size:.85rem}
.btn-lg{padding:20px 38px;font-size:1rem}

/* ---------- Header / Navigation ---------- */
.topbar{
  background:var(--c-dark);
  color:var(--c-bg);
  font-size:.82rem;
  padding:8px 0;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.topbar a{color:var(--c-bg);opacity:.85}
.topbar a:hover{opacity:1;color:var(--c-accent)}
.topbar-contact{display:flex;gap:24px;align-items:center}
.topbar-contact span{display:inline-flex;align-items:center;gap:8px}
.topbar-ico{width:16px;height:16px;flex-shrink:0;object-fit:contain;border-radius:50%}

.header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(247,242,236,.95);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--c-line);
  transition:box-shadow .2s var(--ease);
}
.header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0;gap:32px}
.logo{
  font-family:var(--font-head);
  font-weight:700;
  font-size:1.3rem;
  color:var(--c-dark);
  letter-spacing:.04em;
  display:flex;
  align-items:center;
  gap:12px;
  white-space:nowrap;
  flex-shrink:0;
}
.logo-mark{
  width:42px;height:42px;
  background:var(--c-brand);
  color:var(--c-bg);
  display:flex;align-items:center;justify-content:center;
  border-radius:var(--radius-sm);
  font-family:var(--font-head);
  font-weight:700;
  font-size:1.05rem;
  letter-spacing:.05em;
  flex-shrink:0;
}
.logo-text{display:flex;flex-direction:column;line-height:1;gap:4px;white-space:nowrap}
.logo-text small{font-family:var(--font-body);font-size:.58rem;font-weight:500;letter-spacing:.2em;color:var(--c-brand);text-transform:uppercase}

.nav-menu{display:flex;align-items:center;gap:2px;flex-wrap:nowrap}
.nav-menu a{
  color:var(--c-dark);
  font-weight:500;
  font-size:.9rem;
  padding:10px 12px;
  border-radius:var(--radius-sm);
  position:relative;
  white-space:nowrap;
}
.nav-menu a:hover{color:var(--c-brand)}
.nav-menu a.active{color:var(--c-brand)}
.nav-menu a.active::after{
  content:"";position:absolute;left:14px;right:14px;bottom:4px;height:2px;background:var(--c-brand);
}
.nav-cta{margin-left:8px}

.burger{display:none;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.burger span{width:24px;height:2px;background:var(--c-dark);transition:all .25s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Auf etwas größeren Screens leicht komprimieren, damit die Items in eine Zeile passen */
@media (max-width:1280px){
  .nav-menu a{font-size:.85rem;padding:9px 9px}
  .nav-menu{gap:0}
  .logo{font-size:1.2rem}
  .logo-text small{font-size:.55rem;letter-spacing:.18em}
}

@media (max-width:1180px){
  .nav-menu{
    position:fixed;
    inset:0 0 0 0;
    top:0;
    flex-direction:column;
    background:var(--c-bg);
    padding:120px 32px 40px;
    gap:8px;
    transform:translateX(100%);
    transition:transform .35s var(--ease);
    z-index:90;
    overflow-y:auto;
    align-items:stretch;
  }
  .nav-menu.open{transform:translateX(0)}
  .nav-menu a{font-size:1.3rem;padding:14px 0;border-bottom:1px solid var(--c-line);border-radius:0}
  .nav-menu .nav-cta{margin:18px 0 0}
  .burger{display:flex}
}

/* ---------- Hero (light, cutout pattern) ---------- */
.hero{
  position:relative;
  background:var(--c-bg);
  padding:20px 0 40px;
  overflow:hidden;
}
.hero::before{
  /* Sanfter Akzent-Schein hinter der Person */
  content:"";position:absolute;
  top:-200px;right:-200px;width:900px;height:900px;
  background:radial-gradient(circle, var(--c-accent) 0%, rgba(217,196,154,0) 65%);
  opacity:.35;
  z-index:0;
  pointer-events:none;
}
.hero::after{
  /* Dezentes Linien-Pattern als Untergrund */
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M0 0h40v40H0z' fill='none' stroke='%23B09A6E' stroke-width='.4' opacity='.25'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.4;
  pointer-events:none;
  z-index:0;
}
.hero .container{position:relative;z-index:2}

.hero-grid{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:50px;
  align-items:center;
  min-height:560px;
}

/* === Linke Spalte: Text === */
.hero-content{position:relative;z-index:2}
.hero-trust-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:99px;
  padding:9px 18px;
  font-size:.82rem;
  font-weight:500;
  color:var(--c-dark);
  box-shadow:0 4px 14px rgba(44,39,36,.06);
  margin-bottom:24px;
}
.hero-trust-pill .star{color:var(--c-brand);font-size:1rem;line-height:1}
.hero-content h1{
  color:var(--c-dark);
  margin-bottom:20px;
}
.hero-content h1 em{color:var(--c-brand);font-style:italic;font-weight:500}
.hero-content .lead{color:var(--c-muted);max-width:540px;margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:36px}

.hero-meta{
  display:flex;
  align-items:center;
  gap:18px;
  padding-top:24px;
  border-top:1px solid var(--c-line);
}
.hero-meta-stats{
  display:flex;flex-wrap:wrap;gap:18px 28px;
  font-size:.82rem;color:var(--c-muted);
}
.hero-meta-stats div{display:flex;flex-direction:column;gap:2px}
.hero-meta-stats strong{
  font-family:var(--font-head);font-size:1.5rem;color:var(--c-dark);
  font-weight:600;line-height:1;
}
.hero-meta-stats span{letter-spacing:.05em}

/* === Rechte Spalte: Cutout + Pills === */
.hero-portrait{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:flex-end;
  min-height:560px;
}
.hero-portrait-bg{
  /* Sanfter Akzent-Kreis hinter dem Cutout */
  position:absolute;
  bottom:40px;
  left:50%;
  transform:translateX(-50%);
  width:440px;height:440px;
  background:radial-gradient(circle at 50% 55%, var(--c-accent) 0%, rgba(217,196,154,.35) 55%, rgba(217,196,154,0) 78%);
  border-radius:50%;
  z-index:1;
}
.hero-portrait-building{
  /* Apartment-Foto blass hinter Viktoriya, groß und statisch */
  position:absolute;
  top:0;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:720px;
  background-image:url("../images/hero-building-lg.webp");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  opacity:.22;
  z-index:1;
  pointer-events:none;
  -webkit-mask-image:radial-gradient(ellipse at 50% 50%, rgba(0,0,0,1) 25%, rgba(0,0,0,.7) 55%, rgba(0,0,0,0) 80%);
  mask-image:radial-gradient(ellipse at 50% 50%, rgba(0,0,0,1) 25%, rgba(0,0,0,.7) 55%, rgba(0,0,0,0) 80%);
}
@media (max-width:1024px){
  .hero-portrait-building{width:560px}
}
@media (max-width:640px){
  .hero-portrait-building{width:380px}
}
.hero-portrait-img{
  position:relative;
  z-index:2;
  display:block;
  max-height:600px;
  width:auto;
  height:auto;
  filter:drop-shadow(0 24px 40px rgba(44,39,36,.20));
}

/* Service-Pills */
.hero-pill{
  position:absolute;
  z-index:3;
  display:inline-flex;align-items:center;gap:9px;
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:99px;
  padding:11px 18px;
  font-size:.82rem;
  font-weight:500;
  color:var(--c-dark);
  box-shadow:0 12px 30px rgba(44,39,36,.10);
  white-space:nowrap;
}
.hero-pill .ico{
  width:32px;height:32px;
  display:inline-block;
  flex-shrink:0;
  object-fit:contain;
  border-radius:50%;
}
/* Zickzack-Verteilung, Pills schwingen seitlich ab vom Porträt */
.hero-pill-1{top:4%;right:-30px}
.hero-pill-2{top:28%;left:-50px}
.hero-pill-3{top:50%;right:-30px}
.hero-pill-4{top:72%;left:-40px}
.hero-pill-5{bottom:4%;right:5%}

/* === Responsive === */
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;gap:30px;min-height:0}
  .hero-portrait{min-height:480px;order:2}
  .hero-portrait-img{max-height:480px}
  .hero-portrait-bg{width:340px;height:340px;bottom:30px}
  .hero-pill-1{top:3%;right:-15px;font-size:.78rem}
  .hero-pill-2{top:26%;left:-25px;font-size:.78rem}
  .hero-pill-3{top:48%;right:-15px;font-size:.78rem}
  .hero-pill-4{top:70%;left:-20px;font-size:.78rem}
  .hero-pill-5{bottom:4%;right:5%;font-size:.78rem}
}
@media (max-width:640px){
  .hero{padding:16px 0 24px}
  .hero-portrait{min-height:380px}
  .hero-portrait-img{max-height:380px}
  .hero-portrait-bg{width:260px;height:260px}
  .hero-pill{padding:8px 14px;font-size:.74rem;animation:none}
  .hero-pill-1{top:2%;right:-15px}
  .hero-pill-2{top:22%;left:-20px}
  .hero-pill-3{top:46%;right:-15px}
  .hero-pill-4{top:68%;left:-15px}
  .hero-pill-5{bottom:3%;right:2%}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:14px}
  .hero-meta-stats{gap:14px 20px}
  .hero-meta-stats strong{font-size:1.25rem}
}
.hero-placeholder{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#3a322d 0%,#2C2724 60%,#1d1815 100%);
  z-index:-1;
}
.hero-inner{position:relative;z-index:2;color:var(--c-bg);max-width:780px}
/* (Alte dunkle Hero-Farben entfernt – Hero ist jetzt hell, siehe .hero-content) */
.hero-cta{display:flex;flex-wrap:wrap;gap:16px;margin-top:36px}
.hero-trust{
  display:flex;flex-wrap:wrap;gap:36px;margin-top:56px;
  padding-top:32px;border-top:1px solid rgba(217,196,154,.25);
}
.hero-trust-item{display:flex;flex-direction:column;gap:2px}
.hero-trust-item strong{font-family:var(--font-head);font-size:2rem;color:var(--c-accent);font-weight:600;line-height:1}
.hero-trust-item span{font-size:.85rem;color:rgba(247,242,236,.7);letter-spacing:.05em}

/* Sub-hero mit Bild im Hintergrund – einheitliche Höhe für alle Unterseiten */
.sub-hero{
  position:relative;
  padding:64px 0;
  min-height:440px;
  display:flex;
  align-items:center;
  background:linear-gradient(135deg,#3a322d 0%,#2C2724 100%);
  color:var(--c-bg);
  overflow:hidden;
}
.sub-hero .container{width:100%}
/* Kleinere Headlines im Sub-Hero, damit alle Seiten visuell gleich hoch wirken */
.sub-hero h1{
  font-size:clamp(1.7rem,3vw,2.3rem);
  line-height:1.18;
  margin-bottom:14px;
}
.sub-hero p{
  font-size:1rem;
  line-height:1.6;
  max-width:600px;
}
.sub-hero-image{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(135deg,#3a322d 0%,#2C2724 100%);
}
.sub-hero-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 35%;
  display:block;
}
.sub-hero::before{
  /* Dunkles Overlay über dem Bild */
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(95deg, rgba(28,24,21,.78) 0%, rgba(44,39,36,.55) 38%, rgba(44,39,36,.22) 65%, rgba(44,39,36,.06) 100%);
}
.sub-hero::after{
  /* Dezentes Pattern-Overlay */
  content:"";position:absolute;inset:0;z-index:1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='60' height='60' patternUnits='userSpaceOnUse'><path d='M0 0h60v60H0z' fill='none' stroke='%23D9C49A' stroke-width='.25' opacity='.25'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.22;
  pointer-events:none;
}
.sub-hero-inner{position:relative;z-index:2;max-width:720px}
.sub-hero h1{color:var(--c-bg)}
.sub-hero h1 em{color:var(--c-accent);font-style:italic;font-weight:500}
.sub-hero .eyebrow{color:var(--c-accent)}
.sub-hero p{color:rgba(247,242,236,.88)}
.breadcrumb{font-size:.85rem;margin-bottom:24px;color:rgba(247,242,236,.6)}
.breadcrumb a{color:rgba(247,242,236,.85)}
.breadcrumb a:hover{color:var(--c-accent)}
.breadcrumb span{margin:0 8px;opacity:.5}
@media (max-width:900px){
  .sub-hero::before{background:linear-gradient(180deg, rgba(28,24,21,.55) 0%, rgba(44,39,36,.65) 55%, rgba(44,39,36,.85) 100%)}
}

/* ---------- Cards ---------- */
.card{
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
  padding:36px 32px;
  transition:all .25s var(--ease);
  height:100%;
  display:flex;
  flex-direction:column;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--c-accent)}
.card-icon{
  width:64px;height:64px;
  display:flex;align-items:center;justify-content:center;
  background:var(--c-accent);color:var(--c-dark);
  border-radius:var(--radius-sm);
  margin-bottom:24px;
  font-size:1.5rem;
}
.card-icon img{width:42px;height:42px;display:block}
/* Bare-Variante: ohne goldenen Hintergrund (für Icons mit eigenem Design) */
.card-icon--bare{
  width:auto;height:auto;
  background:transparent;
  margin-bottom:18px;
  padding:0;
}
.card-icon--bare img{width:96px;height:96px}
/* Kleinere Variante für enge Card-Layouts (z.B. 4er-Grid Standardausstattung) */
.card-icon--bare.size-sm img{width:64px;height:64px}

/* Feature-List Icon-Variante (Bild statt Häkchen/Emoji) */
.feature-list .ico-img{
  width:44px;height:44px;
  background:transparent;
  padding:0;
  flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
}
.feature-list .ico-img img{width:100%;height:100%;display:block;object-fit:contain}
.card h3{font-size:1.4rem;margin-bottom:14px}
.card p{color:var(--c-muted);margin:0}
.card-link{margin-top:auto;padding-top:20px;color:var(--c-brand);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:6px}
.card-link:hover{gap:10px;color:var(--c-dark)}

.card-feature{
  background:var(--c-bg);
  border:1px solid var(--c-line);
  padding:40px 40px 36px;
  border-radius:var(--radius-md);
  position:relative;
  overflow:hidden;
}
.card-feature .num{
  position:absolute;top:18px;right:28px;
  font-family:var(--font-head);font-size:3.2rem;font-weight:600;
  color:var(--c-accent);line-height:1;
  opacity:.55;
  z-index:0;
  pointer-events:none;
}
.card-feature > h3,
.card-feature > p{position:relative;z-index:1}
.card-feature h3{padding-right:60px;margin-bottom:14px}

/* ---------- Feature panels (text instead of image) ---------- */
.feature-panel{
  background:linear-gradient(160deg,#3a322d 0%,#2C2724 100%);
  color:var(--c-bg);
  padding:clamp(36px,5vw,56px);
  border-radius:var(--radius-md);
  min-height:340px;
  display:flex;flex-direction:column;justify-content:center;
  position:relative;
  overflow:hidden;
}
.feature-panel::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M0 0h40v40H0z' fill='none' stroke='%23D9C49A' stroke-width='.25' opacity='.35'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.5;pointer-events:none;
}
.feature-panel > *{position:relative;z-index:1}
.feature-panel-title{
  font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.4rem);
  font-weight:600;color:var(--c-accent);margin-bottom:24px;line-height:1.15;
}
.feature-panel-list{display:flex;flex-direction:column;gap:14px}
.feature-panel-list li{
  padding-left:22px;position:relative;font-size:1rem;line-height:1.55;color:rgba(247,242,236,.92);
}
.feature-panel-list li::before{
  content:"";position:absolute;left:0;top:11px;
  width:10px;height:1.5px;background:var(--c-accent);
}
.feature-panel-list strong{color:var(--c-bg);font-weight:600}
.feature-panel-stats{
  display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;
  margin-top:6px;
}
.feature-panel-stats > div{display:flex;flex-direction:column;gap:4px}
.feature-panel-stats strong{
  font-family:var(--font-head);font-size:2.6rem;color:var(--c-brand);
  font-weight:600;line-height:1;
}
.feature-panel-stats span{font-size:.85rem;letter-spacing:.04em;color:var(--c-dark-soft);opacity:.85}
.feature-panel--accent{
  background:linear-gradient(160deg,var(--c-accent) 0%,#c8b384 100%);
  color:var(--c-dark);
}
.feature-panel--accent .feature-panel-list li{color:var(--c-dark);opacity:.92}
.feature-panel--accent .feature-panel-list li::before{background:var(--c-dark)}
.feature-panel--accent .feature-panel-list strong{color:var(--c-dark)}
.feature-panel--accent .feature-panel-title{color:var(--c-dark)}
.feature-panel--accent .eyebrow{color:var(--c-dark);opacity:.75}
.feature-panel--accent .feature-panel-stats strong{color:var(--c-dark)}
.feature-panel--accent .feature-panel-stats span{color:var(--c-dark);opacity:.78}
.feature-panel--light{
  background:var(--c-bg);
  color:var(--c-dark);
  border:1px solid var(--c-line);
}
.feature-panel--light .feature-panel-title{color:var(--c-brand)}
.feature-panel--light .feature-panel-list li{color:var(--c-dark)}
.feature-panel--light .feature-panel-list li::before{background:var(--c-brand)}

/* ---------- Image cards (Portraits etc.) ---------- */
.media{
  position:relative;
  border-radius:var(--radius-md);
  overflow:hidden;
  aspect-ratio:4/5;
  background:var(--c-accent);
  box-shadow:var(--shadow-md);
}
.media img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  display:block;
}
.media--tall{aspect-ratio:3/4}
.media--portrait{aspect-ratio:4/5}
.media--square{aspect-ratio:1/1}
.media--frame{
  border:1px solid var(--c-line);
}
.media--accent-frame{
  border:8px solid var(--c-accent);
}

/* ---------- Image placeholders ---------- */
.img-placeholder{
  background:
    linear-gradient(135deg,#D9C49A 0%,#B09A6E 100%);
  border-radius:var(--radius-md);
  position:relative;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.8);
  font-family:var(--font-head);
  font-size:1.1rem;
  letter-spacing:.05em;
  min-height:300px;
}
.img-placeholder::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'><defs><pattern id='dots' width='20' height='20' patternUnits='userSpaceOnUse'><circle cx='10' cy='10' r='1.2' fill='%23F7F2EC' opacity='.35'/></pattern></defs><rect width='200' height='200' fill='url(%23dots)'/></svg>");
  opacity:.6;
}
.img-placeholder::after{
  content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:64px;height:64px;
  background:rgba(247,242,236,.18);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.img-placeholder span{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-size:.85rem;letter-spacing:.18em;text-transform:uppercase;
  color:rgba(247,242,236,.95);font-family:var(--font-body);font-weight:500;
}
.img-placeholder span::before{
  content:"";width:34px;height:34px;
  background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23F7F2EC' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='3' width='18' height='18' rx='2' ry='2'/><circle cx='8.5' cy='8.5' r='1.5'/><polyline points='21 15 16 10 5 21'/></svg>") center/contain no-repeat;
}
.img-placeholder--tall{min-height:520px}
.img-placeholder--portrait{aspect-ratio:3/4;min-height:0}
.img-placeholder--apartment span::after{
  content:"Apartment-Foto";
}
.img-placeholder--dark{background:linear-gradient(135deg,#3a322d,#2C2724)}

/* ---------- USP / Trust strip ---------- */
.trust-strip{
  background:var(--c-dark);color:var(--c-bg);
  padding:36px 0;
}
.trust-strip .grid-4{gap:16px}
.trust-item{display:flex;align-items:center;gap:14px;justify-content:center;text-align:center;flex-direction:column;padding:6px}
.trust-item strong{font-family:var(--font-head);font-size:2.4rem;color:var(--c-accent);line-height:1;font-weight:600}
.trust-item span{font-size:.85rem;letter-spacing:.05em;opacity:.85}

/* ---------- Locations chips ---------- */
.locations{
  display:flex;flex-wrap:wrap;gap:10px;
  justify-content:center;
}
.location-chip{
  background:var(--c-white);
  border:1px solid var(--c-line);
  padding:10px 18px;
  border-radius:99px;
  font-size:.9rem;
  color:var(--c-dark);
  font-weight:500;
  transition:all .2s var(--ease);
}
.location-chip:hover{background:var(--c-accent);border-color:var(--c-accent);color:var(--c-dark)}

/* ---------- Features (icon list) ---------- */
.feature-list{display:grid;gap:20px}
.feature-list li{
  display:flex;gap:16px;align-items:flex-start;
  padding:18px 0;border-bottom:1px solid var(--c-line);
}
.feature-list li:last-child{border-bottom:none}
.feature-list .ico{
  flex-shrink:0;
  width:40px;height:40px;
  background:var(--c-accent);
  color:var(--c-dark);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:600;
}
.feature-list .ico-wa{
  flex-shrink:0;
  width:40px;height:40px;
  background:#f5e9d7;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.feature-list .ico-wa svg{width:24px;height:24px;fill:var(--c-brand)}
.feature-list strong{display:block;color:var(--c-dark);font-size:1.05rem;margin-bottom:4px;font-weight:600}
.feature-list p{margin:0;color:var(--c-muted);font-size:.95rem}

/* ---------- Process steps ---------- */
.steps{counter-reset:step;display:grid;gap:32px}
.step{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:24px;
  align-items:flex-start;
  padding:32px;
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
}
.step-num{
  width:64px;height:64px;
  background:var(--c-brand);color:var(--c-bg);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1.7rem;font-weight:600;
}
.step h3{margin-bottom:8px}
.step p{margin:0;color:var(--c-muted)}
@media (max-width:640px){
  .step{grid-template-columns:1fr;text-align:left}
}

/* ---------- Quote Feature (großes Statement auf dunklem BG) ---------- */
.quote-feature{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:48px;
  align-items:center;
  max-width:1000px;
  margin:0 auto;
  padding:48px;
  background:linear-gradient(135deg, rgba(217,196,154,.08) 0%, rgba(176,154,110,.04) 100%);
  border:1px solid rgba(217,196,154,.18);
  border-radius:var(--radius-md);
  position:relative;
  overflow:hidden;
}
.quote-feature::before{
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M0 0h40v40H0z' fill='none' stroke='%23D9C49A' stroke-width='.4' opacity='.25'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.25;
  pointer-events:none;
}
.quote-feature > *{position:relative;z-index:1}
.quote-feature-img{
  border-radius:var(--radius-md);
  overflow:hidden;
  aspect-ratio:4/5;
  border:3px solid var(--c-accent);
}
.quote-feature-img img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.quote-feature-text{position:relative}
.quote-mark{
  position:absolute;
  top:-50px;left:-12px;
  font-family:var(--font-head);
  font-size:9rem;
  line-height:1;
  color:var(--c-accent);
  opacity:.55;
  pointer-events:none;
}
.quote-feature blockquote{
  font-family:var(--font-head);
  font-style:italic;
  font-size:clamp(1.4rem,2.2vw,1.85rem);
  line-height:1.45;
  color:var(--c-bg);
  margin:0 0 24px;
  padding:0;
}
.quote-feature-author{display:flex;flex-direction:column;gap:4px}
.quote-feature-author strong{
  font-family:var(--font-body);
  font-size:1.05rem;
  font-weight:600;
  color:var(--c-accent);
  letter-spacing:.02em;
}
.quote-feature-author span{
  font-size:.88rem;
  color:rgba(247,242,236,.7);
  letter-spacing:.02em;
}
@media (max-width:760px){
  .quote-feature{
    grid-template-columns:1fr;
    gap:28px;
    padding:32px 24px;
  }
  .quote-feature-img{max-width:220px;margin:0 auto;aspect-ratio:3/4}
  .quote-mark{font-size:6rem;top:-30px;left:-4px}
  .quote-feature blockquote{font-size:1.2rem}
}

/* ---------- Testimonial / Quote ---------- */
.quote-card{
  background:var(--c-accent);
  border-radius:var(--radius-md);
  padding:48px;
  position:relative;
}
.quote-card::before{
  content:"\201C";
  position:absolute;top:-20px;left:32px;
  font-family:var(--font-head);font-size:6rem;
  color:var(--c-brand);line-height:1;
  opacity:.7;
}
.quote-card p{font-family:var(--font-head);font-style:italic;font-size:1.3rem;line-height:1.5;color:var(--c-dark)}
.quote-author{display:flex;align-items:center;gap:14px;margin-top:20px}
.quote-author-name{font-weight:600;color:var(--c-dark)}
.quote-author-role{font-size:.85rem;color:var(--c-dark-soft);opacity:.7}

/* ---------- CTA section ---------- */
.cta-section{
  background:
    linear-gradient(135deg, rgba(44,39,36,.78) 0%, rgba(58,50,45,.72) 60%, rgba(176,154,110,.62) 100%),
    url("../images/hero-building-lg.webp") center center / cover no-repeat;
  border-radius:var(--radius-lg);
  padding:clamp(48px,7vw,80px);
  color:var(--c-bg);
  text-align:center;
  position:relative;
  overflow:hidden;
}
.cta-section::after{
  /* Subtiles Pattern-Overlay */
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M0 0h40v40H0z' fill='none' stroke='%23D9C49A' stroke-width='.5' opacity='.4'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.25;
}
.cta-section > *{position:relative;z-index:1}
.cta-section h2{color:var(--c-bg);max-width:600px;margin:0 auto 16px}
.cta-section p{color:rgba(247,242,236,.95);max-width:560px;margin:0 auto 32px;font-size:1.1rem}
.cta-section .btn{box-shadow:var(--shadow-md)}

/* ---------- Forms ---------- */
.form{
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
  padding:clamp(22px,3vw,34px);
  box-shadow:var(--shadow-sm);
}
.form h3{margin-top:0;margin-bottom:6px;font-size:1.35rem}
.form > p{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row.single{grid-template-columns:1fr}
@media (max-width:640px){.form-row{grid-template-columns:1fr}}
.field{margin-bottom:12px;display:flex;flex-direction:column;gap:4px}
.field label{font-size:.82rem;font-weight:500;color:var(--c-dark);letter-spacing:.02em}
.field label .req{color:var(--c-brand)}
.field input,.field select,.field textarea{
  width:100%;
  padding:11px 14px;
  border:1.5px solid var(--c-line);
  background:var(--c-bg);
  border-radius:var(--radius-sm);
  font-size:.92rem;
  color:var(--c-dark);
  transition:all .2s var(--ease);
  font-family:inherit;
}
.field textarea{resize:vertical;min-height:88px}
/* Datei-Upload-Felder */
.field input[type="file"]{
  padding:8px 10px;
  cursor:pointer;
  border-style:dashed;
  background:var(--c-white);
}
.field input[type="file"]::file-selector-button{
  background:var(--c-brand);
  color:var(--c-bg);
  border:none;
  padding:8px 14px;
  border-radius:var(--radius-sm);
  font-family:inherit;
  font-weight:600;
  font-size:.85rem;
  cursor:pointer;
  margin-right:12px;
  transition:background .2s var(--ease);
}
.field input[type="file"]::file-selector-button:hover{
  background:var(--c-dark);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;
  border-color:var(--c-brand);
  background:var(--c-white);
  box-shadow:0 0 0 4px rgba(176,154,110,.12);
}
.field-checkbox{
  display:flex;
  flex-direction:row;
  align-items:flex-start;
  gap:12px;
  font-size:.88rem;
  color:var(--c-muted);
  line-height:1.5;
}
.field-checkbox input{
  margin:0;
  margin-top:calc((1em * 1.5 - 18px) / 2);
  width:18px;height:18px;
  accent-color:var(--c-brand);
  flex-shrink:0;
}
.field-checkbox label{
  font-size:inherit;
  line-height:1.5;
  cursor:pointer;
  flex:1;
}
.form .btn{width:100%;margin-top:4px}
.form-note{font-size:.78rem;color:var(--c-muted);margin-top:10px;text-align:center}
.form-success{display:none;text-align:center;padding:30px 20px;background:#eef5ed;border:1px solid #c8dec5;border-radius:var(--radius-sm);color:#3d6438}
.form-success.show{display:block}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--c-line);
}
.faq-item:first-child{border-top:1px solid var(--c-line)}
.faq-q{
  width:100%;text-align:left;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding:24px 0;
  font-family:var(--font-head);font-size:1.25rem;font-weight:600;color:var(--c-dark);
  cursor:pointer;
}
.faq-q .plus{
  flex-shrink:0;
  width:32px;height:32px;border-radius:50%;
  background:var(--c-bg);border:1px solid var(--c-line);
  display:flex;align-items:center;justify-content:center;
  color:var(--c-brand);font-size:1.3rem;font-weight:300;
  transition:all .25s var(--ease);
}
.faq-item.open .plus{background:var(--c-brand);color:var(--c-bg);transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s var(--ease);
  color:var(--c-muted);
}
.faq-item.open .faq-a{max-height:600px}
.faq-a-inner{padding:0 0 24px;font-size:1rem;line-height:1.7}

/* ---------- Apartments / Listing tiles ---------- */
.listing{position:relative;border-radius:var(--radius-md);overflow:hidden;background:var(--c-white);border:1px solid var(--c-line);transition:all .25s var(--ease)}
.listing:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.listing-img{aspect-ratio:4/3}
.listing-img .img-placeholder{min-height:0;height:100%;border-radius:0}
.listing-body{padding:24px}
.listing-tag{display:inline-block;background:var(--c-accent);color:var(--c-dark);font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:4px;margin-bottom:10px}
.listing h3{font-size:1.3rem;margin-bottom:6px}
.listing .listing-meta{color:var(--c-muted);font-size:.92rem;margin-bottom:14px}
.listing-features{display:flex;flex-wrap:wrap;gap:6px}
.listing-features span{background:var(--c-bg);padding:5px 10px;border-radius:4px;font-size:.8rem;color:var(--c-dark-soft);border:1px solid var(--c-line)}

/* ---------- Two-column split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
#anfrage.section .split,
#kontaktformular .split{align-items:start}
@media (max-width:960px){.split{grid-template-columns:1fr;gap:40px}}
.split--reverse > div:first-child{order:2}
@media (max-width:960px){.split--reverse > div:first-child{order:0}}

/* ---------- Footer ---------- */
.footer{
  background:var(--c-dark);
  color:#d6c9b8;
  padding:72px 0 24px;
  font-size:.92rem;
}
.footer h4{
  color:var(--c-bg);
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin-bottom:20px;
}
.footer a{color:#d6c9b8}
.footer a:hover{color:var(--c-accent)}
.footer ul li{padding:6px 0}
.footer-logo{margin-bottom:20px}
.footer-brand p{color:#a89b8b;max-width:340px}
.footer-contact{display:flex;flex-direction:column;gap:12px}
.footer-contact a,.footer-contact .footer-contact-row{display:flex;align-items:center;gap:12px;color:#d6c9b8}
.footer-ico{width:24px;height:24px;flex-shrink:0;object-fit:contain;border-radius:50%}
.footer-ico-svg{width:24px;height:24px;flex-shrink:0;fill:var(--c-accent)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:start}
@media (max-width:768px){
  .footer-grid{grid-template-columns:1fr;gap:32px}
}
.footer-bottom{
  margin-top:56px;padding-top:24px;border-top:1px solid rgba(217,196,154,.15);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  font-size:.85rem;color:#8e8170;
}
.footer-bottom a{color:#a89b8b;margin-right:18px}
.footer-bottom a:last-child{margin-right:0}

/* ---------- Floating buttons (WhatsApp / Phone) ---------- */
.floating-actions{
  position:fixed;
  right:20px;bottom:20px;
  display:flex;flex-direction:column;gap:12px;
  z-index:80;
}
.floating-btn{
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  box-shadow:var(--shadow-md);
  transition:transform .2s var(--ease);
}
.floating-btn:hover{transform:scale(1.08)}
.floating-btn.whatsapp{background:#25D366}
.floating-btn.phone{background:var(--c-brand)}
.floating-btn svg{width:26px;height:26px;fill:currentColor}

/* ---------- Cookie Banner ---------- */
.cookie-banner{
  position:fixed;
  left:20px;right:20px;bottom:20px;
  max-width:520px;
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
  box-shadow:var(--shadow-lg);
  padding:28px;
  z-index:200;
  transform:translateY(calc(100% + 40px));
  transition:transform .4s var(--ease);
}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner h3{font-size:1.3rem;margin-bottom:10px}
.cookie-banner p{font-size:.9rem;color:var(--c-muted);margin-bottom:18px}
.cookie-actions{display:flex;flex-wrap:wrap;gap:8px}
.cookie-actions .btn{flex:1;min-width:140px;padding:12px 18px;font-size:.85rem}
.cookie-link{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--c-muted);cursor:pointer}
.cookie-link:hover{color:var(--c-dark);text-decoration:underline}

/* Cookie Settings Modal */
.cookie-modal{
  position:fixed;inset:0;
  background:rgba(44,39,36,.6);
  backdrop-filter:blur(6px);
  z-index:300;
  display:none;
  align-items:center;justify-content:center;
  padding:20px;
}
.cookie-modal.show{display:flex}
.cookie-modal-inner{
  background:var(--c-white);
  border-radius:var(--radius-md);
  padding:36px;
  max-width:600px;
  width:100%;
  max-height:90vh;overflow-y:auto;
}
.cookie-modal-inner h3{margin-bottom:8px}
.cookie-modal-inner > p{color:var(--c-muted);margin-bottom:24px;font-size:.92rem}
.cookie-cat{
  border:1px solid var(--c-line);
  border-radius:var(--radius-sm);
  padding:18px 20px;
  margin-bottom:14px;
}
.cookie-cat-head{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:8px}
.cookie-cat-head strong{font-family:var(--font-head);font-size:1.15rem;color:var(--c-dark);font-weight:600}
.cookie-cat-head .switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.cookie-cat-head .switch input{opacity:0;width:0;height:0}
.cookie-cat-head .slider{
  position:absolute;cursor:pointer;inset:0;
  background:#d2c7b7;
  border-radius:24px;
  transition:.25s;
}
.cookie-cat-head .slider::before{
  content:"";position:absolute;
  height:18px;width:18px;
  left:3px;bottom:3px;
  background:var(--c-white);
  border-radius:50%;
  transition:.25s;
}
.cookie-cat-head .switch input:checked + .slider{background:var(--c-brand)}
.cookie-cat-head .switch input:checked + .slider::before{transform:translateX(20px)}
.cookie-cat-head .switch input:disabled + .slider{background:var(--c-brand);opacity:.6;cursor:not-allowed}
.cookie-cat p{font-size:.85rem;color:var(--c-muted);margin:0}
.cookie-modal-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.cookie-modal-actions .btn{flex:1;min-width:140px}

/* ---------- Danke-Seite ---------- */
.thankyou-hero{
  position:relative;
  background:var(--c-bg);
  padding:80px 0 100px;
  overflow:hidden;
}
.thankyou-hero::before{
  content:"";position:absolute;
  top:-150px;right:-150px;width:700px;height:700px;
  background:radial-gradient(circle, var(--c-accent) 0%, rgba(217,196,154,0) 65%);
  opacity:.35;
  z-index:0;pointer-events:none;
}
.thankyou-hero::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='600' height='600' viewBox='0 0 600 600'><defs><pattern id='p' width='40' height='40' patternUnits='userSpaceOnUse'><path d='M0 0h40v40H0z' fill='none' stroke='%23B09A6E' stroke-width='.4' opacity='.25'/></pattern></defs><rect width='600' height='600' fill='url(%23p)'/></svg>");
  opacity:.35;
}
.thankyou-card{
  position:relative;z-index:1;
  max-width:760px;margin:0 auto;
  background:var(--c-white);
  border:1px solid var(--c-line);
  border-radius:var(--radius-md);
  padding:clamp(36px,5vw,64px);
  text-align:center;
  box-shadow:var(--shadow-md);
}
.thankyou-check{
  width:88px;height:88px;
  margin:0 auto 24px;
  color:var(--c-brand);
}
.thankyou-check svg{width:100%;height:100%;display:block}
.thankyou-card h1{
  font-size:clamp(1.8rem,3.5vw,2.6rem);
  margin-bottom:14px;
}
.thankyou-card .lead{
  margin:0 auto 36px;max-width:560px;
}
.thankyou-steps{
  display:grid;gap:14px;
  margin:0 auto 36px;max-width:560px;
  text-align:left;
}
.thankyou-step{
  display:grid;grid-template-columns:44px 1fr;gap:14px;
  align-items:center;
  background:var(--c-bg);
  padding:14px 18px;
  border-radius:var(--radius-sm);
  border:1px solid var(--c-line);
}
.thankyou-step .step-num{
  width:36px;height:36px;
  background:var(--c-brand);
  color:var(--c-bg);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:1.15rem;font-weight:600;
}
.thankyou-step strong{display:block;font-size:.95rem;font-weight:600;color:var(--c-dark);margin-bottom:2px}
.thankyou-step p{font-size:.85rem;color:var(--c-muted);margin:0;line-height:1.45}
.thankyou-cta{
  display:flex;flex-wrap:wrap;gap:12px;justify-content:center;
  margin-bottom:24px;
}
.thankyou-note{
  font-size:.82rem;color:var(--c-muted);
  margin:0;padding-top:18px;
  border-top:1px solid var(--c-line);
}
@media (max-width:640px){
  .thankyou-hero{padding:48px 0 64px}
  .thankyou-cta .btn{width:100%}
  .thankyou-step{grid-template-columns:38px 1fr;gap:10px;padding:12px 14px}
  .thankyou-step .step-num{width:30px;height:30px;font-size:1rem}
}

/* ---------- Legal pages ---------- */
.legal{padding:80px 0;max-width:820px;margin:0 auto}
.legal h1{margin-bottom:32px}
.legal h2{font-size:1.5rem;margin-top:40px;margin-bottom:14px;color:var(--c-brand)}
.legal h3{font-size:1.15rem;margin-top:24px;margin-bottom:8px}
.legal p,.legal li{font-size:.97rem;line-height:1.75;color:var(--c-dark-soft)}
.legal ul{padding-left:22px;list-style:disc;margin:0 0 1em}
.legal li{padding:4px 0}
.legal a{color:var(--c-brand)}
.legal a:hover{text-decoration:underline}
.legal-meta{
  background:var(--c-white);border:1px solid var(--c-line);
  padding:24px;border-radius:var(--radius-md);margin-top:32px;font-size:.9rem;
}

/* ---------- Animations ---------- */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(20px)}
  to{opacity:1;transform:translateY(0)}
}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

/* ---------- Utilities ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mb-0{margin-bottom:0}
.mb-sm{margin-bottom:12px}
.mb-md{margin-bottom:24px}
.mb-lg{margin-bottom:40px}
.hide-mobile{}
@media (max-width:640px){.hide-mobile{display:none}}

/* Smooth focus for accessibility */
:focus-visible{outline:2px solid var(--c-brand);outline-offset:3px;border-radius:4px}

/* =========================================================
   MOBILE OPTIMIERUNGEN
   ========================================================= */
@media (max-width:768px){
  body{font-size:16px}
  .container{padding:0 20px}

  /* Topbar kompakter */
  .topbar{font-size:.78rem;padding:6px 0}
  .topbar-inner{gap:10px;justify-content:center}
  .topbar-contact{gap:14px}

  /* Sections weniger Padding */
  .section{padding:56px 0}
  .section-tight{padding:40px 0}
  .section-head{margin-bottom:36px}

  /* Hero */
  .hero{min-height:auto;padding:60px 0 70px}
  .hero h1{font-size:clamp(2rem,8vw,2.6rem);line-height:1.18}
  .hero .lead{font-size:1rem}
  .hero-cta{gap:10px;margin-top:28px}
  .hero-cta .btn{width:100%;justify-content:center}
  .hero-trust{
    gap:18px 24px;margin-top:36px;padding-top:24px;
    display:grid;grid-template-columns:repeat(2,1fr);
  }
  .hero-trust-item strong{font-size:1.6rem}
  .hero-trust-item span{font-size:.72rem}

  /* Sub-Hero */
  .sub-hero{padding:70px 0 44px}
  .sub-hero p{font-size:1rem}

  /* H-Skalen */
  h1{font-size:clamp(1.9rem,7vw,2.4rem)}
  h2{font-size:clamp(1.7rem,5.5vw,2rem)}
  h3{font-size:1.2rem}
  .lead{font-size:1rem;line-height:1.6}

  /* Buttons: Mindestgröße für Tap-Targets, full-width auf Mobile */
  .btn{padding:14px 22px;font-size:.92rem;min-height:48px}
  .btn-lg{padding:16px 26px;font-size:.95rem;min-height:52px}
  .btn-sm{padding:10px 16px;font-size:.82rem;min-height:40px}
  .cta-section .btn,
  .hero-cta .btn{width:100%}

  /* Cards / Listings / Steps */
  .card{padding:28px 24px}
  .card-feature{padding:32px 24px 28px}
  .card-feature .num{top:14px;right:18px;font-size:2.4rem}
  .card-feature h3{padding-right:50px}
  .step{padding:22px;grid-template-columns:1fr;text-align:left}
  .step-num{width:52px;height:52px;font-size:1.4rem}
  .feature-list li{padding:14px 0;gap:12px}
  .feature-list .ico{width:34px;height:34px;font-size:.9rem}
  .feature-list strong{font-size:1rem}
  .feature-list p{font-size:.9rem}

  /* Quote */
  .quote-card{padding:32px 24px}
  .quote-card::before{font-size:4rem;top:-12px;left:18px}
  .quote-card p{font-size:1.1rem}

  /* CTA */
  .cta-section{padding:48px 24px;border-radius:14px}
  .cta-section h2{font-size:1.6rem}
  .cta-section p{font-size:1rem}

  /* Trust strip */
  .trust-strip{padding:28px 0}
  .trust-strip .grid-4{grid-template-columns:repeat(2,1fr);gap:24px 16px}
  .trust-item strong{font-size:1.8rem}
  .trust-item span{font-size:.72rem}

  /* Forms */
  .form{padding:24px}
  .form h3{font-size:1.4rem}
  .field input,.field select,.field textarea{
    padding:14px;font-size:16px; /* 16px verhindert Auto-Zoom auf iOS */
    min-height:48px;
  }
  .field textarea{min-height:110px}
  .form .btn{width:100%}

  /* Header / Logo kompakter */
  .header{position:sticky}
  .nav{padding:14px 0;gap:12px}
  .logo{font-size:1.1rem;gap:10px}
  .logo-mark{width:40px;height:40px;font-size:1rem}
  .logo-text small{font-size:.5rem;letter-spacing:.16em}
  .nav-menu{padding:100px 24px 32px}
  .nav-menu a{font-size:1.15rem;padding:13px 0}

  /* Footer */
  .footer{padding:48px 0 24px}
  .footer .grid-4{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .footer-bottom a{margin-right:14px;font-size:.82rem}

  /* Floating Actions: kleiner + nicht doppelt mit Cookie Banner stören */
  .floating-actions{right:14px;bottom:14px;gap:10px}
  .floating-btn{width:48px;height:48px}
  .floating-btn svg{width:22px;height:22px}

  /* Cookie Banner: volle Breite minus Margin */
  .cookie-banner{
    left:12px;right:12px;bottom:12px;
    max-width:none;padding:22px 20px;
    border-radius:12px;
  }
  .cookie-banner h3{font-size:1.1rem;margin-bottom:8px}
  .cookie-banner p{font-size:.85rem;margin-bottom:14px}
  .cookie-actions{flex-direction:column;gap:8px}
  .cookie-actions .btn{width:100%;flex:none}

  /* Cookie Modal */
  .cookie-modal{padding:0;align-items:flex-end}
  .cookie-modal-inner{
    border-radius:14px 14px 0 0;
    padding:24px 20px 32px;
    max-height:92vh;
  }
  .cookie-modal-actions{flex-direction:column;gap:8px}
  .cookie-modal-actions .btn{width:100%;flex:none}

  /* Feature Panels (statt Bild) */
  .feature-panel{padding:32px 26px;min-height:0}
  .feature-panel-title{font-size:1.6rem;margin-bottom:18px}
  .feature-panel-stats{grid-template-columns:1fr 1fr;gap:18px 20px}
  .feature-panel-stats strong{font-size:2rem}

  /* Bilder auf Mobile: nicht zu groß werden lassen */
  .media{max-height:60vh;aspect-ratio:4/5}
  .media--accent-frame{border-width:5px}
  .hero{min-height:auto}
  .hero-image img{object-position:center 22%}

  /* Locations chips */
  .location-chip{font-size:.82rem;padding:8px 14px}

  /* FAQ */
  .faq-q{font-size:1.05rem;padding:18px 0;gap:14px}
  .faq-q .plus{width:28px;height:28px}

  /* Legal Pages */
  .legal{padding:48px 0}
  .legal h2{font-size:1.3rem;margin-top:32px}
  .legal h3{font-size:1.05rem}
}

@media (max-width:480px){
  /* Sehr schmale Geräte: Topbar zusätzlich abspecken */
  .topbar{padding:5px 0}
  .topbar-inner{flex-direction:column;gap:4px}
  .topbar-contact{gap:14px}

  .hero{padding:48px 0 60px}
  .hero h1{font-size:1.85rem;line-height:1.2}
  .hero-trust-item strong{font-size:1.4rem}

  .feature-panel-stats{grid-template-columns:1fr}

  /* Floating-Buttons reduzieren auf 1 (Phone bleibt) */
  .floating-btn.whatsapp{width:46px;height:46px}
  .floating-btn.phone{width:46px;height:46px}
}

/* Reduzierte Bewegung respektieren */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal{opacity:1;transform:none}
}
