/* ============================================================
   BESTANDSWÄRME – Premium Stylesheet
   ============================================================ */

/* ---------- 1. Tokens ---------- */
:root{
  /* Farbpalette */
  --c-bg:           #F5F1EA;   /* warm cream */
  --c-bg-2:         #ECE4D6;   /* deeper cream */
  --c-ink:          #0E1419;   /* near-black anthracite */
  --c-ink-2:        #1B232B;
  --c-ink-soft:     #4A5560;
  --c-line:         rgba(14,20,25,.12);
  --c-line-soft:    rgba(14,20,25,.06);

  --c-accent:       #E8801A;   /* Bestandswärme Orange (CI) */
  --c-accent-2:     #B8945C;   /* gold */
  --c-accent-deep:  #B86214;   /* burnt copper – deep CI orange */
  --c-jandeck:      #7CB342;   /* Jandeck Grün – nur als sparsamer Subbrand-Akzent */

  --c-dark:         #0E1419;
  --c-dark-2:       #161D24;

  /* Typografie */
  --f-display: "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --f-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

  --fs-hero: clamp(2.6rem, 7vw, 6.2rem);
  --fs-display: clamp(2.2rem, 5vw, 4.6rem);
  --fs-h3: clamp(1.35rem, 2vw, 1.65rem);
  --fs-lead: clamp(1.05rem, 1.2vw, 1.2rem);
  --fs-base: 1rem;
  --fs-small: .875rem;
  --fs-meta: .78rem;

  --ls-meta: .22em;

  /* Layout */
  --container: 1280px;
  --pad-x: clamp(1.25rem, 4vw, 3rem);
  --pad-y: clamp(5rem, 10vw, 9rem);

  --radius: 6px;
  --radius-lg: 14px;

  --t-fast: .25s cubic-bezier(.2,.7,.3,1);
  --t-med:  .55s cubic-bezier(.2,.7,.3,1);
  --t-slow: 1.1s cubic-bezier(.16,.84,.32,1);

  --shadow-sm: 0 1px 2px rgba(14,20,25,.04), 0 2px 8px rgba(14,20,25,.06);
  --shadow-md: 0 4px 20px rgba(14,20,25,.08), 0 20px 50px -10px rgba(14,20,25,.12);
  --shadow-lg: 0 30px 80px -20px rgba(14,20,25,.4);
}

/* ---------- 2. Reset ---------- */
*,*::before,*::after{ box-sizing:border-box }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-sans);
  font-size:var(--fs-base);
  line-height:1.65;
  color:var(--c-ink);
  background:var(--c-bg);
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100% }
a{ color:inherit; text-decoration:none; transition:color var(--t-fast) }
button{ font:inherit; cursor:pointer; border:0; background:none; color:inherit }
ul,ol{ margin:0; padding:0; list-style:none }
p{ margin:0 0 1em }
::selection{ background:var(--c-accent); color:#fff }

/* Focus */
:focus-visible{ outline:2px solid var(--c-accent); outline-offset:3px; border-radius:3px }

/* Skip-Link (A11y, erscheint nur bei Tastatur-Fokus) */
.skip-link{
  position:fixed;
  top:-100px; left:1rem;
  z-index:200;
  background:var(--c-ink);
  color:#F5F1EA;
  padding:.8rem 1.4rem;
  border-radius:var(--radius);
  font-size:.85rem;
  font-weight:600;
  letter-spacing:.05em;
  box-shadow:var(--shadow-md);
  transition:top var(--t-fast);
}
.skip-link:focus-visible{ top:1rem }

/* Typografische Feinheiten */
.h-display,
.hero__title,
.page-hero h1{ text-wrap:balance }
.p-large,
.hero__lead,
.page-hero__lead{ text-wrap:pretty }

/* Anker-Ziele nicht unter dem fixen Header verschwinden lassen */
section[id],
article[id]{ scroll-margin-top:6rem }

/* ---------- 3. Helpers ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--pad-x);
}

.eyebrow,
.meta-label{
  display:inline-block;
  font-family:var(--f-sans);
  font-size:var(--fs-meta);
  font-weight:500;
  letter-spacing:var(--ls-meta);
  text-transform:uppercase;
  color:var(--c-accent-deep);
  margin-bottom:1.25rem;
}
.meta-label::before{
  content:"";
  display:inline-block;
  width:32px; height:1px;
  background:var(--c-accent);
  vertical-align:middle;
  margin-right:.8rem;
}
.meta-label--light{ color:var(--c-accent-2) }

.h-display{
  font-family:var(--f-display);
  font-weight:500;
  font-size:var(--fs-display);
  line-height:1.05;
  letter-spacing:-.01em;
  margin:0 0 1.4rem;
}
.h-display em{ font-style:italic; color:var(--c-accent-deep); font-weight:500 }
.h-display--light{ color:#F5F1EA }
.h-display--light em{ color:var(--c-accent-2) }

.p-large{
  font-size:var(--fs-lead);
  line-height:1.6;
  color:var(--c-ink-soft);
  max-width:62ch;
  margin:0 0 1em;
}
.p-large--light{ color:rgba(245,241,234,.78) }

.section-head{ margin-bottom:4rem; max-width:780px }
.section-head--center{ margin-inline:auto; text-align:center }

/* ---------- 4. Buttons ---------- */
.btn{
  --bg: var(--c-ink);
  --fg: #fff;
  --br: transparent;
  display:inline-flex;
  align-items:center;
  gap:.7rem;
  padding:1.05rem 1.7rem;
  font-size:.92rem;
  font-weight:500;
  letter-spacing:.04em;
  text-transform:uppercase;
  background:var(--bg);
  color:var(--fg);
  border:1px solid var(--br);
  border-radius:var(--radius);
  transition:transform var(--t-fast), background var(--t-fast), color var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
  position:relative;
  overflow:hidden;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 12px 30px -8px rgba(14,20,25,.35) }
.btn svg{ transition:transform var(--t-fast) }
.btn:hover svg{ transform:translateX(4px) }

.btn--primary{
  --bg: var(--c-accent);
  --fg: #fff;
}
.btn--primary:hover{ --bg:#B8631E }

.btn--ghost{
  --bg: transparent;
  --fg: var(--c-ink);
  --br: var(--c-ink);
}
.btn--ghost:hover{ --bg:var(--c-ink); --fg:#fff }

.btn--ghost.btn--dark{
  --fg:#F5F1EA;
  --br: rgba(245,241,234,.5);
}
.btn--ghost.btn--dark:hover{ --bg:rgba(245,241,234,.1); --fg:#fff; --br:#fff }

.btn--full{ width:100%; justify-content:center }

/* ---------- 5. Preloader ---------- */
.preloader{
  position:fixed; inset:0;
  background:var(--c-dark);
  z-index:9999;
  display:grid; place-items:center;
  transition:opacity .6s ease, visibility .6s ease;
}
.preloader__mark{
  animation:spin 2s linear infinite, pulse 1.4s ease-in-out infinite;
}
@keyframes spin{ to{ transform:rotate(360deg) } }
@keyframes pulse{ 50%{ opacity:.5 } }
body.loaded .preloader{ opacity:0; visibility:hidden; pointer-events:none }

/* ---------- 6. Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  padding:1.4rem 0;
  background:rgba(14,20,25,0);
  backdrop-filter:blur(0px);
  transition:background var(--t-fast), padding var(--t-fast), backdrop-filter var(--t-fast), box-shadow var(--t-fast), color var(--t-fast);
  /* Default state: ÜBER dunklem Hero – helles Theme für maximale Lesbarkeit */
  color:#F5F1EA;
}
/* Sanftes Gradient unter dem Header gegen Wash-out auf hellen Bildbereichen */
.site-header::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(14,20,25,.55) 0%, rgba(14,20,25,.0) 100%);
  pointer-events:none;
  opacity:1;
  transition:opacity var(--t-fast);
  z-index:-1;
}
.site-header.is-scrolled{
  background:rgba(245,241,234,.94);
  backdrop-filter:blur(20px) saturate(140%);
  padding:.8rem 0;
  box-shadow:0 1px 0 rgba(14,20,25,.08);
  color:var(--c-ink);
}
.site-header.is-scrolled::before{ opacity:0 }
.site-header.is-hidden{ transform:translateY(-100%) }

.nav-wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  position:relative;
}

.brand{
  display:flex; align-items:center; gap:.85rem;
  color:inherit;
  transition:color var(--t-fast);
}
.brand__icon{ flex-shrink:0; transition:transform var(--t-med) }
.brand:hover .brand__icon{ transform:rotate(-8deg) }
.brand__text{
  display:flex; flex-direction:column; line-height:1.05;
}
.brand__text strong{
  font-family:var(--f-sans);
  font-size:1.15rem;
  font-weight:800;
  letter-spacing:.005em;
  text-transform:uppercase;
  line-height:1;
}
.brand__hi{
  color:var(--c-accent);
  font-weight:800;
}
.brand__text em{
  font-style:normal;
  font-size:.6rem;
  font-weight:500;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:currentColor;
  opacity:.65;
  margin-top:5px;
}
/* subtle pulse for the heating coil inside the brand mark */
.brand__icon .brand__coil{
  transform-origin:50% 73px;
  animation: coilWarm 4.5s ease-in-out infinite;
}
@keyframes coilWarm{
  0%,100%{ opacity:.85 }
  50%{ opacity:1; filter:drop-shadow(0 0 6px rgba(232,128,26,.55)) }
}

.nav ul{
  display:flex; align-items:center; gap:2.2rem;
}
.nav a{
  font-size:.84rem;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:inherit;
  position:relative;
  padding:.4rem 0;
  transition:color var(--t-fast);
}
.nav a:not(.nav__cta)::after{
  content:"";
  position:absolute; left:0; bottom:-2px;
  width:100%; height:2px;
  background:var(--c-accent);
  transform:scaleX(0); transform-origin:right;
  transition:transform var(--t-med);
}
.nav a:not(.nav__cta):hover::after,
.nav a.is-active::after{ transform:scaleX(1); transform-origin:left }
.nav a.is-active{ color:var(--c-accent) }

