/* ============================================
   HdV — Handwerker des Vertrauens · Rebuild 2026
   Stack: Vanilla CSS · Mobile-First · A11y-Heavy
   ============================================ */

:root{
  /* Primary palette — Soft Blue / Trust */
  --brand-50:#eef9fc;
  --brand-100:#d4f0f6;
  --brand-200:#a9e1ed;
  --brand-300:#6fcfe0;
  --brand-400:#2bb3cb;
  --brand-500:#0d96b0;
  --brand-600:#077590;
  --brand-700:#085c72;
  --brand-800:#0a4858;
  --brand-900:#0a2f3a;

  /* Accent — Warm Amber for CTAs */
  --accent-400:#f7b955;
  --accent-500:#e89c2b;
  --accent-600:#c47e15;

  /* Neutrals */
  --ink:#0e1822;
  --ink-soft:#3a4a5b;
  --muted:#6a7989;
  --line:#dfe6ee;
  --line-soft:#eef3f8;
  --bg:#ffffff;
  --bg-tint:#f6f9fc;
  --bg-deep:#0a2f3a;

  /* Semantic */
  --ok:#1f9d5b;
  --warn:#d9831f;

  /* Type scale (mobile-first) */
  --fs-display:clamp(2.1rem, 5.5vw + 1rem, 4.2rem);
  --fs-h1:clamp(1.75rem, 4vw + 0.5rem, 3.0rem);
  --fs-h2:clamp(1.5rem, 2.5vw + 0.8rem, 2.25rem);
  --fs-h3:clamp(1.2rem, 1.5vw + 0.7rem, 1.5rem);
  --fs-lead:clamp(1.06rem, 0.5vw + 0.95rem, 1.25rem);
  --fs-body:1.0625rem; /* 17px mobile body */
  --fs-small:0.95rem;

  /* Spacing */
  --gap-3xs:.25rem;
  --gap-2xs:.5rem;
  --gap-xs:.75rem;
  --gap-s:1rem;
  --gap-m:1.5rem;
  --gap-l:2.25rem;
  --gap-xl:3.5rem;
  --gap-2xl:5.5rem;

  /* Radius / Shadow */
  --r-s:8px;
  --r-m:14px;
  --r-l:22px;
  --r-pill:999px;
  --shadow-1:0 1px 2px rgba(10,47,58,.06), 0 1px 3px rgba(10,47,58,.08);
  --shadow-2:0 6px 18px rgba(10,47,58,.08), 0 2px 4px rgba(10,47,58,.05);
  --shadow-3:0 20px 60px -20px rgba(10,47,58,.18), 0 8px 20px -10px rgba(10,47,58,.12);

  /* Layout */
  --container:1180px;
  --container-narrow:880px;
  --header-h:72px;

  /* Motion */
  --t-fast:.18s ease-out;
  --t-base:.28s ease-out;
  --t-slow:.55s cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  font-size:var(--fs-body);
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
@media (min-width:760px){body{font-size:1.125rem}}

h1,h2,h3,h4{
  font-family:'Manrope','Inter',system-ui,sans-serif;
  font-weight:700;
  line-height:1.18;
  color:var(--ink);
  letter-spacing:-0.015em;
  margin:0 0 var(--gap-s);
}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{margin:0 0 var(--gap-s)}
p:last-child{margin-bottom:0}
a{color:var(--brand-600);text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--brand-700)}
img{max-width:100%;height:auto;display:block}

/* Focus ring (visible, accessible) */
:focus{outline:none}
:focus-visible{
  outline:3px solid var(--brand-400);
  outline-offset:3px;
  border-radius:6px;
}

/* Skip-link */
.skip-link{
  position:absolute;left:-9999px;top:-9999px;
  background:var(--ink);color:#fff;padding:.85rem 1.25rem;
  border-radius:var(--r-s);font-weight:600;z-index:9999;
}
.skip-link:focus{left:1rem;top:1rem}

/* Container helpers */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gap-s);
}
.container--narrow{max-width:var(--container-narrow)}
@media (min-width:760px){.container{padding-inline:var(--gap-l)}}

