/* =========================================================
   martha cleaning — EDITORIAL (V2) · Corporate-Design-konform
   Farben: Navy #24354B (dominant), Beige #F0E0D0 (Akzent), Weiß (neutral)
   Schrift: ausschließlich Futura (Body Medium, Headlines Heavy)
   ========================================================= */
/* Marken-Schrift Futura (Corporate Design: ausschließlich Futura) */
@font-face { font-family: 'Futura'; src: url('../fonts/FuturaLT.woff2') format('woff2'); font-weight: normal; font-style: normal; font-display: swap; }

:root {
  /* Corporate Design Farben */
  --navy: #24354B;        /* Hauptfarbe (dominant) */
  --navy-deep: #1b2838;
  --navy-card: #324a66;
  --beige: #F0E0D0;       /* Akzentfarbe (nur Akzente) */
  --white: #ffffff;       /* Neutralfarbe */
  --ink: #24354B;         /* Text = Navy */
  --muted: #5e6c80;       /* abgesoftetes Navy */
  --cream: #ffffff;       /* Hintergrund neutral = Weiß */
  --cream-2: #faf2e8;     /* sehr heller Beige-Ton (Akzentfläche) */
  --beige-deep: #24354B;  /* Akzent-Text/Icons = Navy (lesbar) */
  --line: #e8e2d8;
  --wa: #25d366;
  --head: 'Futura', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font: 'Futura', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --container: 1240px;
  --shadow-lg: 0 30px 70px -20px rgba(36,53,75,.30);
  --shadow: 0 18px 40px -16px rgba(36,53,75,.20);
  --shadow-sm: 0 8px 24px -10px rgba(36,53,75,.16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: clip; }
body {
  margin: 0; font-family: var(--font); font-weight: 500; background: var(--white); color: var(--ink);
  font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased;
  overflow-x: clip; max-width: 100%;
}
.section--beige { background: var(--beige); }
.section--beige .kicker { color: var(--navy); }
.section--soft { background: var(--cream-2); }
.section--mist { background: #eef1f5; }
img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
.container { max-width: var(--container); margin: 0 auto; padding: 0 32px; }

h1,h2,h3,h4 { font-family: var(--head); color: var(--navy); margin: 0; line-height: 1.18; font-weight: 600; letter-spacing: -.01em; overflow-wrap: break-word; -webkit-hyphens: auto; hyphens: auto; }

/* ---- shared utilities ---- */
.kicker { display: inline-flex; align-items: center; font-size: 13px; font-weight: 600; letter-spacing: .2em; text-transform: uppercase; color: var(--beige-deep); font-family: var(--head); }
.kicker.center { justify-content: center; }
.display { font-family: var(--head); font-weight: 700; font-size: clamp(40px, 7.5vw, 104px); line-height: 1.14; letter-spacing: -.02em; overflow-wrap: break-word; -webkit-hyphens: auto; hyphens: auto; }
.u-beige { position: relative; white-space: nowrap; }
.u-beige::after { content: ''; position: absolute; left: -.02em; right: -.02em; bottom: .07em; height: .26em; background: var(--beige); z-index: -1; border-radius: 3px; }
.lead { font-size: clamp(18px, 1.5vw, 21px); color: var(--muted); max-width: 64ch; }
.section { padding: clamp(80px, 11vw, 150px) 0; }
.section-head { max-width: 760px; }
.section-head h2 { font-size: clamp(34px, 5vw, 60px); margin: 18px 0 0; }
.section-head .lead { margin-top: 22px; }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; } .reveal.d2 { transition-delay: .16s; } .reveal.d3 { transition-delay: .24s; } .reveal.d4 { transition-delay: .32s; } .reveal.d5 { transition-delay: .40s; } .reveal.d6 { transition-delay: .48s; }
@media (prefers-reduced-motion: reduce){ .reveal{opacity:1;transform:none;transition:none;} }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; gap: 10px; font-weight: 600; font-size: 16px; padding: 16px 30px; border-radius: 100px; border: 2px solid var(--navy); background: var(--navy); color: #fff; cursor: pointer; transition: .25s cubic-bezier(.16,1,.3,1); }
.btn:hover { background: var(--beige); border-color: var(--beige); color: var(--navy); transform: translateY(-2px); box-shadow: var(--shadow-sm); }
.btn svg { width: 18px; height: 18px; }
.btn--ghost { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn--ghost:hover { background: var(--navy); color: #fff; border-color: var(--navy); }
.btn--light { background: #fff; border-color: #fff; color: var(--navy); }
.btn--on-dark { border-color: rgba(255,255,255,.5); background: transparent; color: #fff; }
.btn--on-dark:hover { background: #fff; color: var(--navy); border-color:#fff; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header { position: sticky; top: 0; z-index: 200; background: transparent; border-bottom: 1px solid transparent; transition: background .35s ease, border-color .35s ease, box-shadow .35s ease; }
.site-header.scrolled { background: rgba(255,255,255,.82); backdrop-filter: saturate(150%) blur(14px); border-bottom-color: var(--line); box-shadow: 0 6px 24px -16px rgba(36,53,75,.4); }
/* Header-Schrift & Logo standardmäßig Brand-Blau (Navy) – auch transparent oben */
/* Über dem Hero: komplett transparent (Navy-Schrift, fett für Lesbarkeit) */
.site-header.over-hero:not(.scrolled) { background: transparent; }
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 88px; gap: 24px; }
.brand img { height: 38px; width: auto; }
.main-nav ul { display: flex; align-items: center; gap: 6px; }
.nav-link { font-size: 16px; font-weight: 700; color: var(--navy); padding: 10px 16px; border-radius: 100px; display: inline-flex; align-items: center; gap: 7px; transition: .2s; position: relative; }
.nav-link:hover { color: var(--beige-deep); }
.main-nav li.is-active .nav-link::after { content:''; position:absolute; left:16px; right:16px; bottom:4px; height:2px; background:var(--beige-deep); border-radius:2px; }
.caret { width: 9px; height: 9px; }
.has-dropdown { position: relative; }
.dropdown-menu { position: absolute; top: calc(100% + 8px); left: 0; min-width: 290px; background: #fff; border: 1px solid var(--line); border-radius: 16px; box-shadow: var(--shadow); padding: 10px; opacity: 0; visibility: hidden; transform: translateY(8px); transition: .2s; }
.has-dropdown:hover .dropdown-menu, .has-dropdown.open .dropdown-menu { opacity: 1; visibility: visible; transform: none; }
.dropdown-menu a { display: block; padding: 11px 16px; border-radius: 10px; font-size: 15px; color: var(--navy); transition: .15s; }
.dropdown-menu a:hover { background: var(--cream-2); padding-left: 22px; }
.header-actions { display: flex; align-items: center; gap: 14px; }
.btn-call { background: var(--navy); color: #fff; border-radius: 100px; padding: 13px 24px; font-size: 15px; font-weight: 600; transition: .2s; min-width: 150px; text-align: center; display: inline-flex; align-items: center; justify-content: center; }
.btn-call:hover { background: var(--beige); color: var(--navy); }
/* Sprach-Toggle mit Flaggen (Schiebe-Optik, aktive Flagge hervorgehoben) */
.lang-switch { display: inline-flex; align-items: center; gap: 2px; background: rgba(36,53,75,.07); border-radius: 100px; padding: 3px; margin-right: 8px; }
.lang-switch a { display: flex; align-items: center; justify-content: center; padding: 5px 9px; border-radius: 100px; opacity: .4; text-decoration: none; transition: opacity .2s ease, background .2s ease, box-shadow .2s ease; cursor: pointer; }
.lang-switch a.is-current { background: #fff; opacity: 1; box-shadow: 0 2px 7px -1px rgba(36,53,75,.22); cursor: default; }
.lang-switch a:not(.is-current):hover { opacity: .8; }
.lang-switch .flag { width: 22px; height: 15px; border-radius: 2px; display: block; box-shadow: 0 0 0 1px rgba(0,0,0,.08); }
/* Sprach-Toggle im Mobile-Menü: mittig unter „Jetzt anrufen" */
.mobile-nav .lang-switch--m { display: flex; justify-content: center; gap: 2px; width: max-content; margin: 26px auto 0; border-bottom: 0; }
.mobile-nav .lang-switch--m a { padding: 9px 16px; }
.mobile-nav .lang-switch--m .flag { width: 30px; height: 20px; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 26px; height: 2px; background: var(--navy); margin: 5px 0; transition: .25s; }
.mobile-nav { display: none; }

/* =========================================================
   HERO (asymmetric editorial)
   ========================================================= */
.hero { padding: clamp(40px, 6vw, 80px) 0 clamp(60px, 7vw, 110px); position: relative; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: clamp(30px, 5vw, 80px); align-items: center; }
.hero-copy .kicker { margin-bottom: 28px; }
.hero-copy h1 { margin-bottom: 26px; }
.hero-copy .lead { margin-bottom: 36px; }
.hero-cta { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.hero-stats { display: flex; gap: 34px; margin-top: 46px; flex-wrap: wrap; }
.hero-stat .n { font-size: 30px; font-weight: 700; color: var(--navy); line-height: 1; letter-spacing: -.02em; }
.hero-stat .n .star { color: var(--beige-deep); }
.hero-stat .l { font-size: 13.5px; color: var(--muted); margin-top: 6px; }
.hero-stat + .hero-stat { padding-left: 34px; border-left: 1px solid var(--line); }

.hero-media { position: relative; }
.hero-media .frame { position: relative; border-radius: 26px; overflow: hidden; aspect-ratio: 4/5; box-shadow: var(--shadow-lg); background: var(--navy); }
.hero-media .frame video, .hero-media .frame img { width: 100%; height: 100%; object-fit: cover; }
.hero-media .frame::after { content:''; position:absolute; inset:0; background: linear-gradient(160deg, transparent 40%, rgba(22,33,46,.45)); }
.hero-badge { position: absolute; left: -28px; bottom: 34px; background: #fff; border-radius: 18px; padding: 18px 22px; box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 14px; z-index: 3; }
.hero-badge .g { width: 30px; height: 30px; }
.hero-badge .score { font-size: 26px; font-weight: 700; color: var(--navy); line-height: 1; }
.hero-badge .stars { color: #f5b301; font-size: 13px; letter-spacing: 1px; }
.hero-badge .lab { font-size: 12px; color: var(--muted); }
.hero-deco { position: absolute; top: -40px; right: -30px; width: 180px; height: 180px; border: 2px solid var(--beige); border-radius: 50%; opacity: .5; z-index: -1; }

/* =========================================================
   MARQUEE (trust)
   ========================================================= */
.trust { padding: 56px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: var(--cream); }
.trust .tk { text-align: center; margin-bottom: 30px; }
.marquee { overflow: hidden; -webkit-mask-image: linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image: linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-track { display: flex; width: max-content; align-items: center; animation: marquee 34s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-track img { height: 70px; width: auto; margin: 0 50px; filter: grayscale(1); opacity: .55; transition: .3s; }
.marquee-track img:hover { filter: none; opacity: 1; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(calc(-1 * var(--shift, 50%))); } }

/* =========================================================
   STATS BAND
   ========================================================= */
.stats { background: var(--navy); color: #fff; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.stat { padding: 8px 0; }
.stat .num { font-size: clamp(44px, 5vw, 72px); font-weight: 700; color: var(--beige); line-height: 1; letter-spacing: -.03em; }
.stat .cap { margin-top: 14px; color: rgba(255,255,255,.7); font-size: 15px; max-width: 22ch; }
.stat + .stat { border-left: 1px solid rgba(255,255,255,.14); padding-left: 30px; }

/* =========================================================
   EDITORIAL NUMBERED LIST (Vorteile)
   ========================================================= */
.split-head { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(30px,5vw,70px); align-items: start; }
.split-head .sticky { position: sticky; top: 120px; }
.adv-list { border-top: 1px solid var(--line); }
.adv { display: grid; grid-template-columns: auto 1fr; gap: 28px; padding: 30px 0; border-bottom: 1px solid var(--line); align-items: baseline; transition: .3s; }
.adv:hover { padding-left: 10px; }
.adv .idx { font-size: 18px; font-weight: 700; color: var(--beige-deep); font-variant-numeric: tabular-nums; }
.adv h3 { font-size: clamp(22px, 2.4vw, 30px); margin-bottom: 10px; }
.adv p { margin: 0; color: var(--muted); font-size: 16px; max-width: 60ch; }

/* =========================================================
   SERVICES (numbered rows with thumb)
   ========================================================= */
.services { background: var(--cream); }
.services .section-head { text-align: center; max-width: 760px; margin: 0 auto; }
.services .section-head .lead { margin-left: auto; margin-right: auto; }
.srv-list { margin-top: 56px; border-top: 1px solid rgba(255,255,255,.13); }
.srv { display: grid; grid-template-columns: 60px minmax(0,1.25fr) minmax(0,.9fr) 150px 52px; align-items: center; gap: 28px; padding: 24px 18px; border-bottom: 1px solid rgba(255,255,255,.13); transition: .35s cubic-bezier(.16,1,.3,1); border-radius: 16px; }
.srv:hover { background: rgba(255,255,255,.05); padding-left: 28px; }
.srv .idx { font-size: 16px; color: var(--beige); font-weight: 700; }
.srv h3 { font-size: clamp(21px, 2.6vw, 32px); color: #fff; margin: 0; }
.srv .desc { color: rgba(255,255,255,.6); font-size: 15px; }
.srv .thumb { width: 150px; height: 90px; border-radius: 12px; overflow: hidden; opacity: .85; transition: .35s; }
.srv:hover .thumb { opacity: 1; transform: scale(1.04); }
.srv .thumb img { width: 100%; height: 100%; object-fit: cover; }
.srv .arrow { width: 46px; height: 46px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.3); display: flex; align-items: center; justify-content: center; transition: .35s; }
.srv .arrow svg { width: 18px; height: 18px; fill: #fff; transition: .35s; }
.srv:hover .arrow { background: var(--beige); border-color: var(--beige); }
.srv:hover .arrow svg { fill: var(--navy); transform: rotate(-45deg); }
@media (max-width: 860px){ .srv .desc, .srv .thumb { display: none; } .srv { grid-template-columns: 44px 1fr auto; gap: 16px; } }

/* =========================================================
   BEFORE / AFTER
   ========================================================= */
.ba-wrap { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 56px; }
.ba-compare { --pos: 50%; position: relative; aspect-ratio: 3/2; border-radius: 18px; overflow: hidden; box-shadow: var(--shadow); cursor: ew-resize; user-select: none; touch-action: none; background: var(--navy); }
.ba-compare img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; pointer-events: none; -webkit-user-drag: none; }
.ba-compare .ba-top { clip-path: inset(0 0 0 var(--pos)); }
.ba-label { position: absolute; top: 14px; z-index: 3; font-size: 11px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; padding: 6px 13px; border-radius: 100px; }
.ba-label-after { left: 14px; background: var(--beige); color: var(--navy); }
.ba-label-before { right: 14px; background: rgba(22,33,46,.8); color: #fff; }
.ba-divider { position: absolute; top: 0; bottom: 0; left: var(--pos); width: 2px; background: #fff; transform: translateX(-50%); z-index: 2; }
.ba-knob { position: absolute; top: 50%; left: var(--pos); width: 46px; height: 46px; border-radius: 50%; background: #fff; transform: translate(-50%,-50%); z-index: 3; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow); }
.ba-knob svg { width: 24px; height: 24px; fill: var(--navy); }

/* =========================================================
   ABOUT TEASER (editorial split, offset image)
   ========================================================= */
.about-split { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(36px,6vw,90px); align-items: center; }
.about-figure { position: relative; }
.about-figure img { width: 100%; border-radius: 0; box-shadow: none; }
.about-figure .tag { display: none; }
.about-figure--m { display: none; } /* nur mobil: Bild zwischen Headline & Zitat */
.pull { font-size: clamp(22px,2.4vw,30px); font-weight: 600; color: var(--navy); line-height: 1.35; margin: 22px 0; }
.about-split .lead { margin-bottom: 30px; }

/* =========================================================
   REVIEWS (Google 4,9)
   ========================================================= */
.reviews { background: var(--cream-2); overflow: hidden; }
.reviews-head { text-align: center; }
.reviews-badge { display: inline-flex; align-items: center; gap: 18px; margin: 28px auto 0; padding: 16px 32px; background: #fff; border: 1px solid var(--line); border-radius: 100px; box-shadow: var(--shadow-sm); }
.reviews-badge .g-logo { width: 36px; height: 36px; }
.reviews-badge .score { font-size: 40px; font-weight: 700; color: var(--navy); line-height: 1; }
.reviews-badge .sep { width: 1px; height: 40px; background: var(--line); }
.reviews-badge .rb-right { text-align: left; }
.reviews-badge .rb-stars { color: #f5b301; font-size: 20px; letter-spacing: 2px; }
.reviews-badge .rb-label { color: var(--muted); font-size: 13px; margin-top: 3px; }
.reviews-marquee { overflow: hidden; position: relative; margin-top: 50px; }
.reviews-marquee + .reviews-marquee { margin-top: 22px; }
.reviews-marquee::before, .reviews-marquee::after { content: ""; position: absolute; top: 0; width: 130px; height: 100%; z-index: 2; pointer-events: none; }
.reviews-marquee::before { left: 0; background: linear-gradient(to right, var(--cream-2), transparent); }
.reviews-marquee::after { right: 0; background: linear-gradient(to left, var(--cream-2), transparent); }
.reviews-track { display: flex; gap: 22px; width: max-content; padding: 10px 11px; }
.rev-fwd { animation: revFwd 80s linear infinite; }
.rev-rev { animation: revRev 72s linear infinite; }
.reviews-marquee:hover .reviews-track { animation-play-state: paused; }
@keyframes revFwd { to { transform: translateX(-50%); } }
@keyframes revRev { from { transform: translateX(-50%); } }
.rev-card { min-width: 370px; max-width: 370px; background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 28px; box-shadow: var(--shadow-sm); text-align: left; display: flex; flex-direction: column; white-space: normal; }
.rev-stars { color: #f5b301; font-size: 16px; letter-spacing: 2px; margin-bottom: 14px; }
.rev-text { color: var(--ink); font-size: 15px; line-height: 1.6; margin: 0 0 18px; flex: 1; }
.rev-line { height: 1px; background: var(--line); margin-bottom: 16px; }
.rev-author { display: flex; align-items: center; gap: 12px; }
.rev-avatar { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 600; font-size: 15px; flex-shrink: 0; }
.rev-av-a { background: var(--beige); color: #7a5e2e; }
.rev-av-b { background: rgba(31,45,64,.1); color: var(--navy); }
.rev-av-c { background: rgba(66,133,244,.14); color: #2f6bd0; }
.rev-av-d { background: rgba(52,168,83,.14); color: #2a8a47; }
.rev-av-e { background: rgba(155,110,200,.16); color: #7a4fb0; }
.rev-info strong { display: block; color: var(--navy); font-size: 15px; }
.rev-info span { color: var(--muted); font-size: 12.5px; display: flex; align-items: center; gap: 5px; margin-top: 2px; }
.rev-info .g-mini { width: 13px; height: 13px; }

/* =========================================================
   FAQ (2-col, sticky head)
   ========================================================= */
.faq-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: clamp(30px,5vw,80px); align-items: start; }
.faq-grid .sticky { position: sticky; top: 120px; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 26px 0; display: flex; align-items: center; gap: 18px; font-family: var(--font); color: var(--navy); font-size: clamp(17px,1.7vw,21px); font-weight: 600; }
.faq-ic { flex-shrink: 0; width: 30px; height: 30px; border-radius: 50%; border: 1.5px solid var(--beige-deep); position: relative; transition: .3s; }
.faq-ic::before, .faq-ic::after { content: ''; position: absolute; top: 50%; left: 50%; background: var(--beige-deep); border-radius: 2px; transition: .3s; }
.faq-ic::before { width: 12px; height: 2px; transform: translate(-50%,-50%); }
.faq-ic::after { width: 2px; height: 12px; transform: translate(-50%,-50%); }
.faq-item.open .faq-ic { background: var(--beige-deep); }
.faq-item.open .faq-ic::before, .faq-item.open .faq-ic::after { background: #fff; }
.faq-item.open .faq-ic::after { transform: translate(-50%,-50%) rotate(90deg); opacity: 0; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease; }
.faq-a-inner { padding: 0 0 26px 48px; color: var(--muted); font-size: 16px; }

/* =========================================================
   CONTACT (asymmetric, navy)
   ========================================================= */
.contact { background: var(--navy); color: #fff; }
.contact-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(36px,5vw,80px); align-items: start; }
.contact h2 { color: #fff; font-size: clamp(34px,4.5vw,56px); }
.contact .lead { color: rgba(255,255,255,.72); margin-top: 22px; }
.contact-phone { display: inline-flex; align-items: center; gap: 12px; margin-top: 30px; font-size: clamp(24px,2.6vw,34px); font-weight: 700; color: #fff; }
.contact-phone .ico { width: 46px; height: 46px; border-radius: 50%; background: var(--beige); display: flex; align-items: center; justify-content: center; }
.contact-phone .ico svg { width: 22px; height: 22px; fill: var(--navy); }
.form-card { background: #fff; border-radius: 22px; padding: clamp(28px,3vw,40px); box-shadow: var(--shadow-lg); }
/* Kontakt auf hellem Grund */
.contact--light { background: transparent; color: var(--ink); }
.contact--light h2 { color: var(--navy); }
.contact--light .lead { color: var(--muted); }
.contact--light .contact-phone { color: var(--navy); }
.contact--light .form-card { box-shadow: var(--shadow); border: 1px solid var(--line); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-grid .full { grid-column: 1/-1; }
.form-control { width: 100%; padding: 15px 16px; border: 1px solid var(--line); border-radius: 12px; font-family: var(--font); font-size: 15px; background: var(--cream); color: var(--ink); }
.form-control:focus { outline: none; border-color: var(--beige-deep); box-shadow: 0 0 0 3px rgba(185,151,92,.18); background: #fff; }
textarea.form-control { min-height: 120px; resize: vertical; }
.consent { display: flex; gap: 12px; align-items: flex-start; font-size: 13px; color: var(--muted); }
.consent a { color: var(--navy); text-decoration: underline; }
.form-note { margin-top: 14px; color: #1f8a4c; font-weight: 600; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer { background: var(--navy-deep); color: rgba(255,255,255,.72); padding: 80px 0 0; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.05fr; gap: 40px; padding-bottom: 54px; }
@media (max-width: 900px){ .footer-grid { grid-template-columns: 1fr 1fr; } }
.footer-brand img { width: 213px; height: auto; max-width: 100%; filter: brightness(0) invert(1); margin: 0 0 20px; display: block; }
.footer-brand p { max-width: 34ch; margin: 0; text-align: left; }
.site-footer h4 { color: #fff; font-size: 18px; margin-bottom: 18px; }
.site-footer a { color: rgba(255,255,255,.72); transition: .2s; }
.site-footer a:hover { color: var(--beige); }
.footer-links li { margin-bottom: 11px; }
.footer-contact p { margin: 0 0 10px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.13); padding: 24px 0; display: flex; justify-content: center; align-items: center; text-align: center; gap: 12px 28px; flex-wrap: wrap; font-size: 14px; }
.footer-legal { display: inline-flex; flex-wrap: wrap; gap: 4px 12px; }
.footer-legal a { color: rgba(255,255,255,.72); }
.footer-scaleverse { display: inline-flex; align-items: center; gap: 8px; color: rgba(255,255,255,.55); font-size: 13px; transition: color .2s ease; }
.footer-scaleverse:hover { color: #fff; }
.footer-scaleverse img { height: 17px; width: auto; display: block; }

/* Legal-/Rechtstexte */
.legal-prose { color: var(--muted); line-height: 1.75; font-size: 15.5px; max-width: 820px; }
.legal-prose h2 { color: var(--navy); font-size: 22px; margin: 36px 0 12px; }
.legal-prose h3 { color: var(--navy); font-size: 17px; margin: 22px 0 8px; }
.legal-prose p { margin: 0 0 14px; }
.legal-prose ul { margin: 4px 0 16px; padding-left: 20px; }
.legal-prose li { margin: 0 0 7px; }
.legal-prose a { color: var(--navy); font-weight: 600; }
.legal-prose strong { color: var(--navy); }
.legal-prose .addr { background: var(--cream-2); border-radius: 14px; padding: 18px 22px; display: inline-block; }

/* WhatsApp + cookie */
.wa-float { position: fixed; right: 24px; bottom: 24px; width: 62px; height: 62px; border-radius: 50%; background: var(--wa); display: flex; align-items: center; justify-content: center; box-shadow: 0 10px 30px rgba(0,0,0,.28); z-index: 300; transition: .2s; }
.wa-float:hover { transform: scale(1.08); }
.wa-float svg { width: 34px; height: 34px; fill: #fff; }
.cookie-bar { position: fixed; left: 50%; transform: translateX(-50%); bottom: 20px; width: min(960px, calc(100% - 32px)); background: var(--navy); color: rgba(255,255,255,.85); padding: 18px 24px; z-index: 320; display: flex; align-items: center; justify-content: center; gap: 22px; flex-wrap: wrap; font-size: 14px; border-radius: 16px; box-shadow: var(--shadow-lg); }
.cookie-bar p { margin: 0; max-width: 640px; }
.cookie-bar a { color: var(--beige); text-decoration: underline; }
.cookie-bar.hidden { display: none; }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 980px) {
  .hero-grid, .stats-grid, .split-head, .about-split, .faq-grid, .contact-grid { grid-template-columns: 1fr; }
  .about-split > .about-figure { display: none; }
  .about-figure--m { display: block; max-width: 460px; margin: 22px 0 24px; }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 30px 24px; }
  .stat + .stat { border-left: 0; padding-left: 0; }
  .stats-grid .stat:nth-child(even) { border-left: 1px solid rgba(255,255,255,.14); padding-left: 30px; }
  .hero-media { max-width: 460px; margin: 10px auto 0; }
  .about-figure { max-width: 460px; }
  .ba-wrap { grid-template-columns: 1fr; max-width: 460px; margin-left: auto; margin-right: auto; }
  .split-head .sticky, .faq-grid .sticky { position: static; }
  .form-grid { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .main-nav, .header-actions .btn-call, .header-actions .lang-switch { display: none; }
  .nav-toggle { display: block; }
  .mobile-nav { display: block; position: fixed; inset: 88px 0 0; background: var(--cream); z-index: 190; padding: 26px 32px; transform: translateX(100%); transition: .35s cubic-bezier(.16,1,.3,1); overflow-y: auto; }
  .mobile-nav.open { transform: none; }
  .mobile-nav a { display: block; padding: 15px 4px; font-size: 22px; font-weight: 600; color: var(--navy); border-bottom: 1px solid var(--line); }
  .mobile-nav .sub a { font-size: 17px; padding-left: 18px; color: var(--muted); font-weight: 500; }
  .mobile-nav .btn { display: flex; justify-content: center; color: #fff; border-bottom: 0; font-size: 17px; padding: 16px 30px; }
  .rev-card { min-width: 200px; max-width: 200px; padding: 14px 15px; border-radius: 12px; }
  .rev-text { font-size: 11.5px; line-height: 1.5; margin-bottom: 11px; }
  .rev-stars { font-size: 12px; }
  .rev-avatar { width: 30px; height: 30px; font-size: 11px; }
  .rev-author { gap: 9px; }
  .rev-author strong { font-size: 12.5px; }
  .rev-author span { font-size: 10px; }
  .reviews-track { gap: 11px; padding: 6px; }
  .reviews-marquee::before, .reviews-marquee::after { width: 26px; }
  .reviews-badge { gap: 12px; padding: 12px 20px; }
  .reviews-badge .score { font-size: 30px; }
  .reviews-badge .g-logo { width: 28px; height: 28px; }
  .reviews-badge .sep { height: 30px; }
  .footer-grid { grid-template-columns: 1fr; gap: 34px; }
}
@media (max-width: 560px){
  .container { padding: 0 22px; }
  .hero-stat + .hero-stat { padding-left: 22px; }
  .btn { width: 100%; justify-content: center; }
  .hero-cta { gap: 12px; }
}

/* =========================================================
   V2.1 REVISIONS
   ========================================================= */
/* --- HERO full-bleed (zurück zum Original, premium) --- */
.hero-full { position: relative; min-height: 100vh; margin-top: -88px; display: flex; align-items: center; justify-content: center; text-align: center; color: #fff; overflow: hidden; padding: 88px 0 clamp(120px,16vh,170px); }
.hero-full video, .hero-full .hero-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-full::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,33,46,.42) 0%, rgba(22,33,46,.40) 45%, rgba(22,33,46,.66) 100%); }
.hero-full .inner { position: relative; z-index: 2; padding: 56px 24px; max-width: 1040px; }
.hero-full .kicker { color: #fff; opacity: .95; justify-content: center; margin-bottom: 26px; text-shadow: 0 2px 14px rgba(0,0,0,.45); }
.hero-full .display { color: #fff; margin-bottom: 34px; text-shadow: 0 8px 36px rgba(0,0,0,.4); }
.hero-full .display .u-beige::after { background: var(--beige); opacity: .92; height: .22em; z-index: -1; }
.hero-full .lead { color: rgba(255,255,255,.92); margin: 0 auto 38px; }
.hero-full .hero-cta { justify-content: center; }
.hero-scroll { margin: 18px 0 0; width: 46px; height: 46px; border-radius: 50%; border: 1.5px solid rgba(255,255,255,.55); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: .2s; }
.hero-scroll svg { width: 22px; height: 22px; fill: rgba(255,255,255,.92); animation: bob 1.8s ease-in-out infinite; }
.hero-scroll:hover { background: rgba(255,255,255,.16); }
.hero-scroll svg { width: 22px; height: 22px; fill: var(--beige); animation: bob 1.8s ease-in-out infinite; }
@keyframes bob { 0%,100%{transform:translateY(0)} 50%{transform:translateY(7px)} }
/* Kundenlogos direkt auf dem Video (weiße Silhouetten) */
.hero-logos { position: absolute; left: 0; right: 0; bottom: 0; z-index: 3; background: transparent; padding: 0 0 24px; display: flex; flex-direction: column; align-items: center; }
.hero-logos .lab { text-align: center; font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.72); margin-bottom: 14px; font-family: var(--head); font-weight: 600; }
.hero-logos .marquee { width: 100%; -webkit-mask-image: linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); mask-image: linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent); }
.hero-logos .marquee-track { animation-duration: 45s; }
.hero-logos .marquee-track img { height: 64px; margin: 0 54px; filter: none; opacity: .9; }
@media (max-width: 640px){ .hero-logos .marquee-track img { height: 44px; margin: 0 34px; } }

/* --- VORTEILE: Icon-Kacheln + Reveal (Hybrid) --- */
.vbenefits { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 60px; }
.vcard { background: #fff; border: 1px solid var(--line); border-radius: 22px; padding: 44px 34px; box-shadow: var(--shadow-sm); transition: .35s cubic-bezier(.16,1,.3,1); position: relative; overflow: hidden; text-align: center; }
.vcard::before { content: ''; position: absolute; left: 0; top: 0; height: 4px; width: 0; background: var(--beige); transition: .4s; }
.vcard:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); }
.vcard:hover::before { width: 100%; }
.vcard .ic { width: 70px; height: 70px; border-radius: 18px; background: var(--cream-2); display: flex; align-items: center; justify-content: center; margin: 0 auto 24px; transition: .35s; }
.vcard:hover .ic { background: var(--beige); }
.vcard .ic svg { width: 34px; height: 34px; fill: var(--beige-deep); transition: .35s; }
.vcard:hover .ic svg { fill: var(--navy); }
.vcard h3 { font-size: 23px; margin-bottom: 12px; }
.vcard p { margin: 0; color: var(--muted); font-size: 15px; }

/* --- SERVICES: große Bild-Kacheln --- */
.srv-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 60px; }
.srv-card { position: relative; background: #fff; border-radius: 22px; overflow: hidden; display: flex; flex-direction: column; box-shadow: var(--shadow); transition: .4s cubic-bezier(.16,1,.3,1); }
.srv-card:hover { transform: translateY(-8px); box-shadow: var(--shadow-lg); }
.srv-card .img { aspect-ratio: 16/11; overflow: hidden; background: #fff; border-bottom: 1px solid var(--line); }
.srv-card .img img { width: 100%; height: 100%; object-fit: cover; transition: .6s cubic-bezier(.16,1,.3,1); }
.srv-card:hover .img img { transform: scale(1.07); }
.srv-card .num { position: absolute; top: 18px; left: 18px; width: 46px; height: 46px; border-radius: 50%; background: var(--beige); color: var(--navy); font-weight: 700; display: flex; align-items: center; justify-content: center; font-size: 16px; z-index: 2; box-shadow: var(--shadow-sm); }
.srv-card .b { padding: 26px 28px 30px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.srv-card h3 { color: var(--navy); font-size: 23px; }
.srv-card .desc { color: var(--muted); font-size: 15px; flex: 1; }
.srv-card .more { color: var(--beige-deep); font-weight: 600; font-size: 14.5px; display: inline-flex; align-items: center; gap: 8px; margin-top: 8px; transition: .3s; }
.srv-card .more svg { width: 16px; height: 16px; fill: currentColor; transition: .3s; }
.srv-card:hover .more { gap: 14px; }

/* --- SERVICES: alternierende Showcase-Reihen (anders als Vorteile) --- */
.srv-rows { margin-top: 70px; display: flex; flex-direction: column; gap: clamp(56px, 7vw, 110px); }
.srv-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 5vw, 84px); align-items: center; }
.srv-row:nth-child(even) .srv-media { order: 2; }
.srv-media { position: relative; display: flex; align-items: center; justify-content: center; }
.srv-media img { width: 100%; height: auto; max-height: 400px; object-fit: contain; }
.srv-media .num { display: none; }
.srv-info .tag { display: inline-block; font-size: 13px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; color: var(--beige-deep); margin-bottom: 16px; }
.srv-info h3 { font-size: clamp(28px, 3.6vw, 44px); margin-bottom: 18px; line-height: 1.08; }
.srv-info p { color: var(--muted); font-size: 17px; max-width: 48ch; margin-bottom: 26px; }
.srv-info .more { display: inline-flex; align-items: center; gap: 10px; font-family: var(--head); font-weight: 600; font-size: 16px; color: var(--navy); border-bottom: 2px solid var(--beige); padding-bottom: 5px; transition: .3s; }
.srv-info .more svg { width: 18px; height: 18px; fill: currentColor; transition: .3s; }
.srv-info .more:hover { gap: 16px; color: var(--beige-deep); }
@media (max-width: 860px) {
  .srv-row { grid-template-columns: 1fr; gap: 28px; }
  .srv-row:nth-child(even) .srv-media { order: 0; }
  .srv-media { max-width: 540px; }
}

/* --- BEFORE/AFTER: groß --- */
.ba-feature { max-width: 1180px; margin: 60px auto 0; }
.ba-feature .ba-compare { aspect-ratio: 16/8.5; border-radius: 26px; }
.ba-feature .ba-knob { width: 60px; height: 60px; }
.ba-feature .ba-knob svg { width: 30px; height: 30px; }
.ba-feature .ba-label { font-size: 13px; padding: 8px 18px; top: 20px; }
.ba-feature .ba-divider { width: 3px; }
.ba-secondary { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; max-width: 1180px; margin: 26px auto 0; }
.ba-secondary .ba-compare { aspect-ratio: 16/9.5; border-radius: 20px; }
.ba-hint { text-align: center; margin-top: 26px; color: var(--muted); font-size: 14px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.ba-hint svg { width: 20px; height: 20px; fill: var(--beige-deep); }

/* --- ÜBER UNS: stärker --- */
.about-creds { display: flex; gap: 36px; margin: 28px 0 32px; flex-wrap: wrap; }
.about-cred .n { font-size: 28px; font-weight: 700; color: var(--navy); line-height: 1; letter-spacing: -.02em; }
.about-cred .l { font-size: 13.5px; color: var(--muted); margin-top: 7px; }
.about-cred + .about-cred { padding-left: 36px; border-left: 1px solid var(--line); }

/* ---- CTA band (navy) ---- */
.cta-band { background: var(--navy); color: #fff; text-align: center; }
.cta-band h2 { color: #fff; font-size: clamp(32px, 4.5vw, 56px); }
.cta-band .lead { color: rgba(255,255,255,.75); margin: 22px auto 0; }
.cta-band .phone { display: inline-flex; align-items: center; gap: 14px; margin-top: 34px; font-family: var(--head); font-weight: 700; font-size: clamp(28px, 3.6vw, 46px); color: #fff; }
.cta-band .phone .ico { width: 56px; height: 56px; border-radius: 50%; background: var(--beige); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cta-band .phone .ico svg { width: 26px; height: 26px; fill: var(--navy); }

/* ---- Über uns: Story-Text ---- */
.story { max-width: 820px; margin: 0 auto; }
.story p { color: var(--ink); font-size: 17px; margin-bottom: 1.2em; }

/* ---- Jobs hero ---- */
.jobs-hero { padding: clamp(36px,5vw,80px) 0 clamp(56px,7vw,104px); }
.jobs-hero .grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(30px,5vw,80px); align-items: center; }
.jobs-hero .display { font-size: clamp(46px,7vw,96px); }
.jobs-hero .sub { font-family: var(--head); font-weight: 700; font-size: clamp(26px,4vw,50px); color: var(--beige-deep); margin: 4px 0 26px; line-height: 1.05; }
.jobs-hero .media { display: flex; justify-content: center; }
.jobs-hero .media img { width: 100%; max-width: 480px; height: auto; }

/* ---- Job columns ---- */
.job-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; margin-top: 10px; text-align: left; }
.job-col { background: #fff; border: 1px solid var(--line); border-radius: 22px; padding: 38px 32px; box-shadow: var(--shadow-sm); }
.job-col h3 { font-size: 23px; margin-bottom: 22px; display: flex; align-items: center; gap: 13px; }
.job-col h3 .n { width: 40px; height: 40px; border-radius: 50%; background: var(--cream-2); color: var(--beige-deep); font-size: 15px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.job-col li { position: relative; padding: 10px 0 10px 30px; color: var(--muted); font-size: 15px; border-bottom: 1px solid var(--line); }
.job-col li:last-child { border-bottom: 0; }
.job-col li::before { content: ''; position: absolute; left: 0; top: 15px; width: 16px; height: 16px; background: var(--beige-deep); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; }
@media (max-width: 900px) { .jobs-hero .grid { grid-template-columns: 1fr; } .job-cols { grid-template-columns: 1fr; } }

/* =========================================================
   SERVICE PAGE (Leistungsseite) – editorial
   ========================================================= */
.section--navy { background: var(--navy); color: #fff; }
.section--navy h2, .section--navy h3 { color: #fff; }
.section--navy .lead { color: rgba(255,255,255,.72); }
.section--navy .kicker { color: #fff; }
.contact .kicker { color: #fff; }

.svc-hero { text-align: center; padding: clamp(48px,6vw,86px) 0 clamp(40px,5vw,64px); }
.svc-hero .kicker { justify-content: center; margin-bottom: 22px; }
.svc-hero .display { font-size: clamp(40px,6vw,82px); }
.svc-hero .subtitle { font-family: var(--head); color: var(--beige-deep); font-weight: 600; font-size: clamp(20px,2.6vw,30px); margin: 14px 0 24px; }
.svc-hero .lead { margin: 0 auto 30px; max-width: 880px; }

/* Für wen – hochwertige Icon-Kacheln auf Navy */
.audience-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 22px; margin-top: 52px; }
.aud-card { background: #fff; border: 1px solid var(--line); border-radius: 20px; padding: 34px 22px; display: flex; flex-direction: column; align-items: center; gap: 16px; text-align: center; box-shadow: var(--shadow-sm); transition: .3s cubic-bezier(.16,1,.3,1); }
.aud-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.aud-card .ic { width: 62px; height: 62px; border-radius: 50%; background: var(--beige); display: flex; align-items: center; justify-content: center; }
.aud-card .ic svg { width: 30px; height: 30px; stroke: var(--navy); fill: none; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.aud-card span { font-family: var(--head); font-weight: 600; color: var(--navy); font-size: 15px; line-height: 1.3; }
/* Navy-Kontext (dunkle Sektion) */
.section--navy .aud-card { background: var(--navy-card); border-color: transparent; box-shadow: none; }
.section--navy .aud-card:hover { background: #38527090; }
.section--navy .aud-card .ic { background: rgba(240,224,208,.14); }
.section--navy .aud-card .ic svg { stroke: var(--beige); }
.section--navy .aud-card span { color: #fff; }
@media (max-width: 980px){ .audience-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .audience-grid { grid-template-columns: 1fr; } }
.svc-hero .hero-cta { justify-content: center; }
.hero-feats { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; max-width: 1000px; margin: 50px auto 0; }
.hero-feat { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 30px 24px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; align-items: center; gap: 14px; }
.hero-feat .ic { width: 60px; height: 60px; border-radius: 16px; background: var(--cream-2); display: flex; align-items: center; justify-content: center; }
.hero-feat .ic svg { width: 30px; height: 30px; fill: var(--beige-deep); }
.hero-feat p { margin: 0; font-family: var(--head); color: var(--navy); font-weight: 500; font-size: 16px; }
@media (max-width: 760px){ .hero-feats { grid-template-columns: 1fr; } }

/* Leistungsübersicht 4 Spalten */
.feat-cols { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; margin-top: 56px; text-align: left; }
.feat-col { background: #fff; border: 1px solid var(--line); border-radius: 18px; padding: 32px 26px; box-shadow: var(--shadow-sm); }
.feat-col h3 { color: var(--navy); font-size: 20px; margin-bottom: 18px; padding-bottom: 14px; border-bottom: 1px solid var(--line); }
.feat-col li { color: var(--muted); font-size: 14px; padding: 9px 0 9px 27px; position: relative; }
.feat-col li::before { background: var(--navy); }
/* Navy-Kontext (dunkle Sektion) */
.section--navy .feat-col { background: var(--navy-card); border-color: transparent; box-shadow: none; }
.section--navy .feat-col h3 { color: #fff; border-bottom-color: rgba(255,255,255,.18); }
.section--navy .feat-col li { color: rgba(255,255,255,.82); }
.section--navy .feat-col li::before { background: var(--beige); }
.feat-col li::before { content: ''; position: absolute; left: 0; top: 12px; width: 15px; height: 15px; background: var(--beige); -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat; }
@media (max-width: 980px){ .feat-cols { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .feat-cols { grid-template-columns: 1fr; } }

/* USP grid (Warum wir) */
.usp-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 28px 24px; margin-top: 50px; }
.usp { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 14px; }
.usp .ic { width: 64px; height: 64px; border-radius: 18px; background: var(--cream-2); display: flex; align-items: center; justify-content: center; }
.usp .ic svg { width: 30px; height: 30px; fill: var(--beige-deep); }
.usp span { font-family: var(--head); font-weight: 600; color: var(--navy); font-size: 16px; }
@media (max-width: 560px){ .usp-grid { grid-template-columns: 1fr 1fr; } }

/* Breadcrumb */
.breadcrumb { padding-top: 22px; }
.breadcrumb ol { display: flex; flex-wrap: wrap; gap: 9px; align-items: center; font-size: 13.5px; color: var(--muted); }
.breadcrumb li { display: flex; align-items: center; gap: 9px; }
.breadcrumb li:not(:last-child)::after { content: '›'; color: var(--line); }
.breadcrumb a:hover { color: var(--beige-deep); }
.breadcrumb [aria-current] { color: var(--navy); font-weight: 600; }

/* Ablauf / Steps */
.steps { display: grid; grid-template-columns: repeat(5,1fr); gap: 24px; margin-top: 58px; }
.step { text-align: center; }
.step .n { width: 58px; height: 58px; border-radius: 50%; background: var(--navy); color: #fff; font-family: var(--head); font-weight: 700; font-size: 21px; display: flex; align-items: center; justify-content: center; margin: 0 auto 18px; }
.step h3 { font-size: 18px; margin-bottom: 8px; }
.step p { font-size: 14px; color: var(--muted); margin: 0; }
@media (max-width: 900px){ .steps { grid-template-columns: 1fr 1fr; gap: 30px; } }
@media (max-width: 520px){ .steps { grid-template-columns: 1fr; } }

/* Chips (Objekte / Einzugsgebiet / Leistungen) */
.chips { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 40px; justify-content: center; }
.chip { display: inline-flex; align-items: center; gap: 9px; background: #fff; border: 1px solid var(--line); border-radius: 100px; padding: 11px 20px; font-family: var(--head); font-weight: 500; font-size: 15px; color: var(--navy); box-shadow: var(--shadow-sm); transition: .2s; }
a.chip:hover { background: var(--navy); color: #fff; border-color: var(--navy); transform: translateY(-2px); }
.chip svg { width: 16px; height: 16px; fill: var(--beige-deep); flex-shrink: 0; }
a.chip:hover svg { fill: var(--beige); }

/* Service-Reviews (kompakt) */
.svc-rev-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; margin-top: 42px; }
@media (max-width: 860px){ .svc-rev-grid { grid-template-columns: 1fr; } }

/* Map */
.map-embed { margin-top: 50px; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); border: 1px solid var(--line); line-height: 0; }
.map-embed iframe { width: 100%; height: 420px; border: 0; display: block; }

/* Für wen (Checkliste statt Chips) */
.audience { max-width: 780px; margin: 46px auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: 4px 40px; text-align: left; }
.aud { display: flex; align-items: center; gap: 14px; font-family: var(--head); color: var(--navy); font-weight: 500; font-size: 17px; padding: 16px 4px; border-bottom: 1px solid var(--line); }
.aud svg { width: 22px; height: 22px; fill: var(--beige-deep); flex-shrink: 0; }
@media (max-width: 600px){ .audience { grid-template-columns: 1fr; } }

/* Einzugsgebiet-Liste (Stil der alten Templates) */
.area-list { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; max-width: 1000px; margin: 34px auto 0; line-height: 2; }
.area-list a, .area-list span { font-size: 14.5px; }
.area-list a { color: var(--navy); font-weight: 600; transition: .2s; }
.area-list a:hover { color: var(--beige-deep); }
.area-list span { color: var(--muted); }
.area-list > *:not(:last-child) { margin-right: 16px; }
.area-list > *:not(:last-child)::after { content: '·'; color: var(--line); margin-left: 16px; }

/* Kuratierte Stadtteile (mit lokalem Charakter) */
.districts { max-width: 1000px; margin: 44px auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: 0 44px; text-align: left; }
.district { display: flex; align-items: center; gap: 18px; padding: 20px 6px; border-bottom: 1px solid var(--line); transition: .25s cubic-bezier(.16,1,.3,1); }
.district:hover { padding-left: 14px; }
.district .nm { font-family: var(--head); font-weight: 600; color: var(--navy); font-size: 18px; display: block; }
.district .d { color: var(--muted); font-size: 13.5px; display: block; margin-top: 3px; }
.district .arrow { margin-left: auto; width: 34px; height: 34px; border-radius: 50%; border: 1.5px solid var(--line); display: flex; align-items: center; justify-content: center; flex-shrink: 0; transition: .25s; }
.district:hover .arrow { background: var(--beige); border-color: var(--beige); }
.district .arrow svg { width: 14px; height: 14px; fill: var(--navy); transition: .25s; }
.district:hover .arrow svg { transform: rotate(-45deg); }
.areas-more { color: var(--muted); font-size: 15px; margin: 44px auto 0; max-width: 840px; }

/* Kompakte Stadtteil-/Städte-Liste (querverlinkbar) */
.area-cols { columns: 4 170px; column-gap: 40px; max-width: 1040px; margin: 40px auto 0; text-align: left; }
.area-cols a, .area-cols span { display: block; padding: 8px 2px; font-size: 15px; line-height: 1.3; break-inside: avoid; border-bottom: 1px solid var(--line); }
.area-cols a { color: var(--navy); font-weight: 600; transition: .18s; }
.area-cols a:hover { box-shadow: inset 3px 0 0 var(--beige); padding-left: 10px; }
.area-cols span { color: var(--muted); font-weight: 500; }

/* Kompaktes, symmetrisches Stadtteil-Raster (querverlinkbar; verlinkte = navy/blau, Rest dezent) */
.area-chips { display: grid; grid-template-columns: repeat(5, 1fr); gap: 2px 12px; max-width: 820px; margin: 24px auto 0; }
.area-chips a, .area-chips span { font-family: var(--head); font-weight: 600; font-size: 13px; padding: 6px 10px; border-radius: 7px; line-height: 1.2; text-align: left; }
.area-chips a { color: var(--navy); text-decoration: none; transition: background .16s ease, color .16s ease; }
.area-chips a:hover { background: var(--navy); color: #fff; }
.area-chips span { color: var(--muted); font-weight: 500; }
.area-chips--umland { grid-template-columns: repeat(3, 1fr); max-width: 460px; margin-top: 14px; }
.areas-sub { margin: 30px 0 2px; font-family: var(--head); font-weight: 700; color: var(--navy); font-size: 16px; }
@media (max-width: 820px){ .area-chips { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 520px){ .area-chips, .area-chips--umland { grid-template-columns: repeat(2, 1fr); } }

/* Diskreter „Weitere Leistungen"-Block – kompakt, alles in EINER Zeile (Sitemap-Stil) */
.svc-foot { max-width: 1100px; margin: 36px auto 0; padding-top: 22px; border-top: 1px solid var(--line); text-align: center; }
.svc-foot-label { display: block; font-family: var(--head); font-weight: 700; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.svc-foot-links { display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; font-size: 13px; overflow-x: auto; }
.svc-foot-links a { color: var(--navy); font-weight: 600; text-decoration: none; padding: 3px 16px; white-space: nowrap; transition: color .16s ease; }
.svc-foot-links a:hover { color: var(--beige-deep); }
.svc-foot-links a:not(:last-child) { border-right: 1px solid var(--line); }

/* Leistungs-Karussell (Coverflow) */
.srv-carousel { display: flex; align-items: center; gap: 14px; margin-top: 54px; }
.sc-viewport { overflow: hidden; flex: 1 1 auto; min-width: 0; padding: 30px 0; }
.sc-track { display: flex; gap: 16px; will-change: transform; transition: transform .55s cubic-bezier(.16,1,.3,1); }
.sc-card { flex: 0 0 calc((100% - 32px) / 3); max-width: none; background: #fff; border-radius: 22px; overflow: hidden; border: 1px solid rgba(36,53,75,.08); box-shadow: 0 14px 38px -22px rgba(36,53,75,.4); transform: scale(.82); opacity: .5; transition: transform .55s cubic-bezier(.16,1,.3,1), opacity .55s, box-shadow .55s; }
.sc-card.is-active { transform: scale(1); opacity: 1; box-shadow: 0 32px 70px -30px rgba(15,23,38,.55); }
.sc-card .img { position: relative; aspect-ratio: 16/10; background: linear-gradient(158deg, #f4e8da 0%, #fcf5ec 50%, #ffffff 100%); display: flex; align-items: center; justify-content: center; padding: 34px; border-bottom: 1px solid rgba(36,53,75,.07); }
.sc-card .img::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 90% at 50% 0%, rgba(255,255,255,.5), transparent 60%); pointer-events: none; }
.sc-card .img img { position: relative; z-index: 1; max-width: 80%; max-height: 80%; width: auto; height: auto; object-fit: contain; }
.sc-card .b { padding: 28px 30px 32px; text-align: left; }
.sc-card .tag { display: inline-block; font-size: 11.5px; letter-spacing: .16em; text-transform: uppercase; color: var(--navy); font-weight: 700; background: var(--beige); padding: 6px 13px; border-radius: 100px; max-width: 100%; overflow-wrap: break-word; -webkit-hyphens: auto; hyphens: auto; }
.sc-card h3 { font-size: 25px; margin: 16px 0 11px; color: var(--navy); letter-spacing: -.01em; }
.sc-card p { font-size: 14.5px; line-height: 1.6; color: var(--muted); margin: 0 0 22px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.sc-card .more { display: inline-flex; align-items: center; gap: 9px; font-family: var(--head); font-weight: 700; font-size: 15px; color: var(--navy); }
.sc-card .more svg { width: 17px; height: 17px; fill: currentColor; transition: .3s; }
.sc-card.is-active:hover .more svg { transform: translateX(5px); }
.sc-arrow { position: static; flex: 0 0 auto; width: 54px; height: 54px; border-radius: 50%; background: var(--beige); border: 0; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: var(--shadow); transition: transform .2s ease, background .2s ease; }
.sc-arrow:hover { background: #fff; transform: scale(1.07); }
.sc-arrow svg { width: 24px; height: 24px; fill: var(--navy); }
.sc-arrow[disabled] { opacity: .3; pointer-events: none; }
@media (max-width: 980px){ .sc-card { flex-basis: calc((100% - 20px) / 2); } }
@media (max-width: 640px){ .sc-card { flex-basis: 100%; } .sc-arrow { width: 42px; height: 42px; } .srv-carousel { gap: 8px; } }
@media (max-width: 700px){ .districts { grid-template-columns: 1fr; } }

/* So erreichen Sie uns (Standort + Map) */
.svc-loc { display: grid; grid-template-columns: .8fr 1.2fr; gap: 0; align-items: stretch; margin-top: 46px; text-align: left; border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); background: #fff; }
.svc-loc .loc-info { background: #fff; padding: clamp(28px,3vw,44px); display: flex; flex-direction: column; justify-content: center; }
.svc-loc .map-embed { margin: 0; border: 0; border-radius: 0; box-shadow: none; height: 100%; }
.svc-loc .map-embed iframe { height: 100%; min-height: 400px; }
.loc-info p { margin: 0 0 20px; color: var(--muted); }
.loc-info p:last-child { margin-bottom: 0; }
.loc-info p strong { display: block; color: var(--navy); font-family: var(--head); font-size: 16px; margin-bottom: 3px; }
.loc-info a { color: var(--navy); font-weight: 600; }
@media (max-width: 860px){ .svc-loc { grid-template-columns: 1fr; } .svc-loc .map-embed iframe { min-height: 320px; } }

/* Lokale Sektion + große frameless Skyline (keine Kachel) */
.local-block { text-align: center; max-width: 900px; margin: 0 auto; }
.local-media { margin: 50px auto 0; max-width: 1180px; border-radius: 20px; overflow: hidden; }
.local-media img { width: 100%; height: auto; display: block; }

/* Beige-Button (Akzent, z. B. auf Navy-Sektionen) */
.btn--beige { background: var(--beige); border-color: var(--beige); color: var(--navy); }
.btn--beige:hover { background: #fff; border-color: #fff; color: var(--navy); }

/* Lokal-Split: Bild links (kleiner), Text rechts */
.local-split { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(34px,5vw,72px); align-items: center; text-align: left; }
.local-split .media { max-width: 540px; border-radius: 20px; overflow: hidden; }
.local-split .media img { width: 100%; height: auto; display: block; }
@media (max-width: 860px){ .local-split { grid-template-columns: 1fr; gap: 28px; } }
.about-figure .tag { font-size: 15px; }

@media (max-width: 980px){
  .vbenefits { grid-template-columns: 1fr 1fr; }
  .srv-cards { grid-template-columns: 1fr 1fr; }
  .ba-secondary { grid-template-columns: 1fr; }
  .ba-feature .ba-compare { aspect-ratio: 16/10; }
}
@media (max-width: 640px){
  .vbenefits, .srv-cards { grid-template-columns: 1fr; }
  .about-cred + .about-cred { padding-left: 0; border-left: 0; }
  .about-creds { flex-direction: column; gap: 18px; align-items: center; text-align: center; }
  .hero-full { min-height: 100vh; min-height: 100svh; }
}