/* CTA – dunkler Button bleibt immer kontraststark */
.nav__cta{
  background:var(--c-ink) !important;
  color:#F5F1EA !important;
  padding:.75rem 1.3rem !important;
  border-radius:var(--radius);
  letter-spacing:.08em;
  transition:background var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
  box-shadow:0 1px 0 rgba(0,0,0,.15);
}
.nav__cta::after{ display:none !important }
.nav__cta:hover{ background:var(--c-accent) !important; transform:translateY(-1px) }

/* Hellem Header (über dunklem Hero) eine kreme CTA spendieren für noch besseren Kontrast */
.site-header:not(.is-scrolled) .nav__cta{
  background:#F5F1EA !important;
  color:var(--c-ink) !important;
}
.site-header:not(.is-scrolled) .nav__cta:hover{
  background:var(--c-accent) !important;
  color:#fff !important;
}

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  width:32px; height:32px;
  justify-content:center;
}
.nav-toggle span{
  display:block;
  width:24px; height:2px;
  background:currentColor;
  transition:transform var(--t-fast), opacity var(--t-fast);
}
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.5px) rotate(45deg) }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0 }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg) }

@media (max-width: 960px){
  .nav-toggle{ display:flex }
  .nav{
    position:fixed; inset:0 0 0 auto;
    width:min(86%, 380px);
    background:var(--c-bg);
    transform:translateX(100%);
    transition:transform var(--t-med);
    padding:6rem 2.5rem 2.5rem;
    box-shadow:-30px 0 80px rgba(14,20,25,.15);
  }
  .nav.is-open{ transform:translateX(0) }
  .nav ul{ flex-direction:column; align-items:flex-start; gap:1.4rem }
  .nav a{ font-size:1.05rem }
}

/* ---------- 7. HERO ---------- */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  padding:8rem 0 6rem;
  color:#F5F1EA;
}
.hero__bg{
  position:absolute; inset:-10% -2% -2%;
  background:
    radial-gradient(circle at 30% 30%, rgba(217,119,6,.25), transparent 50%),
    radial-gradient(circle at 75% 60%, rgba(184,148,92,.18), transparent 55%),
    linear-gradient(135deg, #1B232B 0%, #0E1419 60%, #050708 100%);
  z-index:-2;
  will-change:transform;
}
.hero__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(14,20,25,0) 0%, rgba(14,20,25,.4) 100%),
    radial-gradient(ellipse at top, transparent, rgba(14,20,25,.5) 75%);
  z-index:-1;
}
.hero__grain{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.45'/></svg>");
  opacity:.08;
  z-index:-1;
  mix-blend-mode:overlay;
  pointer-events:none;
}
.hero__inner{ position:relative; z-index:1; max-width:1100px }

.hero__brand{
  display:inline-flex;
  align-items:center;
  gap:1.1rem;
  padding:.7rem 1.3rem .7rem .7rem;
  border:1px solid rgba(245,241,234,.18);
  border-radius:100px;
  background:rgba(245,241,234,.04);
  backdrop-filter:blur(8px);
  margin-bottom:2.5rem;
  transition:border-color var(--t-fast), background var(--t-fast);
}
.hero__brand:hover{
  border-color:rgba(232,128,26,.5);
  background:rgba(232,128,26,.06);
}
.hero__brand-mark{ flex-shrink:0; animation:floaty 6s ease-in-out infinite }
@keyframes floaty{
  0%,100%{ transform:translateY(0) }
  50%{ transform:translateY(-3px) }
}
.hero__brand-claim{
  font-family:var(--f-display);
  font-size:1.05rem;
  font-style:italic;
  font-weight:500;
  color:#F5F1EA;
  line-height:1.2;
  letter-spacing:-.005em;
}
.hero__brand-claim em{ font-style:italic; color:var(--c-accent) }

.hero .eyebrow{
  color:var(--c-accent-2);
  margin-bottom:2rem;
}
.hero__title{
  font-family:var(--f-display);
  font-size:var(--fs-hero);
  font-weight:500;
  line-height:1;
  letter-spacing:-.02em;
  margin:0 0 2rem;
}
.hero__title .line{
  display:block;
  overflow:hidden;
}
.hero__title em{
  font-style:italic;
  color:var(--c-accent-2);
  font-weight:400;
}
.hero__lead{
  font-size:clamp(1.1rem, 1.5vw, 1.3rem);
  line-height:1.55;
  max-width:54ch;
  color:rgba(245,241,234,.82);
  margin-bottom:2.5rem;
}
.hero__cta{
  display:flex; flex-wrap:wrap; gap:1rem;
  margin-bottom:4.5rem;
}
.hero__cta .btn--ghost{
  --fg:#F5F1EA;
  --br: rgba(245,241,234,.4);
}
.hero__cta .btn--ghost:hover{ --bg:#F5F1EA; --fg:var(--c-dark) }

.hero__stats{
  display:flex; flex-wrap:wrap;
  gap:clamp(2rem, 5vw, 4rem);
  padding-top:2.5rem;
  border-top:1px solid rgba(245,241,234,.15);
}
.hero__stats li{
  display:flex; flex-direction:column;
}
.hero__stats strong{
  font-family:var(--f-display);
  font-size:clamp(1.7rem, 3vw, 2.4rem);
  font-weight:500;
  color:#F5F1EA;
  line-height:1;
  margin-bottom:.4rem;
}
.hero__stats span{
  font-size:.82rem;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:rgba(245,241,234,.6);
}
/* Counter-Zahl (z. B. 35) im großen <strong> darf NICHT auf Label-Größe schrumpfen */
.hero__stats strong span{
  font-size:inherit;
  letter-spacing:normal;
  text-transform:none;
  color:inherit;
}

.scroll-cue{
  position:absolute;
  left:50%;
  bottom:2.5rem;
  transform:translateX(-50%);
  width:24px; height:40px;
  border:1px solid rgba(245,241,234,.4);
  border-radius:14px;
  z-index:2;
}
.scroll-cue span{
  position:absolute;
  left:50%; top:8px;
  width:2px; height:8px;
  background:var(--c-accent-2);
  transform:translateX(-50%);
  border-radius:2px;
  animation:scrollCue 1.8s ease-in-out infinite;
}
@keyframes scrollCue{
  0%{ opacity:0; transform:translate(-50%, 0) }
  40%{ opacity:1 }
  80%,100%{ opacity:0; transform:translate(-50%, 14px) }
}

/* ---------- 8. Trust marquee ---------- */
.trust{
  background:var(--c-ink);
  color:#F5F1EA;
  padding:1.4rem 0;
  overflow:hidden;
  border-top:1px solid rgba(245,241,234,.06);
  border-bottom:1px solid rgba(245,241,234,.06);
}
.trust__marquee{ overflow:hidden; mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent) }
.trust__track{
  display:flex; gap:4rem;
  white-space:nowrap;
  animation:marquee 480s linear infinite;
  font-family:var(--f-display);
  font-style:italic;
  font-size:1.15rem;
  color:rgba(245,241,234,.78);
}
.trust__track:hover{ animation-play-state:paused }
.trust__track span{ flex-shrink:0 }
@keyframes marquee{
  from{ transform:translateX(0) }
  to{ transform:translateX(-50%) }
}

/* ---------- 9. Manifest ---------- */
.manifest{ padding:var(--pad-y) 0; background:var(--c-bg) }
.manifest__grid{
  display:grid;
  grid-template-columns: 1fr 2.2fr;
  gap:clamp(2rem, 6vw, 6rem);
  align-items:start;
}
.manifest__col-meta{ position:sticky; top:7rem }
@media (max-width:820px){
  .manifest__grid{ grid-template-columns:1fr }
  .manifest__col-meta{ position:static }
}

/* ---------- 10. Services ---------- */
.services{
  padding:var(--pad-y) 0;
  background:var(--c-bg-2);
  position:relative;
}
.service-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:1.5rem;
}
.service-card{
  position:relative;
  background:var(--c-bg);
  border:1px solid var(--c-line-soft);
  border-radius:var(--radius-lg);
  padding:2.5rem 2rem 2rem;
  transition:transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
  overflow:hidden;
}
.service-card::before{
  content:"";
  position:absolute; top:0; left:0; right:0;
  height:2px;
  background:linear-gradient(90deg, var(--c-accent), var(--c-accent-2));
  transform:scaleX(0); transform-origin:left;
  transition:transform var(--t-slow);
}
.service-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
  border-color:var(--c-line);
}
.service-card:hover::before{ transform:scaleX(1) }
.service-card__num{
  font-family:var(--f-display);
  font-style:italic;
  font-size:1rem;
  color:var(--c-accent);
  margin-bottom:1.2rem;
  letter-spacing:.05em;
}
.service-card h3{
  font-family:var(--f-display);
  font-size:var(--fs-h3);
  font-weight:600;
  margin:0 0 .9rem;
  letter-spacing:-.005em;
}
.service-card p{
  color:var(--c-ink-soft);
  font-size:.96rem;
  line-height:1.6;
  margin-bottom:1.5rem;
}
.service-card__points{
  border-top:1px solid var(--c-line-soft);
  padding-top:1.25rem;
}
.service-card__points li{
  font-size:.82rem;
  color:var(--c-ink-soft);
  padding:.3rem 0 .3rem 1.2rem;
  position:relative;
  letter-spacing:.02em;
}
.service-card__points li::before{
  content:"";
  position:absolute; left:0; top:.85rem;
  width:6px; height:6px; border-radius:50%;
  background:var(--c-accent);
}