/* Section spacing */
.section{padding-block:var(--gap-xl)}
.section--lg{padding-block:var(--gap-2xl)}
.section--tint{background:var(--bg-tint)}
.section--deep{background:var(--bg-deep);color:#dfeaef}
.section--deep h1,.section--deep h2,.section--deep h3{color:#fff}
.section--deep a{color:var(--brand-200)}

/* ============================================
   HEADER
   ============================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(10px);
  -webkit-backdrop-filter:saturate(180%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);gap:var(--gap-m);
}
.brand-mark{
  display:flex;align-items:center;gap:.7rem;
  text-decoration:none;color:var(--ink);
  font-family:'Manrope',sans-serif;font-weight:800;
  letter-spacing:-0.01em;
}
.brand-mark__logo{
  width:42px;height:42px;border-radius:10px;
  background:linear-gradient(135deg,var(--brand-500),var(--brand-700));
  color:#fff;display:grid;place-items:center;
  font-weight:800;letter-spacing:-.5px;font-size:1.05rem;
  box-shadow:var(--shadow-1);
}
.brand-mark__text{font-size:1.05rem;line-height:1.15}
.brand-mark__text small{
  display:block;font-weight:500;color:var(--muted);
  font-size:.72rem;letter-spacing:.01em;text-transform:uppercase;
}

.nav-primary{display:none}
.nav-primary ul{
  list-style:none;display:flex;gap:.25rem;margin:0;padding:0;
}
.nav-primary a{
  display:inline-block;padding:.6rem .9rem;
  font-weight:500;color:var(--ink-soft);
  text-decoration:none;border-radius:var(--r-s);
  transition:background var(--t-fast),color var(--t-fast);
}
.nav-primary a:hover,.nav-primary a[aria-current="page"]{
  background:var(--bg-tint);color:var(--brand-700);
}
.header-cta{display:none;align-items:center;gap:.7rem}
@media (min-width:1000px){
  .nav-primary{display:block}
  .header-cta{display:inline-flex}
}

/* Mobile menu */
.menu-toggle{
  appearance:none;background:transparent;border:1px solid var(--line);
  padding:.55rem .85rem;border-radius:var(--r-s);
  font-weight:600;font-size:.95rem;cursor:pointer;
  display:inline-flex;align-items:center;gap:.45rem;
  min-height:44px;
}
@media (min-width:1000px){.menu-toggle{display:none}}
.menu-toggle__icon{width:18px;height:14px;position:relative;display:inline-block}
.menu-toggle__icon::before,.menu-toggle__icon::after,.menu-toggle__icon span{
  content:"";position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:2px;
  transition:transform var(--t-fast),top var(--t-fast),opacity var(--t-fast);
}
.menu-toggle__icon::before{top:0}
.menu-toggle__icon span{top:6px}
.menu-toggle__icon::after{top:12px}
.menu-toggle[aria-expanded="true"] .menu-toggle__icon::before{top:6px;transform:rotate(45deg)}
.menu-toggle[aria-expanded="true"] .menu-toggle__icon::after{top:6px;transform:rotate(-45deg)}
.menu-toggle[aria-expanded="true"] .menu-toggle__icon span{opacity:0}

.mobile-drawer{
  position:fixed;inset:var(--header-h) 0 0 0;z-index:40;
  background:#fff;
  transform:translateX(100%);transition:transform var(--t-base);
  display:flex;flex-direction:column;
  overflow-y:auto;
}
.mobile-drawer[data-open="true"]{transform:translateX(0)}
.mobile-drawer ul{list-style:none;margin:0;padding:var(--gap-m)}
.mobile-drawer a{
  display:block;padding:1rem 1.1rem;font-size:1.1rem;font-weight:600;
  color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line-soft);
  min-height:48px;
}
.mobile-drawer a:hover{color:var(--brand-600)}
.mobile-drawer__cta{padding:var(--gap-m)}
@media (min-width:1000px){.mobile-drawer{display:none}}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;padding:.95rem 1.4rem;
  font-weight:600;font-size:1rem;letter-spacing:-0.005em;
  border-radius:var(--r-pill);
  border:1px solid transparent;
  text-decoration:none;cursor:pointer;
  transition:transform var(--t-fast),background var(--t-fast),box-shadow var(--t-fast),color var(--t-fast),border-color var(--t-fast);
  min-height:48px;line-height:1.1;
}
.btn:active{transform:translateY(1px)}
.btn--primary{
  background:var(--brand-600);color:#fff;
  box-shadow:0 2px 0 var(--brand-800),var(--shadow-1);
}
.btn--primary:hover{background:var(--brand-700);color:#fff;box-shadow:0 4px 0 var(--brand-800),var(--shadow-2)}
.btn--accent{
  background:var(--accent-500);color:#1a1206;
  box-shadow:0 2px 0 var(--accent-600),var(--shadow-1);
}
.btn--accent:hover{background:var(--accent-400);color:#1a1206}
.btn--ghost{
  background:transparent;color:var(--brand-700);border-color:var(--brand-300);
}
.btn--ghost:hover{background:var(--brand-50);color:var(--brand-800)}
.btn--block{display:flex;width:100%}
.btn__arrow{transition:transform var(--t-fast)}
.btn:hover .btn__arrow{transform:translateX(3px)}

/* ============================================
   HERO
   ============================================ */
.hero{
  position:relative;
  background:radial-gradient(circle at 75% 20%,var(--brand-100),transparent 55%),
             linear-gradient(180deg,var(--bg) 0%,var(--bg-tint) 100%);
  padding-block:var(--gap-xl) var(--gap-2xl);
  overflow:hidden;
}
.hero__grid{
  display:grid;gap:var(--gap-l);
  grid-template-columns:1fr;align-items:center;
}
@media (min-width:980px){
  .hero__grid{grid-template-columns:1.1fr .9fr;gap:var(--gap-xl)}
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  background:#fff;color:var(--brand-700);
  padding:.45rem .9rem;border-radius:var(--r-pill);
  font-size:.85rem;font-weight:600;letter-spacing:.01em;
  border:1px solid var(--brand-100);
  box-shadow:var(--shadow-1);
  margin-bottom:var(--gap-s);
}
.hero__eyebrow .dot{
  width:8px;height:8px;border-radius:99px;background:var(--ok);
  box-shadow:0 0 0 3px rgba(31,157,91,.18);
}
.hero h1{font-size:var(--fs-display);line-height:1.06;letter-spacing:-.025em;margin-bottom:var(--gap-m)}
.hero h1 em{font-style:normal;color:var(--brand-600);position:relative;display:inline-block}
.hero h1 em::after{
  content:"";position:absolute;left:0;right:0;bottom:.08em;height:.32em;
  background:linear-gradient(90deg,var(--brand-100),var(--accent-400));
  border-radius:99px;opacity:.55;z-index:-1;
}
.hero__lead{
  font-size:var(--fs-lead);color:var(--ink-soft);
  max-width:42ch;margin-bottom:var(--gap-l);
}
.hero__ctas{display:flex;flex-wrap:wrap;gap:var(--gap-s);margin-bottom:var(--gap-l)}
.hero__trust{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:var(--gap-m) var(--gap-l);
  padding-top:var(--gap-m);border-top:1px solid var(--line);
  font-size:var(--fs-small);color:var(--muted);
}
.hero__trust strong{color:var(--ink);display:block;font-size:1.2rem;line-height:1}
.hero__trust-item{display:flex;flex-direction:column;gap:.15rem;min-width:0}

/* Hero card-stack (right side) */
.hero__visual{
  position:relative;min-height:380px;
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;
  gap:var(--gap-s);
}
.hero-card{
  background:#fff;border-radius:var(--r-l);
  padding:1.2rem;box-shadow:var(--shadow-3);
  border:1px solid var(--line-soft);
  position:relative;overflow:hidden;
}
.hero-card__icon{
  width:42px;height:42px;border-radius:12px;
  background:var(--brand-50);color:var(--brand-600);
  display:grid;place-items:center;margin-bottom:.65rem;
  font-size:1.35rem;
}
.hero-card__title{font-weight:700;color:var(--ink);font-size:1rem;margin-bottom:.25rem}
.hero-card__desc{font-size:.85rem;color:var(--muted);margin:0;line-height:1.45}
.hero-card--feature{
  grid-column:span 2;
  background:linear-gradient(135deg,var(--brand-700),var(--brand-900));
  color:#dfeaef;border:none;
}
.hero-card--feature .hero-card__title{color:#fff;font-size:1.05rem}
.hero-card--feature .hero-card__desc{color:rgba(255,255,255,.78)}
.hero-card--feature .hero-card__icon{background:rgba(255,255,255,.12);color:#fff}
.hero-card__metric{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:2.5rem;line-height:1;letter-spacing:-.03em;
  color:#fff;margin:.4rem 0 .2rem;
}

/* ============================================
   3-STEP / STEP PROCESS
   ============================================ */
.steps{
  display:grid;gap:var(--gap-m);
  grid-template-columns:1fr;
  counter-reset:step;
}
@media (min-width:760px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{
  position:relative;background:#fff;
  padding:1.6rem 1.4rem;border-radius:var(--r-l);
  border:1px solid var(--line);
  counter-increment:step;
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--brand-200)}
.step::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;top:1.1rem;right:1.1rem;
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:2.6rem;line-height:1;
  color:var(--brand-100);letter-spacing:-.04em;
  pointer-events:none;
}
.step h3{margin-bottom:.5rem;padding-right:3rem}
.step p{color:var(--ink-soft);font-size:.98rem}

/* ============================================
   AUDIENCE / SERVICE CARDS
   ============================================ */
.audience-grid{
  display:grid;gap:var(--gap-m);
  grid-template-columns:1fr;
}
@media (min-width:760px){.audience-grid{grid-template-columns:repeat(3,1fr)}}
.audience-card{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-l);padding:1.7rem 1.4rem;
  display:flex;flex-direction:column;gap:.7rem;
  text-decoration:none;color:inherit;
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
  min-height:230px;
}
.audience-card:hover{
  transform:translateY(-4px);border-color:var(--brand-300);
  box-shadow:var(--shadow-2);
}
.audience-card__icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg,var(--brand-50),var(--brand-100));
  color:var(--brand-700);display:grid;place-items:center;
  font-size:1.6rem;margin-bottom:.3rem;
}
.audience-card h3{margin-bottom:0}
.audience-card p{color:var(--ink-soft);flex:1}
.audience-card__cta{
  margin-top:.4rem;font-weight:600;color:var(--brand-600);
  display:inline-flex;align-items:center;gap:.35rem;
}
.audience-card:hover .audience-card__cta{color:var(--brand-700)}

/* ============================================
   MEMBER CARDS (Verzeichnis)
   ============================================ */
.member-filters{
  display:flex;flex-wrap:wrap;gap:.55rem;
  padding:1rem;background:var(--bg-tint);
  border-radius:var(--r-m);margin-bottom:var(--gap-m);
  border:1px solid var(--line-soft);
}
.member-filter{
  appearance:none;cursor:pointer;
  padding:.55rem 1.05rem;border-radius:var(--r-pill);
  border:1px solid var(--line);background:#fff;
  font-size:.92rem;font-weight:500;color:var(--ink-soft);
  transition:all var(--t-fast);
  min-height:40px;
}
.member-filter:hover{border-color:var(--brand-300);color:var(--brand-700)}
.member-filter[aria-pressed="true"]{
  background:var(--brand-600);color:#fff;border-color:var(--brand-600);
}

.member-grid{
  display:grid;gap:var(--gap-m);
  grid-template-columns:1fr;
}
@media (min-width:680px){.member-grid{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.member-grid{grid-template-columns:repeat(3,1fr)}}
.member-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-l);
  padding:1.5rem 1.3rem;display:flex;flex-direction:column;gap:.6rem;
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
}
.member-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2);border-color:var(--brand-200)}
.member-card__head{display:flex;align-items:center;justify-content:space-between;gap:.6rem;margin-bottom:.25rem}
.member-card__badge{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.75rem;font-weight:600;padding:.3rem .7rem;
  border-radius:var(--r-pill);
  background:var(--brand-50);color:var(--brand-700);
  text-transform:uppercase;letter-spacing:.04em;
}
.member-card__icon{
  width:52px;height:52px;border-radius:12px;
  background:linear-gradient(135deg,var(--brand-50),var(--brand-200));
  color:var(--brand-700);display:grid;place-items:center;font-size:1.4rem;
}
.member-card h3{margin-bottom:.25rem;font-size:1.18rem}
.member-card__meta{
  display:flex;flex-wrap:wrap;gap:.4rem .9rem;
  font-size:.86rem;color:var(--muted);margin-top:.35rem;
}
.member-card__meta span{display:inline-flex;align-items:center;gap:.3rem}
.member-card__desc{font-size:.95rem;color:var(--ink-soft);margin:.4rem 0}
.member-card__footer{
  margin-top:.6rem;padding-top:.85rem;border-top:1px solid var(--line-soft);
  display:flex;align-items:center;justify-content:space-between;
  font-size:.88rem;color:var(--muted);
}
.member-card[hidden]{display:none}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonials{
  display:grid;gap:var(--gap-m);
  grid-template-columns:1fr;
}
@media (min-width:760px){.testimonials{grid-template-columns:repeat(2,1fr)}}
@media (min-width:1000px){.testimonials{grid-template-columns:repeat(3,1fr)}}
.testimonial{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-l);padding:1.6rem 1.4rem;
  display:flex;flex-direction:column;gap:.8rem;
  position:relative;overflow:hidden;
}
.testimonial::before{
  content:"\201C";
  position:absolute;top:-1rem;right:1rem;
  font-family:Georgia,serif;font-size:6rem;line-height:1;
  color:var(--brand-100);pointer-events:none;
}
.testimonial p{font-size:.98rem;color:var(--ink);flex:1;line-height:1.55}
.testimonial__author{
  display:flex;align-items:center;gap:.7rem;margin-top:auto;
  padding-top:.85rem;border-top:1px solid var(--line-soft);
}
.testimonial__avatar{
  width:42px;height:42px;border-radius:99px;flex-shrink:0;
  background:linear-gradient(135deg,var(--brand-300),var(--brand-600));
  color:#fff;display:grid;place-items:center;
  font-weight:700;font-size:.95rem;
}
.testimonial__name{font-weight:600;color:var(--ink);font-size:.92rem;line-height:1.2}
.testimonial__role{font-size:.82rem;color:var(--muted);line-height:1.3;display:block}