/* ---------- 11. Parallax banner ---------- */
.banner-parallax{
  position:relative;
  min-height:60vh;
  display:flex; align-items:center;
  overflow:hidden;
  isolation:isolate;
  padding:6rem 0;
  color:#F5F1EA;
}
.banner-parallax__bg{
  position:absolute; inset:-15% 0;
  background:
    radial-gradient(circle at 25% 50%, rgba(217,119,6,.15), transparent 40%),
    radial-gradient(circle at 80% 50%, rgba(184,148,92,.1), transparent 45%),
    linear-gradient(135deg, #1B232B, #0E1419);
  z-index:-2;
  will-change:transform;
}
.banner-parallax__overlay{
  position:absolute; inset:0;
  background:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='600' viewBox='0 0 800 600'><g fill='none' stroke='%23B8945C' stroke-width='1' opacity='.08'><path d='M0,300 Q200,200 400,300 T800,300'/><path d='M0,350 Q200,250 400,350 T800,350'/><path d='M0,400 Q200,300 400,400 T800,400'/></g></svg>") center/cover no-repeat;
  z-index:-1;
  opacity:.7;
}
.banner-parallax blockquote{
  margin:0;
  max-width:880px;
  text-align:center;
  margin-inline:auto;
}
.banner-parallax blockquote p{
  font-family:var(--f-display);
  font-style:italic;
  font-weight:400;
  font-size:clamp(1.4rem, 2.6vw, 2.2rem);
  line-height:1.4;
  margin:0 0 1.5rem;
  letter-spacing:-.005em;
}
.banner-parallax cite{
  font-style:normal;
  font-size:.82rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-accent-2);
}

/* ---------- 12. Process ---------- */
.process{ padding:var(--pad-y) 0; background:var(--c-bg) }
.process-list{
  counter-reset:step;
  border-top:1px solid var(--c-line);
}
.process-step{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:clamp(1.5rem, 4vw, 4rem);
  padding:2.5rem 0;
  border-bottom:1px solid var(--c-line);
  align-items:start;
  transition:background var(--t-med);
}
.process-step:hover{ background:rgba(217,119,6,.03) }
.process-step__num{
  font-family:var(--f-display);
  font-style:italic;
  color:var(--c-accent);
  position:relative;
}
.process-step__num span{
  font-size:clamp(2rem, 3.5vw, 3rem);
  font-weight:500;
  display:block;
  line-height:1;
}
.process-step__body h3{
  font-family:var(--f-display);
  font-size:clamp(1.5rem, 2.4vw, 2rem);
  font-weight:500;
  margin:0 0 .7rem;
  letter-spacing:-.005em;
}
.process-step__body p{
  color:var(--c-ink-soft);
  font-size:1.05rem;
  line-height:1.6;
  margin:0;
  max-width:62ch;
}
@media (max-width:680px){
  .process-step{ grid-template-columns:1fr; gap:.8rem }
}

/* ---------- 13. Split / Benefits ---------- */
.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  min-height:90vh;
  background:var(--c-dark);
  color:#F5F1EA;
  position:relative;
  overflow:hidden;
}
.split__media{
  position:relative;
  overflow:hidden;
  will-change:transform;
}
.split__media-inner{
  position:absolute; inset:-10%;
  background:
    radial-gradient(circle at 50% 30%, rgba(217,119,6,.35), transparent 55%),
    linear-gradient(160deg, #2A3540 0%, #0E1419 70%);
}
.split__media::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 30px, rgba(184,148,92,.08) 30px 31px),
    repeating-linear-gradient(-45deg, transparent 0 30px, rgba(184,148,92,.05) 30px 31px);
  mix-blend-mode:overlay;
}
.split__content{
  display:flex; align-items:center;
  padding:var(--pad-y) clamp(1.5rem, 5vw, 5rem);
}
.split__content-inner{ max-width:560px }
.split__content .meta-label{ color:var(--c-accent-2) }
.split__content .h-display{ color:#F5F1EA }
.split__content .h-display em{ color:var(--c-accent-2) }

.benefit-list{
  display:flex; flex-direction:column;
  border-top:1px solid rgba(245,241,234,.12);
  margin-top:2rem;
}
.benefit-list li{
  padding:1.4rem 0 1.4rem 2.5rem;
  border-bottom:1px solid rgba(245,241,234,.12);
  font-size:1.05rem;
  line-height:1.55;
  color:rgba(245,241,234,.8);
  position:relative;
  transition:padding-left var(--t-fast), color var(--t-fast);
}
.benefit-list li::before{
  content:"";
  position:absolute; left:0; top:1.7rem;
  width:18px; height:1px;
  background:var(--c-accent-2);
  transition:width var(--t-fast);
}
.benefit-list li:hover{ padding-left:3rem; color:#F5F1EA }
.benefit-list li:hover::before{ width:30px; background:var(--c-accent) }
.benefit-list strong{ color:#F5F1EA; font-weight:600 }

@media (max-width:900px){
  .split{ grid-template-columns:1fr }
  .split__media{ min-height:40vh }
}

/* ---------- 14. References ---------- */
.references{ padding:var(--pad-y) 0; background:var(--c-bg) }
.reference-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:1.5rem;
}
.reference{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform var(--t-med), box-shadow var(--t-med);
}
.reference:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-md);
}
.reference__visual{
  aspect-ratio: 4/3;
  position:relative;
  background:
    radial-gradient(circle at 30% 30%, hsl(var(--ref-hue,24) 60% 55% / .25), transparent 50%),
    linear-gradient(135deg, hsl(var(--ref-hue,24) 30% 25%), hsl(var(--ref-hue,24) 50% 15%));
  overflow:hidden;
  display:flex; flex-direction:column;
  justify-content:space-between;
  padding:1.5rem;
  color:#F5F1EA;
}
.reference__visual::after{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 26px, rgba(255,255,255,.04) 26px 27px),
    repeating-linear-gradient(90deg, transparent 0 26px, rgba(255,255,255,.04) 26px 27px);
}
.reference__year{
  font-family:var(--f-display);
  font-size:3rem;
  font-weight:500;
  font-style:italic;
  line-height:1;
  position:relative;
  z-index:1;
  align-self:flex-end;
  color:rgba(245,241,234,.75);
}
.reference__type{
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(245,241,234,.7);
  position:relative; z-index:1;
}
.reference__body{ padding:1.5rem 1.5rem 1.75rem }
.reference__body h3{
  font-family:var(--f-display);
  font-size:1.4rem;
  font-weight:500;
  margin:0 0 .5rem;
}
.reference__body p{
  margin:0;
  color:var(--c-ink-soft);
  font-size:.92rem;
}

/* ---------- 15. Partners ---------- */
.partners{
  padding:var(--pad-y) 0;
  background:var(--c-bg-2);
}
.partners__grid{
  display:grid;
  grid-template-columns: 1.2fr 1fr;
  gap:clamp(2rem, 6vw, 6rem);
  align-items:center;
}
.partners__text .btn{ margin-top:1.5rem }

.partners__visual{
  display:flex; justify-content:center;
}
.ring-anim{
  position:relative;
  width:min(100%, 460px);
  aspect-ratio:1;
}
.ring{
  position:absolute; inset:0;
  border:1px solid var(--c-line);
  border-radius:50%;
}
.ring--1{ inset:8% }
.ring--2{ inset:22% }
.ring--3{ inset:36% }
.ring-core{
  position:absolute; inset:36%;
  border-radius:50%;
  display:grid; place-items:center;
  font-family:var(--f-display);
  font-weight:600;
  font-size:1.1rem;
  letter-spacing:.2em;
  color:var(--c-ink);
  background:
    radial-gradient(circle at 35% 30%, rgba(217,119,6,.18), transparent 60%),
    var(--c-bg);
  box-shadow:0 10px 40px -10px rgba(14,20,25,.2);
}
.ring-tag{
  position:absolute;
  font-size:.78rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--c-ink);
  background:var(--c-bg);
  border:1px solid var(--c-line);
  padding:.4rem .9rem;
  border-radius:100px;
  white-space:nowrap;
  box-shadow:var(--shadow-sm);
  transition:transform var(--t-med), background var(--t-med), color var(--t-med);
}
.ring-tag:hover{ background:var(--c-accent); color:#fff; border-color:var(--c-accent); transform:scale(1.05) }
.ring-tag--1{ top:0;   left:50%; transform:translateX(-50%) }
.ring-tag--2{ top:18%; right:-5% }
.ring-tag--3{ bottom:18%; right:-5% }
.ring-tag--4{ bottom:0; left:50%; transform:translateX(-50%) }
.ring-tag--5{ bottom:18%; left:-5% }
.ring-tag--6{ top:18%; left:-5% }

.ring{ animation:ringPulse 6s ease-in-out infinite }
.ring--2{ animation-delay:-2s }
.ring--3{ animation-delay:-4s }
@keyframes ringPulse{
  0%,100%{ opacity:.4; transform:scale(1) }
  50%{ opacity:.8; transform:scale(1.02) }
}

@media (max-width:900px){
  .partners__grid{ grid-template-columns:1fr }
  .ring-anim{ margin:2rem auto 0 }
}

/* ---------- 16. FAQ ---------- */
.faq{ padding:var(--pad-y) 0; background:var(--c-bg) }
.faq-list{
  max-width:880px;
  border-top:1px solid var(--c-line);
}
.faq-item{
  border-bottom:1px solid var(--c-line);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1.6rem 3rem 1.6rem 0;
  font-family:var(--f-display);
  font-size:clamp(1.15rem, 1.7vw, 1.45rem);
  font-weight:500;
  color:var(--c-ink);
  position:relative;
  transition:color var(--t-fast);
}
.faq-item summary::-webkit-details-marker{ display:none }
.faq-item summary::after{
  content:"";
  position:absolute;
  right:.5rem; top:50%;
  width:14px; height:14px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:translateY(-70%) rotate(45deg);
  transition:transform var(--t-med);
}
.faq-item[open] summary{ color:var(--c-accent-deep) }
.faq-item[open] summary::after{ transform:translateY(-30%) rotate(-135deg) }
.faq-item:hover summary{ color:var(--c-accent-deep) }
.faq-body{
  padding:0 0 1.8rem;
  color:var(--c-ink-soft);
  max-width:62ch;
  line-height:1.7;
  animation:fadeUp .4s ease both;
}
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(-6px) }
  to{   opacity:1; transform:translateY(0) }
}

/* ---------- 17. CTA ---------- */
.cta{
  position:relative;
  padding:var(--pad-y) 0;
  overflow:hidden;
  isolation:isolate;
  color:#F5F1EA;
}
.cta__bg{
  position:absolute; inset:-10%;
  background:
    radial-gradient(circle at 70% 30%, rgba(217,119,6,.3), transparent 50%),
    radial-gradient(circle at 20% 70%, rgba(184,148,92,.18), transparent 55%),
    linear-gradient(135deg, #1B232B 0%, #0E1419 70%);
  z-index:-2;
  will-change:transform;
}
.cta__overlay{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.45'/></svg>");
  opacity:.06;
  mix-blend-mode:overlay;
  z-index:-1;
}
.cta__grid{
  display:grid;
  grid-template-columns: 1.1fr 1fr;
  gap:clamp(2.5rem, 6vw, 6rem);
  align-items:start;
}
.cta__intro{ padding-top:.5rem }
.cta__contact{
  display:flex; flex-direction:column; gap:1rem;
  margin-top:2.5rem;
  padding-top:2.5rem;
  border-top:1px solid rgba(245,241,234,.18);
}
.cta__contact li{
  display:flex; align-items:center; gap:1rem;
  font-size:1.05rem;
  color:rgba(245,241,234,.85);
}
.cta__contact svg{ flex-shrink:0; color:var(--c-accent-2) }
.cta__contact a:hover{ color:var(--c-accent-2) }

.cta__form{
  background:#F5F1EA;
  color:var(--c-ink);
  padding:clamp(1.75rem, 3vw, 2.75rem);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
}
.cta__form-title{
  font-family:var(--f-display);
  font-size:1.7rem;
  font-weight:600;
  margin:0 0 1.75rem;
  padding-bottom:1.25rem;
  border-bottom:1px solid var(--c-line);
}
.form-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:1rem;
  margin-bottom:1rem;
}
@media (max-width:480px){ .form-row{ grid-template-columns:1fr } }
.cta__form label{
  display:flex; flex-direction:column;
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
}
.cta__form label.full{ margin-bottom:1rem }
.cta__form input,
.cta__form select,
.cta__form textarea{
  font-family:inherit;
  font-size:1rem;
  font-weight:400;
  letter-spacing:0;
  text-transform:none;
  color:var(--c-ink);
  background:transparent;
  border:0;
  border-bottom:1px solid var(--c-line);
  padding:.65rem 0;
  margin-top:.3rem;
  outline:none;
  transition:border-color var(--t-fast);
  border-radius:0;
}
.cta__form textarea{ resize:vertical; min-height:80px }
.cta__form input:focus,
.cta__form select:focus,
.cta__form textarea:focus{
  border-color:var(--c-accent);
}
.cta__form .checkbox{
  flex-direction:row;
  align-items:flex-start;
  gap:.7rem;
  font-size:.8rem;
  letter-spacing:0;
  text-transform:none;
  color:var(--c-ink-soft);
  margin:1.25rem 0 1.5rem;
}
.cta__form .checkbox input{ margin-top:3px; accent-color:var(--c-accent) }
.cta__form .checkbox a{ color:var(--c-accent-deep); text-decoration:underline }
.form-hint{
  font-size:.78rem;
  text-align:center;
  color:var(--c-ink-soft);
  margin:1rem 0 0;
}

@media (max-width:900px){
  .cta__grid{ grid-template-columns:1fr }
}

/* ---------- 18. Footer ---------- */
.site-footer{
  background:var(--c-dark);
  color:rgba(245,241,234,.7);
  padding:5rem 0 2rem;
}
.footer__grid{
  display:grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap:3rem;
  padding-bottom:4rem;
  border-bottom:1px solid rgba(245,241,234,.1);
}
@media (max-width:760px){
  .footer__grid{ grid-template-columns:1fr 1fr; gap:2.5rem 2rem }
}
@media (max-width:480px){
  .footer__grid{ grid-template-columns:1fr }
}
.brand--footer{ color:#F5F1EA }
.brand--footer .brand__text em{ color:rgba(245,241,234,.5) }
.footer__claim{
  margin:1.5rem 0 0;
  font-size:.95rem;
  line-height:1.6;
  max-width:32ch;
}
.footer__claim strong{
  color:#F5F1EA;
  font-weight:600;
  letter-spacing:.005em;
}
.footer__col h4{
  font-family:var(--f-sans);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#F5F1EA;
  margin:0 0 1.2rem;
}
.footer__col ul{ display:flex; flex-direction:column; gap:.7rem }
.footer__col a{ font-size:.92rem; color:rgba(245,241,234,.7) }
.footer__col a:hover{ color:var(--c-accent-2) }

.footer__bottom{
  display:flex; justify-content:space-between; flex-wrap:wrap;
  gap:1rem;
  padding-top:2rem;
  font-size:.82rem;
  color:rgba(245,241,234,.5);
}

/* ---------- 19. To-Top ---------- */
.to-top{
  position:fixed;
  right:1.5rem; bottom:1.5rem;
  width:46px; height:46px;
  background:var(--c-ink);
  color:#F5F1EA;
  border-radius:50%;
  display:grid; place-items:center;
  z-index:40;
  opacity:0; transform:translateY(20px);
  transition:opacity var(--t-med), transform var(--t-med), background var(--t-fast);
  box-shadow:var(--shadow-md);
  pointer-events:none;
}
.to-top.is-visible{ opacity:1; transform:translateY(0); pointer-events:auto }
.to-top:hover{ background:var(--c-accent) }

/* ---------- 20. Scroll reveal ---------- */
.reveal{
  opacity:0;
  transform:translateY(32px);
  transition: opacity 1.1s cubic-bezier(.2,.7,.3,1), transform 1.1s cubic-bezier(.2,.7,.3,1);
  will-change:transform, opacity;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
/* staggered children in lists */
.service-grid .reveal{ transition-delay:calc(var(--i, 0) * 90ms) }
.reference-grid .reveal{ transition-delay:calc(var(--i, 0) * 90ms) }
.benefit-list .reveal{ transition-delay:calc(var(--i, 0) * 60ms) }
.values-grid .reveal{ transition-delay:calc(var(--i, 0) * 90ms) }

/* ---------- 20b. Premium Text-Reveal (Wort-Masken) ---------- */
.split-words{ display:inline-block }
.split-words .word{
  display:inline-block;
  overflow:hidden;
  vertical-align:bottom;
  padding-bottom:.05em;
  margin-bottom:-.05em;
}
.split-words .word > span{
  display:inline-block;
  transform:translate3d(0, 110%, 0);
  transition:transform 1.1s cubic-bezier(.16,.84,.32,1);
}
.split-words.is-visible .word > span{ transform:translate3d(0,0,0) }
.split-words .word:nth-child(1) > span{ transition-delay:.05s }
.split-words .word:nth-child(2) > span{ transition-delay:.13s }
.split-words .word:nth-child(3) > span{ transition-delay:.21s }
.split-words .word:nth-child(4) > span{ transition-delay:.29s }
.split-words .word:nth-child(5) > span{ transition-delay:.37s }
.split-words .word:nth-child(6) > span{ transition-delay:.45s }
.split-words .word:nth-child(7) > span{ transition-delay:.53s }
.split-words .word:nth-child(8) > span{ transition-delay:.61s }
.split-words .word:nth-child(9) > span{ transition-delay:.69s }
.split-words .word:nth-child(10) > span{ transition-delay:.77s }

/* ---------- 20c. Scroll Progress (Premium-Detail) ---------- */
.scroll-progress{
  position:fixed; top:0; left:0;
  height:2px;
  width:0%;
  background:linear-gradient(90deg, var(--c-accent), var(--c-accent-2));
  z-index:100;
  transition:width .12s linear;
  pointer-events:none;
  box-shadow:0 0 12px rgba(232,128,26,.6);
}

/* ---------- 20d. Page Load Curtain (Premium reveal) ---------- */
.page-curtain{
  position:fixed; inset:0;
  background:var(--c-dark);
  z-index:99;
  transform-origin:bottom;
  transform:scaleY(1);
  transition:transform 1.1s cubic-bezier(.76,0,.24,1);
  pointer-events:none;
}
body.loaded .page-curtain{ transform:scaleY(0) }

/* ---------- 20e. Card 3D-Tilt – subtle premium hover ---------- */
.service-card,
.value-card,
.reference{
  transform-style:preserve-3d;
  will-change:transform;
}
@media (hover:hover) and (pointer:fine){
  .service-card:hover{ transform:translateY(-8px) perspective(1200px) rotateX(2deg) rotateY(-2deg) }
  .value-card:hover{   transform:translateY(-6px) perspective(1200px) rotateX(1.5deg) rotateY(-1.5deg) }
  .reference:hover{    transform:translateY(-8px) perspective(1200px) rotateX(1.5deg) rotateY(-2deg) }
}

/* ---------- 20f. Section divider reveal ---------- */
.divider-line{
  display:block;
  width:0%;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--c-accent) 50%, transparent);
  margin:0;
  transition:width 1.6s cubic-bezier(.2,.7,.3,1);
}
.divider-line.is-visible{ width:100% }

/* ---------- 20g. Number-counter highlight ---------- */
[data-counter]{ display:inline-block; min-width:.6em; font-variant-numeric:tabular-nums }

/* ---------- 20h. Magnetic button hint ---------- */
.btn{ transition:transform .35s cubic-bezier(.2,.7,.3,1), background var(--t-fast), color var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast) }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
  }
  .reveal{ opacity:1; transform:none }
  [data-parallax]{ transform:none !important }
  html{ scroll-behavior:auto }
}

/* ---------- 21. Subpage layout (impressum, datenschutz) ---------- */
.subpage-hero{
  background:var(--c-dark);
  color:#F5F1EA;
  padding:11rem 0 4rem;
  position:relative;
  overflow:hidden;
}
.subpage-hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(circle at 70% 30%, rgba(217,119,6,.18), transparent 50%);
}
.subpage-hero .container{ position:relative }
.subpage-hero h1{
  font-family:var(--f-display);
  font-size:clamp(2.4rem, 5vw, 4rem);
  font-weight:500;
  margin:1rem 0 0;
  letter-spacing:-.01em;
}
.subpage-body{
  padding:var(--pad-y) 0;
}
.subpage-body .container{ max-width:780px }
.subpage-body h2{
  font-family:var(--f-display);
  font-size:1.7rem;
  font-weight:600;
  margin:2.5rem 0 1rem;
}
.subpage-body h3{
  font-family:var(--f-sans);
  font-size:1.05rem;
  font-weight:600;
  margin:1.6rem 0 .7rem;
}
.subpage-body p,
.subpage-body li{
  color:var(--c-ink-soft);
  line-height:1.7;
}
.subpage-body ul{
  list-style:disc;
  padding-left:1.2rem;
  margin:1rem 0;
}
.subpage-body a{ color:var(--c-accent-deep); text-decoration:underline }