/* ============================================
   FAQ (Akkordeon)
   ============================================ */
.faq-group{display:flex;flex-direction:column;gap:var(--gap-2xs)}
.faq-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-m);
  overflow:hidden;transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.faq-item[open]{border-color:var(--brand-300);box-shadow:var(--shadow-1)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:1.05rem 1.2rem;
  font-weight:600;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  min-height:54px;font-size:1.02rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--brand-700)}
.faq-item summary::after{
  content:"+";font-family:'Manrope',sans-serif;
  font-size:1.6rem;line-height:1;font-weight:400;
  color:var(--brand-600);transition:transform var(--t-base);
}
.faq-item[open] summary::after{content:"\2013"}
.faq-item__body{padding:0 1.2rem 1.2rem;color:var(--ink-soft);font-size:.98rem}
.faq-item__body p{margin-bottom:.6rem}

/* ============================================
   STATS / TRUST STRIP
   ============================================ */
.stats{
  display:grid;gap:var(--gap-m);
  grid-template-columns:repeat(2,1fr);
}
@media (min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{
  text-align:center;padding:var(--gap-s);
}
.stat__value{
  font-family:'Manrope',sans-serif;font-weight:800;
  font-size:clamp(2.2rem,4vw,2.8rem);line-height:1;
  letter-spacing:-.03em;color:var(--brand-600);
  display:block;margin-bottom:.35rem;
}
.section--deep .stat__value{
  color:#fff;background:linear-gradient(180deg,#fff,var(--brand-200));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.stat__label{
  font-size:.9rem;color:var(--muted);
  text-transform:uppercase;letter-spacing:.04em;font-weight:500;
}
.section--deep .stat__label{color:rgba(255,255,255,.7)}

/* ============================================
   FEATURE LIST (with checkmarks)
   ============================================ */
.feature-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}
.feature-list li{
  display:flex;align-items:flex-start;gap:.75rem;
  padding-left:0;font-size:1.02rem;color:var(--ink-soft);
}
.feature-list li::before{
  content:"";flex-shrink:0;
  width:22px;height:22px;border-radius:99px;
  background:var(--brand-50);color:var(--brand-700);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23077590' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat:no-repeat;background-size:14px;background-position:center;
  margin-top:.18em;
}
.feature-list--inverse li{color:rgba(255,255,255,.85)}
.feature-list--inverse li::before{
  background:rgba(255,255,255,.12);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23a9e1ed' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");
  background-repeat:no-repeat;background-size:14px;background-position:center;
}

/* ============================================
   CTA-BANNER
   ============================================ */
.cta-banner{
  background:linear-gradient(135deg,var(--brand-700) 0%,var(--brand-900) 100%);
  color:#fff;border-radius:var(--r-l);
  padding:2.3rem 1.6rem;text-align:center;
  position:relative;overflow:hidden;
}
.cta-banner::before,.cta-banner::after{
  content:"";position:absolute;border-radius:99px;pointer-events:none;
}
.cta-banner::before{
  width:340px;height:340px;left:-100px;top:-100px;
  background:radial-gradient(circle,var(--brand-500),transparent 70%);opacity:.4;
}
.cta-banner::after{
  width:280px;height:280px;right:-80px;bottom:-80px;
  background:radial-gradient(circle,var(--accent-500),transparent 70%);opacity:.25;
}
.cta-banner > *{position:relative}
.cta-banner h2{color:#fff;margin-bottom:.7rem;font-size:clamp(1.4rem,2.5vw,2rem)}
.cta-banner p{color:rgba(255,255,255,.85);max-width:48ch;margin:0 auto var(--gap-m)}
.cta-banner .btn{margin:.3rem}

/* ============================================
   CONTACT
   ============================================ */
.contact-grid{
  display:grid;gap:var(--gap-l);
  grid-template-columns:1fr;
}
@media (min-width:880px){.contact-grid{grid-template-columns:1.2fr 1fr}}
.contact-info{
  background:var(--bg-tint);border-radius:var(--r-l);
  padding:1.8rem;border:1px solid var(--line-soft);
}
.contact-info h3{margin-bottom:1rem}
.contact-info__row{
  display:flex;align-items:flex-start;gap:.85rem;
  padding:.95rem 0;border-bottom:1px solid var(--line);
}
.contact-info__row:last-child{border-bottom:0}
.contact-info__icon{
  width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:#fff;color:var(--brand-600);
  display:grid;place-items:center;font-size:1.15rem;
  box-shadow:var(--shadow-1);
}
.contact-info__label{font-size:.82rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600;display:block;margin-bottom:.2rem}
.contact-info__value{color:var(--ink);font-weight:500;text-decoration:none;font-size:1.05rem}
.contact-info__value:hover{color:var(--brand-700)}

.contact-form{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-l);padding:1.8rem;
}
.form-row{display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:1rem}
@media (min-width:600px){.form-row--2{grid-template-columns:1fr 1fr}}
.form-field label{
  display:block;font-weight:600;color:var(--ink);
  font-size:.92rem;margin-bottom:.4rem;
}
.form-field input,.form-field textarea,.form-field select{
  width:100%;padding:.85rem 1rem;
  border:1px solid var(--line);border-radius:var(--r-s);
  font:inherit;font-size:1rem;color:var(--ink);background:#fff;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
  min-height:48px;
}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{
  border-color:var(--brand-400);
  box-shadow:0 0 0 3px rgba(43,179,203,.18);
  outline:none;
}
.form-field textarea{resize:vertical;min-height:120px}
.form-field__hint{font-size:.82rem;color:var(--muted);margin-top:.3rem}
.form-checkbox{
  display:flex;align-items:flex-start;gap:.6rem;
  font-size:.88rem;color:var(--ink-soft);
  padding:.5rem 0;
}
.form-checkbox input{width:20px;height:20px;margin-top:.15rem;flex-shrink:0}