/* ============================================================
   22. PAGE HERO – Premium-Header für Unterseiten
   ============================================================ */
.page-hero{
  position:relative;
  min-height:62vh;
  display:flex; align-items:flex-end;
  padding:9rem 0 5rem;
  overflow:hidden;
  isolation:isolate;
  color:#F5F1EA;
  background:var(--c-dark);
}
.page-hero__bg{
  position:absolute; inset:-10%;
  z-index:-2; will-change:transform;
  background:
    radial-gradient(circle at 25% 40%, rgba(232,128,26,.22), transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(184,148,92,.18), transparent 55%),
    linear-gradient(135deg, #1B232B 0%, #0E1419 70%, #050708 100%);
}
.page-hero__overlay{
  position:absolute; inset:0; z-index:-1;
  background:
    linear-gradient(180deg, rgba(14,20,25,.55) 0%, rgba(14,20,25,.15) 50%, rgba(14,20,25,.6) 100%);
}
.page-hero__grain{
  position:absolute; inset:0; z-index:-1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.45'/></svg>");
  opacity:.07; mix-blend-mode:overlay; pointer-events:none;
}
.page-hero__inner{ position:relative; z-index:1; max-width:1100px }

/* Zweiter Parallax-Layer im Subpage-Hero: langsamer, dekorativer Glanz-Orb */
.page-hero__orb{
  position:absolute;
  width:60vw; height:60vw;
  max-width:780px; max-height:780px;
  right:-20%; top:-20%;
  border-radius:50%;
  background:
    radial-gradient(circle, rgba(232,128,26,.18) 0%, rgba(232,128,26,0) 60%);
  z-index:-1;
  pointer-events:none;
  will-change:transform;
  filter:blur(30px);
}
.page-hero__orb--2{
  right:auto; left:-15%; top:auto; bottom:-25%;
  width:40vw; height:40vw;
  background:radial-gradient(circle, rgba(184,148,92,.16) 0%, rgba(184,148,92,0) 60%);
}

/* Lange, dünne Akzentlinien im Subpage-Hero (zeichnen sich beim Scroll) */
.page-hero__line{
  position:absolute;
  left:var(--pad-x); right:var(--pad-x);
  bottom:3rem;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(184,148,92,.45) 50%, transparent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform 2s cubic-bezier(.16,.84,.32,1);
  z-index:0;
}
.page-hero.is-revealed .page-hero__line{ transform:scaleX(1) }
.page-hero__crumbs{
  display:flex; align-items:center; gap:.6rem;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  color:rgba(245,241,234,.55);
  margin-bottom:1.5rem;
}
.page-hero__crumbs a:hover{ color:var(--c-accent-2) }
.page-hero__crumbs span{ opacity:.55 }
.page-hero h1{
  font-family:var(--f-display);
  font-weight:500;
  font-size:clamp(2.6rem, 6vw, 5rem);
  line-height:1.05;
  letter-spacing:-.015em;
  margin:0 0 1.2rem;
  max-width:18ch;
}
.page-hero h1 em{ font-style:italic; color:var(--c-accent-2); font-weight:500 }
.page-hero__lead{
  font-size:clamp(1.05rem, 1.4vw, 1.25rem);
  line-height:1.6;
  color:rgba(245,241,234,.82);
  max-width:55ch;
  margin:0;
}

/* ============================================================
   23. REGION – Münsterland-Sektion
   ============================================================ */
.region{
  padding:var(--pad-y) 0;
  background:var(--c-bg);
  position:relative;
  overflow:hidden;
}
.region__grid{
  display:grid;
  grid-template-columns: 1fr 1.1fr;
  gap:clamp(2.5rem, 6vw, 6rem);
  align-items:center;
}
@media (max-width:920px){
  .region__grid{ grid-template-columns:1fr }
}
.region__copy .h-display{ margin-bottom:1.5rem }
.region__cities{
  display:flex; flex-wrap:wrap; gap:.5rem;
  margin:1.5rem 0 2rem;
}
.region__cities li{
  font-size:.84rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:.5rem 1rem;
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:100px;
  color:var(--c-ink);
  font-weight:500;
  transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.region__cities li:hover{
  background:var(--c-accent);
  color:#fff;
  border-color:var(--c-accent);
  transform:translateY(-2px);
}
.region__cities li.is-hq{
  background:var(--c-ink); color:#F5F1EA; border-color:var(--c-ink);
}
.region__cities li.is-hq::before{
  content:"★ ";
  color:var(--c-accent);
}

/* Stilisierte Karte */
.region__map{
  position:relative;
  aspect-ratio: 5 / 4;
  background:
    radial-gradient(circle at 30% 35%, rgba(232,128,26,.12), transparent 55%),
    linear-gradient(135deg, #ECE4D6 0%, #F5F1EA 100%);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  overflow:hidden;
}
.region__map::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, transparent 0 32px, rgba(14,20,25,.04) 32px 33px),
    repeating-linear-gradient(90deg, transparent 0 32px, rgba(14,20,25,.04) 32px 33px);
  pointer-events:none;
}
.region__map svg{
  position:relative;
  width:100%; height:100%;
  display:block;
}
.map-pin{
  cursor:default;
  transition:transform .3s ease;
}
.map-pin:hover{ transform:scale(1.15); transform-origin:center }
.map-pin__dot{
  fill:var(--c-accent);
  filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));
}
.map-pin__dot--hq{ fill:var(--c-ink) }
.map-pin__label{
  font-family:var(--f-sans);
  font-size:10px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  fill:var(--c-ink);
}
.map-pin__pulse{
  fill:var(--c-accent);
  opacity:.4;
  animation:mapPulse 2.4s ease-out infinite;
  transform-origin:center;
  transform-box:fill-box;
}
@keyframes mapPulse{
  0%{ transform:scale(1); opacity:.5 }
  100%{ transform:scale(3.5); opacity:0 }
}
.region__map-legend{
  position:absolute;
  left:1.25rem; bottom:1.25rem;
  font-size:.72rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  background:rgba(245,241,234,.9);
  backdrop-filter:blur(8px);
  padding:.4rem .8rem;
  border-radius:100px;
}

/* Regionaler Stempel */
.region__stamp{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.55rem 1rem;
  border:1px solid var(--c-accent-deep);
  border-radius:100px;
  background:rgba(232,128,26,.06);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-accent-deep);
  margin-bottom:1.5rem;
}
.region__stamp::before{
  content:"";
  width:8px; height:8px; border-radius:50%;
  background:var(--c-accent);
  animation:beacon 1.6s ease-in-out infinite;
}
@keyframes beacon{
  0%,100%{ box-shadow:0 0 0 0 rgba(232,128,26,.6) }
  70%{ box-shadow:0 0 0 8px rgba(232,128,26,0) }
}

/* ============================================================
   24. STATS / KENNZAHLEN GRID
   ============================================================ */
.stats-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:1rem;
  padding:2.5rem 0;
  border-top:1px solid var(--c-line);
  border-bottom:1px solid var(--c-line);
}
.stat{
  display:flex; flex-direction:column;
  padding:1rem;
}
.stat__num{
  font-family:var(--f-display);
  font-size:clamp(2.4rem, 4vw, 3.4rem);
  font-weight:500;
  color:var(--c-accent-deep);
  line-height:1;
  margin-bottom:.5rem;
}
.stat__num em{ font-style:normal; color:var(--c-accent) }
.stat__label{
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  font-weight:500;
}

/* ============================================================
   25. TWO-COL – Story-Block für Über-uns
   ============================================================ */
.two-col{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:clamp(2.5rem, 6vw, 6rem);
  padding:var(--pad-y) 0;
  align-items:center;
}
@media (max-width:820px){ .two-col{ grid-template-columns:1fr } }
.two-col--reverse .two-col__media{ order:1 }
@media (max-width:820px){ .two-col--reverse .two-col__media{ order:0 } }

.two-col__media{
  aspect-ratio: 4/5;
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 30% 30%, rgba(232,128,26,.2), transparent 50%),
    linear-gradient(160deg, #2A3540 0%, #0E1419 80%);
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.two-col__media::before{
  content:"";
  position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(45deg, transparent 0 32px, rgba(184,148,92,.07) 32px 33px);
  mix-blend-mode:overlay;
}
.two-col__media-mark{
  position:absolute; left:50%; top:50%;
  transform:translate(-50%, -50%);
  width:55%; max-width:220px;
  color:rgba(245,241,234,.4);
}

/* ============================================================
   26. Values / Karten-Grid (Über uns)
   ============================================================ */
.values{
  padding:var(--pad-y) 0;
  background:var(--c-bg-2);
}
.values-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:1.25rem;
}
.value-card{
  background:var(--c-bg);
  border:1px solid var(--c-line-soft);
  border-radius:var(--radius-lg);
  padding:2rem;
  transition:transform var(--t-med), box-shadow var(--t-med);
}
.value-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md) }
.value-card__icon{
  width:48px; height:48px;
  display:grid; place-items:center;
  background:rgba(232,128,26,.1);
  color:var(--c-accent-deep);
  border-radius:12px;
  margin-bottom:1.2rem;
}
.value-card h3{
  font-family:var(--f-display);
  font-size:1.35rem;
  font-weight:600;
  margin:0 0 .7rem;
}
.value-card p{
  font-size:.96rem;
  line-height:1.6;
  color:var(--c-ink-soft);
  margin:0;
}

/* ============================================================
   27. Big CTA-Strip (für Unterseiten-Footer)
   ============================================================ */
.cta-strip{
  background:var(--c-dark);
  color:#F5F1EA;
  padding:clamp(4rem, 8vw, 7rem) 0;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.cta-strip::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(circle at 80% 50%, rgba(232,128,26,.22), transparent 50%);
}
.cta-strip__orb{
  position:absolute;
  width:50vw; height:50vw;
  max-width:620px; max-height:620px;
  left:-10%; top:-30%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(184,148,92,.18) 0%, rgba(184,148,92,0) 60%);
  z-index:-1;
  filter:blur(40px);
  will-change:transform;
  pointer-events:none;
}
.cta-strip__inner{
  display:grid;
  grid-template-columns: 2fr 1fr;
  gap:3rem;
  align-items:center;
}
@media (max-width:820px){ .cta-strip__inner{ grid-template-columns:1fr } }
.cta-strip h2{
  font-family:var(--f-display);
  font-size:clamp(1.9rem, 3.5vw, 3rem);
  font-weight:500;
  margin:0 0 .8rem;
  line-height:1.1;
  color:#F5F1EA;
}
.cta-strip h2 em{ color:var(--c-accent-2); font-style:italic }
.cta-strip p{
  font-size:1.05rem;
  color:rgba(245,241,234,.8);
  margin:0;
  max-width:55ch;
}
.cta-strip__actions{ display:flex; flex-direction:column; gap:.8rem; align-items:flex-start }
@media (max-width:820px){ .cta-strip__actions{ flex-direction:row; flex-wrap:wrap } }
.cta-strip .btn--ghost{ --fg:#F5F1EA; --br:rgba(245,241,234,.4) }
.cta-strip .btn--ghost:hover{ --bg:#F5F1EA; --fg:var(--c-dark) }

/* ============================================================
   28. Region badge in Hero (Premium "Heimat"-Marker)
   ============================================================ */
.region-badge{
  display:inline-flex; align-items:center; gap:.6rem;
  padding:.45rem 1rem;
  border:1px solid rgba(245,241,234,.25);
  border-radius:100px;
  background:rgba(245,241,234,.05);
  backdrop-filter:blur(8px);
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#F5F1EA;
  margin-bottom:1.5rem;
  font-weight:500;
}
.region-badge svg{ color:var(--c-accent) }

/* ============================================================
   29. Service-Detail (Leistungen Page)
   ============================================================ */
.service-detail{
  padding:var(--pad-y) 0;
  border-bottom:1px solid var(--c-line);
}
.service-detail:nth-child(even){ background:var(--c-bg-2) }
.service-detail__grid{
  display:grid;
  grid-template-columns: 1fr 1.6fr;
  gap:clamp(2rem, 5vw, 5rem);
  align-items:start;
}
@media (max-width:820px){ .service-detail__grid{ grid-template-columns:1fr } }
.service-detail__num{
  font-family:var(--f-display);
  font-style:italic;
  font-size:clamp(3rem, 6vw, 5rem);
  font-weight:500;
  color:var(--c-accent);
  line-height:1;
}
.service-detail__title{
  font-family:var(--f-display);
  font-weight:500;
  font-size:clamp(1.8rem, 3vw, 2.6rem);
  margin:1rem 0 1.2rem;
  line-height:1.1;
}
.service-detail__lead{
  font-size:1.1rem;
  line-height:1.6;
  color:var(--c-ink-soft);
  margin-bottom:1.5rem;
  max-width:60ch;
}
.service-detail__list{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:.8rem;
  margin-top:1.5rem;
}
.service-detail__list li{
  position:relative;
  padding:.9rem 1rem .9rem 2.5rem;
  background:rgba(232,128,26,.05);
  border-radius:var(--radius);
  color:var(--c-ink);
  font-weight:500;
  font-size:.95rem;
}
.service-detail__list li::before{
  content:"✓";
  position:absolute; left:1rem; top:.85rem;
  color:var(--c-accent);
  font-weight:700;
}

/* ============================================================
   30. Active state for nav (multipage)
   ============================================================ */
body[data-page] .nav a[data-page]{ position:relative }

/* ============================================================
   31. BESTANDSWÄRME-SYSTEM® – 12-Schritt-Methodik
   ============================================================ */
.system{
  padding:var(--pad-y) 0;
  background:var(--c-dark);
  color:#F5F1EA;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.system::before{
  content:"";
  position:absolute; inset:-10%; z-index:-1;
  background:
    radial-gradient(circle at 70% 30%, rgba(232,128,26,.18), transparent 50%),
    radial-gradient(circle at 25% 70%, rgba(184,148,92,.12), transparent 55%);
}
.system .section-head{ color:#F5F1EA }
.system .section-head .meta-label{ color:var(--c-accent-2) }
.system .section-head h2{ color:#F5F1EA }
.system .section-head h2 em{ color:var(--c-accent-2) }
.system .section-head p{ color:rgba(245,241,234,.78) }

.system__phases{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:1.25rem;
}
@media (max-width:980px){ .system__phases{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:540px){ .system__phases{ grid-template-columns:1fr } }

.phase{
  background:rgba(245,241,234,.04);
  border:1px solid rgba(245,241,234,.12);
  border-radius:var(--radius-lg);
  padding:1.75rem 1.5rem;
  position:relative;
  transition:border-color var(--t-med), background var(--t-med);
}
.phase:hover{
  border-color:rgba(232,128,26,.4);
  background:rgba(232,128,26,.05);
}
.phase__num{
  font-family:var(--f-display);
  font-style:italic;
  font-size:1rem;
  color:var(--c-accent-2);
  letter-spacing:.05em;
  margin-bottom:.6rem;
}
.phase__title{
  font-family:var(--f-display);
  font-size:1.35rem;
  font-weight:600;
  margin:0 0 1rem;
  color:#F5F1EA;
}
.phase__steps{
  display:flex; flex-direction:column;
  border-top:1px solid rgba(245,241,234,.1);
  padding-top:1rem;
}
.phase__step{
  display:flex; gap:.7rem;
  padding:.55rem 0;
  font-size:.92rem;
  color:rgba(245,241,234,.85);
  align-items:baseline;
  border-bottom:1px solid rgba(245,241,234,.06);
}
.phase__step:last-child{ border-bottom:none }
.phase__step b{
  font-family:var(--f-display);
  font-style:italic;
  font-weight:500;
  font-size:.82rem;
  color:var(--c-accent);
  min-width:22px;
}
.system__claim{
  margin-top:3rem;
  text-align:center;
  font-family:var(--f-display);
  font-style:italic;
  font-size:clamp(1.15rem,1.8vw,1.5rem);
  color:var(--c-accent-2);
}
.system__claim sup{
  font-size:.65em;
  vertical-align:super;
  margin-left:2px;
}

/* ============================================================
   32. PACKAGES – Vier Pakete
   ============================================================ */
.packages{
  padding:var(--pad-y) 0;
  background:var(--c-bg);
}
.packages__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.25rem;
  margin-top:3rem;
}
@media (max-width:1100px){ .packages__grid{ grid-template-columns:repeat(2,1fr) } }
@media (max-width:560px){ .packages__grid{ grid-template-columns:1fr } }

.package{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  padding:2rem 1.75rem 1.75rem;
  display:flex; flex-direction:column;
  position:relative;
  transition:transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
}
.package:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md) }
.package--featured{
  background:var(--c-dark);
  color:#F5F1EA;
  border-color:var(--c-accent);
  box-shadow:0 20px 60px -20px rgba(14,20,25,.3);
}
.package--featured::before{
  content:"Empfohlen";
  position:absolute;
  top:-12px; left:50%;
  transform:translateX(-50%);
  background:var(--c-accent);
  color:#fff;
  font-size:.7rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:.4rem .85rem;
  border-radius:100px;
  white-space:nowrap;
}
.package__eyebrow{
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-accent-deep);
  font-weight:600;
  margin-bottom:.5rem;
}
.package--featured .package__eyebrow{ color:var(--c-accent-2) }
.package__title{
  font-family:var(--f-display);
  font-size:1.7rem;
  font-weight:600;
  margin:0 0 .35rem;
  line-height:1.1;
}
.package__lead{
  font-size:.9rem;
  color:var(--c-ink-soft);
  margin:0 0 1.2rem;
  min-height:2.6em;
}
.package--featured .package__lead{ color:rgba(245,241,234,.7) }
.package__price{
  font-family:var(--f-display);
  font-size:1.25rem;
  font-weight:600;
  padding-bottom:1.25rem;
  border-bottom:1px solid var(--c-line);
  margin-bottom:1.25rem;
}
.package--featured .package__price{ border-bottom-color:rgba(245,241,234,.18) }
.package__price em{ font-style:normal; color:var(--c-accent-deep) }
.package--featured .package__price em{ color:var(--c-accent) }
.package__price small{ font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; opacity:.6; display:block; font-family:var(--f-sans); margin-top:.3rem; font-weight:500 }
.package__items{ flex:1; margin-bottom:1.5rem }
.package__items li{
  position:relative;
  padding:.5rem 0 .5rem 1.6rem;
  font-size:.92rem;
  line-height:1.5;
  border-bottom:1px solid var(--c-line-soft);
}
.package--featured .package__items li{ border-bottom-color:rgba(245,241,234,.08); color:rgba(245,241,234,.85) }
.package__items li:last-child{ border-bottom:none }
.package__items li::before{
  content:"";
  position:absolute; left:0; top:1rem;
  width:8px; height:8px; border-radius:50%;
  background:var(--c-accent);
}
.package .btn{ width:100% }

/* ============================================================
   33. ONLINE-RECHNER
   ============================================================ */
.calc{
  padding:var(--pad-y) 0;
  background:var(--c-bg-2);
}
.calc__layout{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  gap:clamp(2rem, 4vw, 3rem);
  align-items:flex-start;
}
@media (max-width:900px){ .calc__layout{ grid-template-columns:1fr } }

.calc__form{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:clamp(1.5rem, 3vw, 2.5rem);
  box-shadow:var(--shadow-md);
}
.calc__step{
  border-bottom:1px solid var(--c-line);
  padding-bottom:1.75rem;
  margin-bottom:1.75rem;
}
.calc__step:last-of-type{ border-bottom:none; margin-bottom:0; padding-bottom:0 }
.calc__step h3{
  font-family:var(--f-display);
  font-size:1.25rem;
  font-weight:600;
  margin:0 0 1rem;
  display:flex; align-items:center; gap:.8rem;
}
.calc__step h3 span{
  display:inline-grid; place-items:center;
  width:32px; height:32px;
  font-family:var(--f-display);
  font-style:italic;
  font-size:1rem;
  color:#fff;
  background:var(--c-accent);
  border-radius:50%;
}

.calc__inputs{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:1rem;
}
@media (max-width:480px){ .calc__inputs{ grid-template-columns:1fr } }
.calc__inputs label{
  display:flex; flex-direction:column;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  font-weight:500;
}
.calc__inputs label.full{ grid-column:1 / -1 }
.calc__inputs input,
.calc__inputs select{
  font-family:inherit;
  font-size:1rem;
  letter-spacing:0;
  text-transform:none;
  color:var(--c-ink);
  background:var(--c-bg);
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  padding:.8rem 1rem;
  margin-top:.4rem;
  outline:none;
  transition:border-color var(--t-fast), background var(--t-fast);
}
.calc__inputs input:focus,
.calc__inputs select:focus{
  border-color:var(--c-accent);
  background:#fff;
}

.calc__chips{
  display:flex; flex-wrap:wrap; gap:.5rem;
  margin-top:.5rem;
}
.calc__chip{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.55rem 1rem;
  font-size:.86rem;
  font-weight:500;
  background:var(--c-bg);
  border:1px solid var(--c-line);
  border-radius:100px;
  cursor:pointer;
  transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  user-select:none;
  position:relative;
}
.calc__chip:hover{ border-color:var(--c-accent) }
.calc__chip.is-active{ background:var(--c-accent); color:#fff; border-color:var(--c-accent) }
.calc__chip input{ position:absolute; opacity:0; pointer-events:none }

.calc__result{
  position:sticky; top:7rem;
  background:var(--c-dark);
  color:#F5F1EA;
  border-radius:var(--radius-lg);
  padding:clamp(1.75rem, 3vw, 2.5rem);
  box-shadow:var(--shadow-lg);
  isolation:isolate;
  overflow:hidden;
}
.calc__result::before{
  content:"";
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(circle at 70% 20%, rgba(232,128,26,.25), transparent 55%);
}
.calc__result-eyebrow{
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--c-accent-2);
  font-weight:600;
  margin-bottom:.7rem;
}
.calc__result-title{
  font-family:var(--f-display);
  font-size:clamp(1.5rem, 2.6vw, 2rem);
  font-weight:500;
  margin:0 0 .5rem;
  line-height:1.15;
}
.calc__result-sub{
  color:rgba(245,241,234,.7);
  font-size:.9rem;
  margin:0 0 1.6rem;
}
.calc__result-amount{
  font-family:var(--f-display);
  font-size:clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight:500;
  color:#F5F1EA;
  line-height:1.1;
  margin:.4rem 0 .25rem;
  font-variant-numeric:tabular-nums;
}
.calc__result-amount em{ font-style:italic; color:var(--c-accent) }
.calc__result-range{
  font-size:.85rem;
  letter-spacing:.08em;
  color:rgba(245,241,234,.6);
  text-transform:uppercase;
  margin-bottom:1.75rem;
}
.calc__result-breakdown{
  display:flex; flex-direction:column;
  margin-bottom:1.75rem;
  padding-top:1.25rem;
  border-top:1px solid rgba(245,241,234,.18);
}
.calc__result-breakdown li{
  display:flex; justify-content:space-between;
  padding:.5rem 0;
  font-size:.88rem;
  color:rgba(245,241,234,.78);
}
.calc__result-breakdown b{ color:#F5F1EA; font-weight:500; font-variant-numeric:tabular-nums }
.calc__result-disclaimer{
  font-size:.72rem;
  letter-spacing:.04em;
  color:rgba(245,241,234,.55);
  line-height:1.5;
  margin:1.25rem 0 0;
}

/* ============================================================
   34. TECHNIK / Voraussetzungen
   ============================================================ */
.tech-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
  gap:1.25rem;
}
.tech-card{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  padding:1.75rem;
  transition:transform var(--t-med), box-shadow var(--t-med);
}
.tech-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md) }
.tech-card h3{
  font-family:var(--f-display);
  font-size:1.3rem;
  font-weight:600;
  margin:0 0 .8rem;
  display:flex; align-items:baseline; gap:.6rem;
}
.tech-card h3 b{
  font-family:var(--f-display);
  font-style:italic;
  font-size:.95rem;
  color:var(--c-accent);
  font-weight:500;
}
.tech-card p{
  color:var(--c-ink-soft);
  font-size:.95rem;
  line-height:1.6;
  margin:0 0 1rem;
}
.tech-card__spec{
  display:flex; justify-content:space-between;
  padding:.6rem 0;
  border-top:1px solid var(--c-line-soft);
  font-size:.86rem;
}
.tech-card__spec b{ font-weight:600 }
.tech-card__spec span{ color:var(--c-ink-soft) }