/* ============================================
   FOOTER
   ============================================ */
.site-footer{
  background:var(--bg-deep);color:rgba(255,255,255,.7);
  padding-block:var(--gap-xl) var(--gap-l);
  font-size:.95rem;
}
.site-footer h4{color:#fff;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.9rem}
.site-footer a{color:rgba(255,255,255,.7);text-decoration:none;transition:color var(--t-fast)}
.site-footer a:hover{color:#fff}
.footer-grid{
  display:grid;gap:var(--gap-l);
  grid-template-columns:1fr;margin-bottom:var(--gap-l);
}
@media (min-width:760px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand p{max-width:30ch;line-height:1.55}
.footer-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.55rem}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding-top:var(--gap-m);
  display:flex;flex-wrap:wrap;gap:.5rem var(--gap-m);
  align-items:center;justify-content:space-between;
  font-size:.85rem;color:rgba(255,255,255,.55);
}
.footer-bottom__links{display:flex;flex-wrap:wrap;gap:1rem}

/* ============================================
   BOTTOM NAV MOBILE
   ============================================ */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:30;
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
  display:flex;align-items:stretch;justify-content:space-around;
  padding:.45rem env(safe-area-inset-right) calc(.45rem + env(safe-area-inset-bottom)) env(safe-area-inset-left);
}
.bottom-nav__item{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.18rem;
  padding:.4rem .25rem;text-decoration:none;color:var(--muted);
  font-size:.7rem;font-weight:600;letter-spacing:.01em;
  min-height:48px;
  transition:color var(--t-fast);
}
.bottom-nav__item[aria-current="page"]{color:var(--brand-600)}
.bottom-nav__item:hover{color:var(--brand-700)}
.bottom-nav__icon{font-size:1.25rem;line-height:1}
@media (min-width:760px){.bottom-nav{display:none}}
@media (max-width:759px){body{padding-bottom:64px}.mobile-drawer{padding-bottom:80px}}