.tech-warn{
  background:rgba(232,128,26,.06);
  border:1px solid var(--c-accent-deep);
  border-radius:var(--radius-lg);
  padding:1.5rem 1.75rem;
  margin-top:2rem;
  display:flex; gap:1rem;
  align-items:flex-start;
}
.tech-warn svg{ color:var(--c-accent-deep); flex-shrink:0; margin-top:2px }
.tech-warn strong{ display:block; margin-bottom:.3rem; font-size:.95rem }
.tech-warn p{ font-size:.9rem; color:var(--c-ink-soft); margin:0; line-height:1.55 }

/* ============================================================
   35. FAQ-Page – Sidebar Layout
   ============================================================ */
.faq-page{
  display:grid;
  grid-template-columns:1fr 2.2fr;
  gap:clamp(2rem, 5vw, 5rem);
  padding:var(--pad-y) 0;
}
@media (max-width:880px){ .faq-page{ grid-template-columns:1fr } }
.faq-page__nav{
  position:sticky; top:7rem;
  align-self:start;
}
.faq-page__nav h3{
  font-family:var(--f-display);
  font-size:1.4rem;
  font-weight:600;
  margin:0 0 1rem;
}
.faq-page__nav ul{ border-left:1px solid var(--c-line); padding-left:1rem }
.faq-page__nav a{
  display:block;
  padding:.5rem 0;
  font-size:.92rem;
  color:var(--c-ink-soft);
  transition:color var(--t-fast);
}
.faq-page__nav a:hover{ color:var(--c-accent-deep) }
.faq-page__group{ margin-bottom:3rem }
.faq-page__group h2{
  font-family:var(--f-display);
  font-size:1.7rem;
  font-weight:600;
  margin:0 0 1.5rem;
  padding-bottom:.6rem;
  border-bottom:2px solid var(--c-line);
}

/* ============================================================
   36. PARTNER-Section
   ============================================================ */
.partner-benefits{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1rem;
  margin-top:2rem;
}
.partner-benefit{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  padding:1.5rem;
}
.partner-benefit h3{
  font-family:var(--f-display);
  font-size:1.2rem;
  font-weight:600;
  margin:0 0 .5rem;
}
.partner-benefit p{ font-size:.93rem; color:var(--c-ink-soft); margin:0; line-height:1.55 }

/* ============================================================
   37. Wizard / Checkliste im Kontaktformular
   ============================================================ */
.wizard{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.wizard__bar{
  display:flex; align-items:center; flex-wrap:wrap;
  background:var(--c-bg-2);
  padding:1rem 1.25rem;
  font-size:.74rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  border-bottom:1px solid var(--c-line);
  gap:.7rem;
}
.wizard__bar b{ color:var(--c-accent-deep); font-weight:600 }
.wizard__step{
  padding:1.75rem clamp(1.25rem, 3vw, 2.5rem);
  border-bottom:1px solid var(--c-line);
}
.wizard__step:last-child{ border-bottom:none }
.wizard__step h3{
  font-family:var(--f-display);
  font-size:1.3rem;
  font-weight:600;
  margin:0 0 .4rem;
  display:flex; align-items:baseline; gap:.6rem;
}
.wizard__step h3 b{
  font-family:var(--f-display);
  font-style:italic;
  font-size:.85rem;
  color:var(--c-accent);
}
.wizard__step > p{ color:var(--c-ink-soft); font-size:.92rem; margin:0 0 1.25rem }
.wizard__chips{
  display:flex; flex-wrap:wrap; gap:.5rem;
}
.wizard__chip{
  display:inline-flex; align-items:center;
  padding:.55rem 1rem;
  font-size:.88rem;
  font-weight:500;
  color:var(--c-ink);
  background:var(--c-bg);
  border:1px solid var(--c-line);
  border-radius:100px;
  cursor:pointer;
  transition:background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  user-select:none;
  position:relative;
}
.wizard__chip:hover{ border-color:var(--c-accent) }
.wizard__chip input{ position:absolute; opacity:0; pointer-events:none }
.wizard__chip.is-active,
.wizard__chip:has(input:checked){
  background:var(--c-accent);
  color:#fff;
  border-color:var(--c-accent);
}
.wizard__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}
@media (max-width:520px){ .wizard__grid{ grid-template-columns:1fr } }
.wizard__grid label{
  display:flex; flex-direction:column;
  font-size:.78rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  font-weight:500;
}
.wizard__grid label.full{ grid-column:1 / -1 }
.wizard__grid input,
.wizard__grid select,
.wizard__grid textarea{
  font-family:inherit;
  font-size:1rem;
  letter-spacing:0;
  text-transform:none;
  color:var(--c-ink);
  background:var(--c-bg);
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  padding:.8rem 1rem;
  margin-top:.4rem;
  outline:none;
  transition:border-color var(--t-fast);
}
.wizard__grid textarea{ resize:vertical; min-height:90px }
.wizard__grid input:focus,
.wizard__grid select:focus,
.wizard__grid textarea:focus{ border-color:var(--c-accent) }
.wizard__upload{
  border:2px dashed var(--c-line);
  background:var(--c-bg);
  border-radius:var(--radius);
  padding:2rem;
  text-align:center;
  cursor:pointer;
  transition:border-color var(--t-fast), background var(--t-fast);
}
.wizard__upload:hover{ border-color:var(--c-accent); background:rgba(232,128,26,.04) }
.wizard__upload svg{ color:var(--c-accent); margin-bottom:.8rem }
.wizard__upload b{ display:block; font-weight:600; margin-bottom:.3rem }
.wizard__upload span{ font-size:.85rem; color:var(--c-ink-soft) }
.wizard__submit{
  padding:1.75rem clamp(1.25rem, 3vw, 2.5rem);
  background:var(--c-bg-2);
  display:flex; flex-direction:column; gap:1rem;
}
.wizard__submit .checkbox{
  display:flex; gap:.7rem;
  align-items:flex-start;
  font-size:.85rem;
  color:var(--c-ink-soft);
}
.wizard__submit .checkbox input{ margin-top:3px; accent-color:var(--c-accent) }
.wizard__submit .checkbox a{ color:var(--c-accent-deep); text-decoration:underline }

/* ============================================================
   38. USP / Differenzierung – Was uns unterscheidet
   ============================================================ */
.usp{
  padding:var(--pad-y) 0;
  background:var(--c-bg-2);
  position:relative;
}
.usp__grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1.5rem;
  margin-top:3rem;
}
@media (max-width:820px){ .usp__grid{ grid-template-columns:1fr } }
.usp-card{
  background:var(--c-bg);
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  padding:2.25rem;
  display:grid;
  grid-template-columns:60px 1fr;
  gap:1.5rem;
  align-items:start;
  transition:transform var(--t-med), box-shadow var(--t-med), border-color var(--t-med);
}
.usp-card--wide{ grid-column:1 / -1 }
.usp-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--c-accent);
}
.usp-card__num{
  font-family:var(--f-display);
  font-style:italic;
  font-size:2.5rem;
  font-weight:500;
  color:var(--c-accent);
  line-height:1;
  padding-top:.3rem;
}
.usp-card__body h3{
  font-family:var(--f-display);
  font-size:1.4rem;
  font-weight:600;
  margin:0 0 .7rem;
  line-height:1.2;
}
.usp-card__body h3 em{ font-style:italic; color:var(--c-accent-deep) }
.usp-card__body p{
  color:var(--c-ink-soft);
  font-size:.98rem;
  line-height:1.6;
  margin:0 0 1rem;
}
.usp-card__body p:last-child{ margin-bottom:0 }
.usp-card__contrast{
  display:flex; gap:1rem;
  padding-top:1rem;
  margin-top:1rem;
  border-top:1px solid var(--c-line);
}
.usp-card__contrast div{
  flex:1;
  padding:.75rem 1rem;
  border-radius:var(--radius);
  font-size:.82rem;
  line-height:1.4;
}
.usp-card__contrast .contrast-neg{
  background:rgba(14,20,25,.04);
  color:var(--c-ink-soft);
  position:relative;
  padding-left:2rem;
}
.usp-card__contrast .contrast-neg::before{
  content:"×";
  position:absolute; left:.7rem; top:.65rem;
  color:#9C7860;
  font-size:1.1rem;
  font-weight:700;
}
.usp-card__contrast .contrast-pos{
  background:rgba(232,128,26,.08);
  color:var(--c-ink);
  font-weight:500;
  position:relative;
  padding-left:2rem;
}
.usp-card__contrast .contrast-pos::before{
  content:"✓";
  position:absolute; left:.7rem; top:.6rem;
  color:var(--c-accent);
  font-size:1rem;
  font-weight:700;
}
@media (max-width:520px){
  .usp-card{ grid-template-columns:1fr; gap:.75rem }
  .usp-card__num{ font-size:1.8rem }
  .usp-card__contrast{ flex-direction:column; gap:.5rem }
}

/* ============================================================
   39. PIONIER-PROGRAMM (Referenzen-Seite)
   ============================================================ */
.pionier{
  padding:var(--pad-y) 0;
  background:var(--c-dark);
  color:#F5F1EA;
  position:relative;
  overflow:hidden;
  isolation:isolate;
}
.pionier::before{
  content:"";
  position:absolute; inset:-10%; z-index:-1;
  background:
    radial-gradient(circle at 70% 30%, rgba(232,128,26,.2), transparent 55%),
    radial-gradient(circle at 25% 70%, rgba(184,148,92,.13), transparent 55%);
}
.pionier .section-head h2{ color:#F5F1EA }
.pionier .section-head h2 em{ color:var(--c-accent-2) }
.pionier .section-head .meta-label{ color:var(--c-accent-2) }
.pionier .section-head p{ color:rgba(245,241,234,.78) }

.pionier__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:clamp(2rem, 5vw, 4rem);
  align-items:flex-start;
}
@media (max-width:820px){ .pionier__grid{ grid-template-columns:1fr } }

.pionier__perks{
  display:flex; flex-direction:column;
  gap:1rem;
}
.pionier__perk{
  padding:1.5rem;
  background:rgba(245,241,234,.05);
  border:1px solid rgba(245,241,234,.12);
  border-radius:var(--radius-lg);
  display:grid;
  grid-template-columns: 40px 1fr;
  gap:1.25rem;
  align-items:start;
  transition:border-color var(--t-med), background var(--t-med);
}
.pionier__perk:hover{
  border-color:rgba(232,128,26,.4);
  background:rgba(232,128,26,.04);
}
.pionier__perk-num{
  font-family:var(--f-display);
  font-style:italic;
  font-size:1.4rem;
  color:var(--c-accent-2);
  line-height:1;
}
.pionier__perk h3{
  font-family:var(--f-display);
  font-size:1.15rem;
  font-weight:600;
  margin:0 0 .35rem;
  color:#F5F1EA;
}
.pionier__perk p{
  margin:0;
  color:rgba(245,241,234,.75);
  font-size:.92rem;
  line-height:1.55;
}

.pionier__spot{
  padding:2rem;
  background:linear-gradient(135deg, rgba(232,128,26,.15) 0%, rgba(232,128,26,.05) 100%);
  border:1px solid rgba(232,128,26,.35);
  border-radius:var(--radius-lg);
  margin-bottom:1.5rem;
}
.pionier__spot-eyebrow{
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--c-accent-2);
  font-weight:600;
  margin-bottom:.7rem;
}
.pionier__spot-count{
  font-family:var(--f-display);
  font-size:clamp(2.5rem, 5vw, 3.75rem);
  font-weight:500;
  color:#F5F1EA;
  line-height:1;
  margin-bottom:.4rem;
}
.pionier__spot-count em{ color:var(--c-accent); font-style:italic }
.pionier__spot-desc{
  font-size:1rem;
  color:rgba(245,241,234,.85);
  line-height:1.55;
  margin:0;
}

/* ============================================================
   40. Ehrlichkeits-Note / Manifest-Statement
   ============================================================ */
.manifest-quote{
  background:var(--c-bg);
  padding:var(--pad-y) 0;
}
.manifest-quote__body{
  max-width:900px;
  margin-inline:auto;
  text-align:center;
}
.manifest-quote__eyebrow{
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-accent-deep);
  font-weight:600;
  margin-bottom:2rem;
}
.manifest-quote blockquote{
  margin:0;
  font-family:var(--f-display);
  font-style:italic;
  font-weight:500;
  font-size:clamp(1.4rem, 2.6vw, 2rem);
  line-height:1.35;
  color:var(--c-ink);
  letter-spacing:-.005em;
}
.manifest-quote blockquote::before{
  content:"„";
  display:inline-block;
  font-size:2.5em;
  line-height:0;
  vertical-align:-0.35em;
  color:var(--c-accent);
  margin-right:.15em;
  font-weight:600;
}
.manifest-quote blockquote::after{
  content:"" ""; opacity:0;
}
.manifest-quote cite{
  display:block;
  margin-top:2rem;
  font-style:normal;
  font-size:.85rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-ink-soft);
  font-weight:500;
}
.manifest-quote cite b{
  display:block;
  font-family:var(--f-display);
  font-size:1rem;
  color:var(--c-ink);
  letter-spacing:0;
  text-transform:none;
  font-weight:600;
  margin-bottom:.2rem;
}


/* ============================================================
   41. LEISTUNGSMATRIX – Wer macht was (Paket-Abgrenzung)
   ============================================================ */
.matrix{
  overflow-x:auto;
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
}
.matrix table{
  width:100%;
  border-collapse:collapse;
  min-width:680px;
  font-size:.92rem;
}
.matrix th,
.matrix td{
  padding:.85rem 1.1rem;
  text-align:center;
  border-bottom:1px solid var(--c-line-soft);
}
.matrix th:first-child,
.matrix td:first-child{ text-align:left }
.matrix thead th{
  font-family:var(--f-display);
  font-size:1.05rem;
  font-weight:600;
  background:var(--c-dark);
  color:#F5F1EA;
}
.matrix thead th:nth-child(3){ color:var(--c-accent) }
.matrix tbody tr:hover{ background:rgba(232,128,26,.04) }
.matrix__group td{
  font-family:var(--f-sans);
  font-size:.72rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--c-accent-deep);
  background:var(--c-bg-2);
  text-align:left;
}
.matrix td em{ font-style:italic; color:var(--c-ink-soft); font-size:.82em }
.matrix__legend{
  margin-top:1.25rem;
  font-size:.82rem;
  color:var(--c-ink-soft);
  line-height:1.7;
}
.matrix__legend b{ color:var(--c-accent-deep) }

/* Auftragsende-Zeile in den Paketkarten */
.package__scope{
  font-size:.82rem;
  line-height:1.55;
  color:var(--c-ink-soft);
  border-top:1px dashed var(--c-line);
  padding-top:1rem;
  margin:0 0 1.25rem;
}
.package__scope b{ color:var(--c-ink); font-weight:600 }
.package--featured .package__scope{
  color:rgba(245,241,234,.7);
  border-top-color:rgba(245,241,234,.2);
}
.package--featured .package__scope b{ color:#F5F1EA }