/* ============================================
   UTILITY
   ============================================ */
.eyebrow{
  display:inline-block;
  font-size:.85rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--brand-600);
  margin-bottom:var(--gap-xs);
}
.section-header{margin-bottom:var(--gap-l);max-width:55ch}
.section-header--center{margin-inline:auto;text-align:center}
.section-header p{font-size:var(--fs-lead);color:var(--ink-soft)}

.partner-strip{
  display:flex;flex-wrap:wrap;justify-content:center;align-items:center;
  gap:var(--gap-m) var(--gap-xl);
  padding:var(--gap-m) 0;
  opacity:.7;
}
.partner-strip__item{
  font-family:'Manrope',sans-serif;font-weight:700;
  color:var(--muted);font-size:1.1rem;letter-spacing:-.01em;
}

.badge-row{display:flex;flex-wrap:wrap;gap:.55rem;margin-bottom:var(--gap-s)}
.badge{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--brand-50);color:var(--brand-700);
  padding:.4rem .8rem;border-radius:var(--r-pill);
  font-size:.82rem;font-weight:600;
}
.badge--accent{background:#fff5e6;color:var(--accent-600)}
.badge--dark{background:rgba(255,255,255,.08);color:#fff;backdrop-filter:blur(6px)}

/* Reveal-on-scroll animation — default-visible always. Only pending items animate in. */
.reveal{opacity:1;transform:none;transition:opacity var(--t-slow),transform var(--t-slow)}
.reveal[data-reveal-pending="true"]{opacity:0;transform:translateY(18px)}
.reveal.is-visible{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important;transition:none}
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

/* Page hero (sub-pages) */
.page-hero{
  background:radial-gradient(circle at 80% 20%,var(--brand-100),transparent 60%),
             linear-gradient(180deg,var(--bg) 0%,var(--bg-tint) 100%);
  padding-block:var(--gap-xl);
}
.page-hero h1{font-size:var(--fs-h1)}
.breadcrumbs{
  font-size:.88rem;color:var(--muted);margin-bottom:var(--gap-s);
  display:flex;flex-wrap:wrap;gap:.4rem;align-items:center;
}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--brand-700)}
.breadcrumbs__sep{color:var(--line)}

/* Content block (text-heavy pages) */
.prose{max-width:65ch;color:var(--ink-soft);font-size:1.05rem;line-height:1.7}
.prose h2{margin-top:var(--gap-l);margin-bottom:var(--gap-s);color:var(--ink)}
.prose h3{margin-top:var(--gap-m);margin-bottom:.5rem;color:var(--ink)}
.prose ul,.prose ol{padding-left:1.4rem;margin-bottom:var(--gap-s)}
.prose li{margin-bottom:.4rem}
.prose strong{color:var(--ink)}
.prose a{color:var(--brand-600);text-decoration:underline}

/* Pillars (2-col content cards) */
.pillars{
  display:grid;gap:var(--gap-m);
  grid-template-columns:1fr;
}
@media (min-width:760px){.pillars{grid-template-columns:1fr 1fr}}
.pillar{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-l);
  padding:1.7rem;
}
.pillar__icon{
  width:48px;height:48px;border-radius:12px;
  background:var(--brand-50);color:var(--brand-700);
  display:grid;place-items:center;font-size:1.4rem;margin-bottom:.85rem;
}
.pillar h3{font-size:1.18rem}

/* Map placeholder */
.coverage-map{
  background:linear-gradient(135deg,var(--brand-50),var(--brand-100));
  border-radius:var(--r-l);padding:2rem 1.5rem;
  display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;
  border:1px solid var(--brand-200);
}
.coverage-city{
  background:#fff;color:var(--brand-700);
  padding:.5rem 1rem;border-radius:var(--r-pill);
  font-weight:600;font-size:.92rem;
  border:1px solid var(--brand-200);
  box-shadow:var(--shadow-1);
}

/* ============================================
   IMAGES — Hero, Service Cards, Step Cards
   ============================================ */

/* HERO mit Bild */
.hero--with-image{
  position:relative;
  background:linear-gradient(180deg,var(--bg-tint) 0%,var(--bg) 100%);
}
.hero--with-image .hero__media{
  position:relative;
  border-radius:var(--r-l);
  overflow:hidden;
  box-shadow:var(--shadow-3);
  aspect-ratio:16/9;
}
.hero--with-image .hero__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.hero--with-image .hero__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(10,47,58,.18) 0%,rgba(10,47,58,.0) 60%);
  pointer-events:none;
}

/* Service / Member-Card mit Bild-Header */
.member-card--with-image{
  padding:0;
  overflow:hidden;
}
.member-card--with-image .member-card__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--brand-50);
}
.member-card--with-image .member-card__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
  transition:transform var(--t-slow);
}
.member-card--with-image:hover .member-card__media img{
  transform:scale(1.04);
}
.member-card--with-image .member-card__media::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,47,58,0) 50%,rgba(10,47,58,.55) 100%);
  pointer-events:none;
}
.member-card--with-image .member-card__body{
  padding:1.2rem 1.3rem 1.4rem;
}

/* Step-Card mit Bild-Header */
.step--with-image{
  padding:0;
  overflow:hidden;
}
.step--with-image .step__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--brand-50);
}
.step--with-image .step__media img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}
.step--with-image .step__body{
  padding:1.4rem 1.4rem 1.6rem;
}
.step--with-image::before{
  top:auto;bottom:1rem;right:1.1rem;
  color:#fff;
  text-shadow:0 2px 6px rgba(0,0,0,.4);
}

/* Section-Header Bild (leistungen.html sections) */
.section-image{
  position:relative;
  border-radius:var(--r-l);
  overflow:hidden;
  margin-bottom:var(--gap-m);
  aspect-ratio:21/9;
  box-shadow:var(--shadow-2);
}
.section-image img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.section-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,47,58,0) 50%,rgba(10,47,58,.35) 100%);
  pointer-events:none;
}

/* Image Disclaimer im Footer */
.image-disclaimer{
  font-size:.75rem;
  color:rgba(255,255,255,.5);
  margin-top:.6rem;
  font-style:italic;
  max-width:55ch;
}
