/* ==================================================
   LEUCHTTURM – GLOBALES SECTION- UND ABSTANDSSYSTEM
================================================== */

:root{
  --blue:#0b2c41;
  --blue-deep:#081f2f;
  --gold:#c6a570;
  --gold-soft:#d7bc8f;
  --ink:#233642;
  --muted:#5f6f7a;
  --white:#ffffff;

  --shadow:0 18px 55px rgba(8,31,47,.16);
  --shadow-soft:0 10px 30px rgba(8,31,47,.10);

  --max:1360px;
  --section-max:1180px;
  --shell:clamp(1rem, .4rem + 2vw, 2rem);

  --space-section-y:clamp(3.2rem, 2.4rem + 2vw, 5rem);
  --space-head-bottom:clamp(1.6rem, 1.2rem + .8vw, 2.4rem);
  --space-head-bottom-lg:clamp(2rem, 1.5rem + 1.2vw, 3rem);
  --space-grid-gap:clamp(1.4rem, 1.1rem + .8vw, 2.2rem);
  --space-card-pad:clamp(1.5rem, 1.2rem + .8vw, 2.2rem);
  --space-copy-gap:clamp(.8rem, .7rem + .2vw, 1rem);

  --list-indent:1.15rem;
  --list-offset:.8rem;
  --list-gap:.5rem;
  --list-gap-compact:.38rem;

  --fs-body:clamp(1rem, .96rem + .18vw, 1.1rem);
  --fs-small:clamp(.92rem, .9rem + .12vw, 1rem);
  --fs-h1:clamp(3.1rem, 2.35rem + 4vw, 5.6rem);
  --fs-h2:clamp(1.9rem, 1.35rem + 2vw, 3.35rem);
  --fs-h3:clamp(1.2rem, 1.05rem + .7vw, 1.65rem);
  --fs-sub:clamp(1.35rem, 1.12rem + .85vw, 1.95rem);
  --fs-button:clamp(1rem, .96rem + .16vw, 1.06rem);

  --lh-body:1.65;
  --lh-tight:.95;
  --lh-heading:1.04;

  --radius-xl:28px;
  --radius-lg:22px;
  --radius-md:16px;
}

*,
*::before,
*::after{box-sizing:border-box;}

html{scroll-behavior:smooth;}

body{
  margin:0;
  font-family:"Segoe UI", Inter, Arial, sans-serif;
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  color:var(--ink);
  background:linear-gradient(180deg, #f2eee7 0%, #f9f5ef 100%);
}

h1,h2,h3,p,ul,li,blockquote{margin:0;}
a{text-decoration:none;color:inherit;}
button{font:inherit;}

.container{
  width:min(var(--max), calc(100% - (var(--shell) * 2)));
  margin:0 auto;
}

.section-shell{
  max-width:var(--section-max);
}

/* =========================
   HEADER
========================= */

.site-header{
  position:sticky;
  top:0;
  z-index:70;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(11,44,65,.08);
}

.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1.2rem;
  min-height:64px;
}

.brand{
  display:inline-flex;
  align-items:center;
  min-width:max-content;
}

.brand-mark{
  color:var(--blue);
  font-weight:700;
  letter-spacing:.02em;
}

.top-nav{
  display:flex;
  align-items:center;
  gap:1.15rem;
  flex-wrap:wrap;
}

.top-link{
  color:var(--blue);
  font-size:var(--fs-small);
  transition:.2s ease;
}

.top-link:hover{color:var(--gold);}

.menu-toggle{
  display:none;
  background:none;
  border:0;
  color:var(--blue);
  font-size:1.6rem;
  line-height:1;
  cursor:pointer;
}

/* =========================
   GLOBAL SECTION SYSTEM
========================= */

.section{
  position:relative;
  padding-block:var(--space-section-y);
  border:0;
}

.section + .section{
  margin-top:0;
}

.section::before,
.section::after{
  content:none !important;
  display:none !important;
}

.section-head{
  margin-bottom:var(--space-head-bottom);
}

.section-head-center{
  text-align:center;
}

.section-head-center h2{
  margin-inline:auto;
  max-width:none;
}

.eyebrow{
  margin-bottom:.45rem;
  font-size:var(--fs-small);
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
}

.section-head h2{
  font-size:var(--fs-h2);
  line-height:var(--lh-heading);
  color:var(--blue);
  font-weight:350;
}

.aufgabe-grid,
.abgabe-grid,
.uebernahme-grid,
.grid,
.pricing-layout{
  gap:var(--space-grid-gap);
}

.aufgabe-card,
.abgabe-card,
.content-card,
.price-card,
.hero-benefits,
.hero-cta{
  padding:var(--space-card-pad);
}

.content-card > * + *,
.aufgabe-card > * + *,
.abgabe-card > * + *{
  margin-top:var(--space-copy-gap);
}

/* =========================
   GLOBAL LIST SYSTEM
========================= */

.list,
.aufgabe-list,
.uebernahme-list,
.partner-action-list,
.partner-result-list,
.fuerwen-list,
.termin-list{
  margin:var(--list-offset) 0 0;
  padding-left:var(--list-indent);
}

.list li,
.aufgabe-list li,
.uebernahme-list li,
.partner-action-list li,
.partner-result-list li,
.fuerwen-list li,
.termin-list li{
  line-height:1.5;
}

.list li + li,
.aufgabe-list li + li,
.uebernahme-list li + li,
.partner-action-list li + li,
.partner-result-list li + li,
.fuerwen-list li + li,
.termin-list li + li{
  margin-top:var(--list-gap);
}

.list li::marker,
.aufgabe-list li::marker,
.uebernahme-list li::marker,
.fuerwen-list li::marker,
.termin-list li::marker{
  color:var(--gold);
}

.list-light li::marker{
  color:var(--gold-soft);
}

.list-compact li + li{
  margin-top:var(--list-gap-compact);
}

/* =========================
   GLOBAL TILES
========================= */


.marke-tile,
.warum30-tile{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:60px;
  padding:0.85rem 1rem;
  border-radius:20px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(11,44,65,.08);
  box-shadow:0 10px 24px rgba(8,31,47,.06);
  color:var(--blue);
  font-size:clamp(1.02rem, .97rem + .22vw, 1.16rem);
  font-weight:600;
  text-align:center;
  line-height:1.22;
 
}

/* =========================
   HERO
========================= */

.hero{
  position:relative;
  min-height:calc(84svh - 64px);
  overflow:hidden;
  background:var(--blue-deep);
  isolation:isolate;
}

.hero-bg{
  position:absolute;
  inset:0;
  background-image:url('/assets/img/hero.webp');
  background-repeat:no-repeat;
  background-size:cover;
  background-position:top center;
  transform:scale(1.03);
}

.hero-bg-sharp{
  z-index:0;
}

.hero-bg-soft{
  z-index:1;
  filter:blur(20px) saturate(1) brightness(.72);
  mask-image:linear-gradient(
    90deg,
    #000 0%,
    #000 60%,
    rgba(0,0,0,.78) 74%,
    rgba(0,0,0,.34) 88%,
    transparent 97%
  );
  -webkit-mask-image:linear-gradient(
    90deg,
    #000 0%,
    #000 60%,
    rgba(0,0,0,.78) 74%,
    rgba(0,0,0,.34) 88%,
    transparent 97%
  );
}

.hero-vignette{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(
      90deg,
      rgba(7,26,40,.82) 0%,
      rgba(7,26,40,.66) 18%,
      rgba(9,32,48,.46) 34%,
      rgba(11,36,54,.22) 48%,
      rgba(11,36,54,.08) 62%,
      rgba(11,36,54,0) 76%
    ),
    linear-gradient(
      180deg,
      rgba(5,18,28,.20) 0%,
      rgba(5,18,28,.06) 32%,
      rgba(5,18,28,0) 100%
    );
  pointer-events:none;
}

.hero-glow{
  position:absolute;
  inset:0;
  z-index:3;
  background:
    radial-gradient(circle at 20% 56%, rgba(198,165,112,.12) 0%, rgba(198,165,112,.05) 18%, transparent 38%),
    radial-gradient(circle at 59% 56%, rgba(255,245,216,.18) 0%, rgba(255,245,216,.10) 12%, rgba(255,245,216,.04) 24%, transparent 42%),
    radial-gradient(circle at 80% 18%, rgba(255,220,165,.16) 0%, rgba(255,220,165,.08) 16%, transparent 30%);
  pointer-events:none;
}

.hero-inner{
  position:relative;
  z-index:4;
  padding:clamp(1.5rem, 1rem + 2vw, 2.8rem) 0 clamp(1.7rem, 1.1rem + 2.3vw, 3rem);
}

.hero-headline-full{
  width:min(100%, 1220px);
  margin:0 0 clamp(1.4rem, 1.15rem + 1vw, 2.4rem) 0;
  padding:0;
}

.hero-headline-full h1,
.hero h1{
  max-width:18ch;
  margin:0;
  font-size:clamp(2.7rem, 2rem + 3.5vw, 5.05rem);
  line-height:.92;
  letter-spacing:-.042em;
  color:#fff;
  font-weight:300;
  text-wrap:balance;
  text-shadow:0 2px 18px rgba(0,0,0,.22);
}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.5fr) minmax(520px, 1fr);
  gap:clamp(1.1rem, .9rem + .8vw, 1.8rem);
  align-items:end;
}

.hero-copy{
  width:min(100%, 980px);
  max-width:72ch;
  color:rgba(255,255,255,.96);
  padding:0;
  margin:0;
  align-self:end;
}

.hero-subtitle{
  max-width:30ch;
  margin-top:0;
  font-size:clamp(1.18rem, 1.04rem + .6vw, 1.7rem);
  line-height:1.22;
  color:#fff;
  font-weight:650;
}

.hero-text{
  max-width:90ch;
  margin-top:1.1rem;
}

.hero-text p{
  font-size:clamp(1rem, .96rem + .16vw, 1.08rem);
  line-height:1.68;
  color:rgba(255,255,255,.94);
}

.hero-text p + p{
  margin-top:.95rem;
}

.hero-highlight{
  font-size:clamp(1.16rem, 1.02rem + .48vw, 1.5rem);
  line-height:1.38;
  color:var(--gold);
  font-weight:500;
  max-width:none;
}

.hero-inline-cta{
  margin-top:1.35rem;
}

.hero-button{
  width:auto;
  min-height:54px;
  padding:0 1.35rem;
}

.hero-side{
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  align-items:stretch;
  align-self:end;
  width:100%;
  max-width:600px;
  margin-left:auto;
  padding-left:0;
  padding-top:0;
}

.hero-benefits{
  border-radius:24px;
  background:linear-gradient(180deg, rgba(8,31,47,.38) 0%, rgba(8,31,47,.56) 100%);
  border:1px solid rgba(255,255,255,.08);
  color:#fff;
  box-shadow:0 12px 26px rgba(0,0,0,.14);
  backdrop-filter:blur(6px);
  padding:1.5rem 1.6rem;
}

.hero-benefits ul{
  margin:0;
  padding-left:1.05rem;
}

.hero-benefits li{
  font-size:clamp(1rem, .95rem + .14vw, 1.08rem);
  line-height:1.52;
}

.hero-benefits li + li{
  margin-top:.5rem;
}

.hero-benefits li::marker{
  color:var(--gold);
  font-size:.9em;
}
/* =========================
   BUTTONS
========================= */

.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:56px;
  padding:0 1.2rem;
  border-radius:14px;
  font-size:var(--fs-button);
  font-weight:700;
  transition:.2s ease;
}

.button-primary{
  background:linear-gradient(180deg, #d6b885 0%, #c6a570 100%);
  color:var(--blue);
  box-shadow:0 10px 26px rgba(8,31,47,.18);
}

.button-primary:hover{transform:translateY(-2px);}

/* =========================
   AUFGABE
========================= */

.section-aufgabe{
  background:linear-gradient(180deg, rgba(198,165,112,.08) 0%, rgba(255,255,255,.6) 100%);
}

.aufgabe-inner{max-width:1100px;}

#aufgabe .section-head{
  margin-bottom:var(--space-head-bottom-lg);
}

#aufgabe .section-head h2{
  max-width:26ch;
  margin-inline:auto;
}

.aufgabe-grid{
  display:grid;
  grid-template-columns:minmax(0, .95fr) minmax(0, 1.25fr);
  align-items:stretch;
}

.aufgabe-card{
  height:100%;
  border-radius:24px;
  background:rgba(255,255,255,.68);
  border:1px solid rgba(198,165,112,.18);
  box-shadow:0 10px 28px rgba(8,31,47,.06);
  backdrop-filter:blur(8px);
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  font-size:var(--fs-body);
  line-height:var(--lh-body);
}

.aufgabe-box-title{
  margin-top:0 !important;
  margin-bottom:1.1rem !important;
  font-size:1.05rem;
  font-weight:600;
  text-align:center;
  color:var(--ink);
  letter-spacing:0.02em;
}

.aufgabe-list{
  margin-top:0;
}

.aufgabe-list li{
  font-size:clamp(1.06rem, 1rem + .24vw, 1.18rem);
}

.aufgabe-copy-card p + p{
  margin-top:.35rem;
}

/* =========================
   ABGABE
========================= */

.section-soft-blue{
  background:linear-gradient(180deg, rgba(11,44,65,.15) 0%, rgba(11,44,65,.19) 100%);
}

.abgabe-inner{max-width:1100px;}

#abgabe .section-head{
  text-align:center;
  margin-bottom:var(--space-head-bottom);
}

.abgabe-grid{
  display:grid;
  grid-template-columns:minmax(0, .95fr) minmax(0, 1.25fr);
  align-items:center;
}

.abgabe-quote-wrap{
  display:flex;
  align-items:center;
  min-height:100%;
}

.abgabe-quote{
  max-width:none;
  margin:0;
  font-size:clamp(2.7rem, 2rem + 2.6vw, 4.6rem);
  line-height:.98;
  font-style:italic;
  font-weight:300;
  letter-spacing:-.03em;
  color:var(--blue);
  text-wrap:balance;
}

.abgabe-card{
  width:100%;
  max-width:none;
}

.section-soft-blue .content-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(11,44,65,.08);
  backdrop-filter:blur(6px);
}

/* =========================
   ÜBERNAHME
========================= */

.section-uebernahme{
  background:rgba(255,255,255,.72);
}

.uebernahme-inner{
  max-width:1180px;
}

#uebernahme .section-head h2{
  max-width:none;
}

.uebernahme-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  margin-top:.25rem;
}

.uebernahme-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(11,44,65,.08);
  border-radius:24px;
  box-shadow:0 12px 26px rgba(8,31,47,.05);
  padding:var(--space-card-pad);
}

.uebernahme-kicker{
  margin:0 0 .55rem 0;
  color:var(--gold);
  font-size:var(--fs-small);
  font-weight:700;
  letter-spacing:.04em;
}

.uebernahme-card h3{
  margin:0 0 .6rem 0;
  font-size:clamp(1.24rem, 1.08rem + .45vw, 1.5rem);
  line-height:1.2;
  color:var(--blue);
}

.uebernahme-copy{
  color:var(--muted);
}

.uebernahme-list{
  padding-left:var(--list-indent);
}

.uebernahme-cta{
  margin-top:clamp(2rem, 1.6rem + 1vw, 3rem);
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.95rem;
}

.uebernahme-cta-copy{
  font-size:clamp(1.05rem, .98rem + .28vw, 1.18rem);
  line-height:1.35;
  color:var(--blue);
}

/* =========================
   GENERIC CONTENT
========================= */

.grid{
  display:grid;
}

.grid-2{
  grid-template-columns:repeat(2, minmax(0,1fr));
}

.content-card{
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(255,255,255,.94) 0%, rgba(250,246,239,.94) 100%);
  border:1px solid rgba(11,44,65,.08);
  box-shadow:var(--shadow-soft);
}

.dark-card{
  background:linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(255,255,255,.08);
  color:var(--white);
  box-shadow:0 12px 30px rgba(0,0,0,.12);
}

.content-card h3{
  font-size:var(--fs-h3);
  line-height:1.16;
  color:inherit;
}

.pricing-layout{
  display:grid;
  grid-template-columns:minmax(280px, .7fr) minmax(0,1.3fr);
}

/* =========================
   FOOTER
========================= */

.site-footer{
  margin-top:0;
  border-top:1px solid rgba(11,44,65,.08);
  padding:18px 0;
  font-size:.95rem;
  color:var(--muted);
}

.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.footer-left{
  color:var(--muted);
}

.footer-right{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.footer-right a{
  color:var(--muted);
  text-decoration:none;
  transition:color .2s ease;
}

.footer-right a:hover{
  color:var(--blue);
}

/* =========================
   LIGHT SECTIONS
========================= */

.section-light{
  background:rgba(255,255,255,.72);
}

/* =========================
   PARTNER
========================= */

.section-partner{
  background:linear-gradient(180deg, rgba(11,44,65,.90) 0%, rgba(8,31,47,.96) 100%);
  color:var(--white);
}

.section-partner .eyebrow{
  color:var(--gold-soft);
}

.section-partner .section-head h2{
  color:var(--white);
  max-width:none;
}

.partner-inner{
  max-width:1180px;
}

.partner-grid{
  display:grid;
  grid-template-columns:1.15fr .95fr;
  gap:var(--space-grid-gap);
}

.partner-intro-card,
.partner-outro-card{
  min-height:100%;
}

.partner-intro-card,
.partner-outro-card,
.section-partner .content-card{
  background:linear-gradient(180deg, rgba(255,255,255,.07) 0%, rgba(255,255,255,.04) 100%);
  border:1px solid rgba(255,255,255,.10);
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  color:var(--white);
}

.section-partner .content-card > * + *{
  margin-top:var(--space-copy-gap);
}

.section-partner p,
.section-partner li{
  color:rgba(255,255,255,.92);
}

.partner-label{
  font-weight:700;
  color:var(--gold-soft) !important;
}

.partner-highlight{
  font-weight:700;
  color:var(--white) !important;
}

/* =========================
   MARKE
========================= */

.marke-inner{
  max-width:1100px;
}

.section-marke .section-head h2{
  max-width:none;
  text-wrap:balance;
}

.marke-subline{
  margin:0 0 clamp(1.2rem, 1rem + .5vw, 1.8rem);
  text-align:center;
  color:var(--blue);
  font-size:clamp(1.05rem, .98rem + .22vw, 1.16rem);
  font-weight:600;
}

.marke-tiles{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:clamp(.75rem, .68rem + .4vw, 1.5rem);


}

.marke-team-note{
  margin-top:clamp(1.4rem, 1.15rem + .7vw, 2.2rem);
  text-align:center;
  color:var(--blue);
  font-size:clamp(1.12rem, 1.02rem + .28vw, 1.28rem);
  font-weight:700;
  line-height:1.35;
}

/* =========================
   KOSTEN
========================= */

.section-kosten .section-head h2{
  max-width:none;
}

.kosten-inner{
  max-width:1080px;
}

.kosten-grid{
  display:grid;
  grid-template-columns:minmax(240px, .78fr) minmax(0, 1.22fr);
  gap:var(--space-grid-gap);
  align-items:center;
}

.kosten-price-wrap{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  min-height:100%;
  padding:clamp(.6rem, .5rem + .4vw, 1rem) 0;
}

.kosten-price-label{
  margin:0 0 .55rem 0;
  color:var(--gold);
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:var(--fs-small);
  font-weight:700;
}

.kosten-price{
  margin:0;
  font-size:clamp(3.4rem, 2.4rem + 3.2vw, 5.4rem);
  line-height:.92;
  color:var(--blue);
  font-weight:700;
  letter-spacing:-.03em;
}

.kosten-price-note{
  margin:.45rem 0 0 0 !important;
  color:var(--muted);
  font-size:clamp(1rem, .96rem + .16vw, 1.08rem);
}

.kosten-card{
  min-height:100%;
}

.kosten-copy-card p:first-child{
  margin-top:0 !important;
}

.kosten-list{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  column-gap:clamp(1.2rem, 1rem + .8vw, 2rem);
  row-gap:clamp(.55rem, .45rem + .2vw, .75rem);
  margin:var(--list-offset) 0 0;
  padding-left:var(--list-indent);
}

.kosten-list li{
  margin:0;
  line-height:1.45;
}

.kosten-list li + li{
  margin-top:0;
}

.kosten-copy-card p:last-child{
  margin-top:.9rem !important;
}

/* =========================
   FÜR WEN
========================= */

.section-fuerwen .section-head h2{
  max-width:none;
}

.fuerwen-inner{
  max-width:1080px;
}

.fuerwen-grid{
  display:grid;
  grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);
  gap:var(--space-grid-gap);
  align-items:center;
}

.fuerwen-card{
  text-align:left;
  padding:clamp(1.4rem, 1.2rem + .8vw, 2rem);
}

.fuerwen-card .list{
  margin-top:0;
}

.fuerwen-quote-wrap{
  display:flex;
  align-items:center;
  min-height:100%;
}

.fuerwen-quote{
  margin:0;
  max-width:42ch;
  font-size:clamp(1.28rem, 1.12rem + .48vw, 1.6rem);
  line-height:1.52;
  font-style:italic;
  color:var(--blue);
}

/* =========================
   ZIEL
========================= */

.ziel-inner{
  max-width:980px;
}

.ziel-stack{
  display:grid;
  gap:.45rem;
  text-align:center;
  color:var(--blue);
}

.ziel-stack p{
  font-size:clamp(1.08rem, 1rem + .25vw, 1.2rem);
}

.ziel-highlight{
  margin-top:.45rem;
  font-size:clamp(1.18rem, 1.02rem + .45vw, 1.4rem) !important;
  font-weight:700;
}

/* =========================
   TERMIN
========================= */

.section-termin{
  background: linear-gradient(180deg, #0b2c41 0%, #08202e 100%);
  color:#fff;
}

.section-termin .section-head h2{
  max-width:none;
  color:#fff;
}

.termin-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,.85fr);
  gap:var(--space-grid-gap);
  align-items:center;
}

.termin-cta{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:18px;
  padding-left:clamp(.2rem, .2rem + .8vw, 1rem);
  background:none;
  border:0;
  box-shadow:none;
  border-radius:0;
}

.termin-link{
  font-size:clamp(1.2rem,1.1rem + .3vw,1.4rem);
  font-weight:600;
  color:#fff;
  margin:0;
  max-width:22ch;
  line-height:1.35;
}

/* =========================
   ABOUT
========================= */

.about-inner{
  max-width:980px;
}

.about-list{
  columns:2;
  column-gap:2rem;
  margin:var(--list-offset) 0 0;
  padding-left:var(--list-indent);
}

.about-list li{
  break-inside:avoid;
  line-height:1.5;
  margin-bottom:var(--list-gap);
}

.about-list li::marker{
  color:var(--gold);
}

/* =========================
   WARUM 30
========================= */

.warum30-inner{
  max-width:1080px;
}

.section-warum30 .section-head h2{
  max-width:none;
}

.warum30-tiles{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  margin-top:.2rem;
  gap:clamp(.75rem, .68rem + .4vw, 1.5rem);
}


.warum30-copy{
  margin-top:clamp(1.4rem, 1.1rem + .7vw, 2rem);
  max-width:78ch;
  color:var(--blue);
}

.warum30-copy p + p{
  margin-top:.8rem;
}

/* =========================
   TESTIMONIALS
========================= */

.testimonials-inner{
  max-width:1220px;
}

.testimonials-slider-grid{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:clamp(.8rem, .7rem + .4vw, 1.2rem);
}

.testimonial-slide-grid{
  display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(0, 3fr);
  gap:clamp(1.4rem, 1.2rem + 1vw, 2.4rem);
  align-items:start;
  min-height:clamp(300px, 30vw, 390px);
  padding:clamp(1.2rem, 1rem + .8vw, 1.8rem) 0;
  background:transparent;
}

.testimonial-grid-left{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.8rem;
}

.testimonial-photo-wrap{
  width:60%;
  max-width:240px;
  aspect-ratio:4 / 5;
  border-radius:24px;
  overflow:hidden;
  background:rgba(11,44,65,.08);
  box-shadow:0 12px 28px rgba(8,31,47,.08);
}

.testimonial-photo{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.testimonial-role{
  margin:0;
  font-size:clamp(.98rem, .94rem + .14vw, 1.04rem);
  line-height:1.45;
  color:var(--muted);
}

.testimonial-link{
  margin-top:.35rem;
}

.testimonial-grid-right{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:flex-start;
  min-width:0;
  padding-top:.2rem;
}

.testimonial-text{
  position:relative;
  margin:0;
  max-width:none;
  padding-left:1.25rem;
  font-size:clamp(1.02rem, .96rem + .3vw, 1.22rem);
  line-height:1.82;
  color:var(--blue);
  font-style:italic;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.testimonial-text::before{
  content:"“";
  position:absolute;
  left:0;
  top:-.15em;
  font-size:2.8rem;
  line-height:1;
  color:rgba(198,165,112,.45);
  font-family:Georgia, "Times New Roman", serif;
  font-style:normal;
}

.testimonial-text.is-collapsed{
  -webkit-line-clamp:6;
}

.testimonial-more{
  margin-top:.85rem;
  padding:0;
  border:0;
  background:none;
  color:var(--gold);
  font-size:var(--fs-small);
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  cursor:pointer;
}

.testimonial-name{
  margin-top:1.1rem;
  font-size:clamp(1.05rem, 1rem + .22vw, 1.18rem);
  line-height:1.35;
  color:var(--blue);
  font-weight:700;
}

.button-secondary{
  background:transparent;
  border:1px solid rgba(11,44,65,.14);
  color:var(--blue);
  box-shadow:none;
}

.button-secondary:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(8,31,47,.08);
}

.testimonials-arrow{
  width:54px;
  height:54px;
  border-radius:999px;
  border:1px solid rgba(11,44,65,.10);
  background:rgba(255,255,255,.92);
  color:var(--blue);
  font-size:2rem;
  line-height:1;
  cursor:pointer;
  box-shadow:0 10px 20px rgba(8,31,47,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.testimonials-arrow:hover{
  transform:translateY(-2px);
  border-color:rgba(198,165,112,.35);
  box-shadow:0 14px 24px rgba(8,31,47,.1);
}

.testimonials-dots{
  display:flex;
  justify-content:center;
  gap:.6rem;
  margin-top:.75rem;
}

.testimonials-dot{
  width:10px;
  height:10px;
  border-radius:999px;
  border:0;
  background:rgba(11,44,65,.18);
  cursor:pointer;
  padding:0;
  transition:transform .18s ease, background .18s ease;
}

.testimonials-dot.is-active{
  background:var(--gold);
  transform:scale(1.15);
}

/* =========================
   TESTIMONIAL MODAL
========================= */

.testimonial-modal[hidden]{
  display:none;
}

.testimonial-modal{
  position:fixed;
  inset:0;
  z-index:200;
}

.testimonial-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(8,31,47,.62);
  backdrop-filter:blur(4px);
}

.testimonial-modal-dialog{
  position:relative;
  width:min(920px, calc(100% - 2rem));
  max-height:calc(100svh - 2rem);
  margin:1rem auto;
  overflow:auto;
  border-radius:28px;
  background:rgba(255,255,255,.98);
  box-shadow:0 28px 70px rgba(8,31,47,.24);
  padding:clamp(1.4rem, 1.1rem + 1vw, 2rem);
}

.testimonial-modal-close{
  position:absolute;
  top:.85rem;
  right:.9rem;
  width:42px;
  height:42px;
  border-radius:999px;
  border:1px solid rgba(11,44,65,.10);
  background:#fff;
  color:var(--blue);
  font-size:1.8rem;
  line-height:1;
  cursor:pointer;
}

.testimonial-modal-head{
  padding-right:3rem;
}

.testimonial-modal-role{
  margin:0 0 .35rem 0;
  color:var(--muted);
  font-size:var(--fs-small);
}

.testimonial-modal-name{
  margin:0;
  color:var(--blue);
  font-size:clamp(1.35rem, 1.2rem + .5vw, 1.7rem);
  line-height:1.2;
}

.testimonial-modal-body{
  margin-top:1.2rem;
  color:var(--ink);
  font-size:clamp(1rem, .96rem + .18vw, 1.08rem);
  line-height:1.8;
  white-space:pre-line;
}

.testimonial-modal-actions{
  margin-top:1.4rem;
}

/* =========================
   FINAL CTA
========================= */

.section-cta-final{
  background:linear-gradient(180deg, rgba(11,44,65,.88) 0%, rgba(8,31,47,.96) 100%);
  color:var(--white);
}

.section-cta-final .eyebrow{
  color:var(--gold-soft);
}

.section-cta-final .section-head h2{
  color:var(--white);
  max-width:none;
  font-size:clamp(2.2rem, 1.8rem + 2vw, 3rem);
  line-height:1.2;
}

.cta-final-inner{
  max-width:980px;
}

.cta-final-stack{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:1rem;
  text-align:center;
}

.cta-sub{
  margin:0;
  font-size:clamp(1rem, .95rem + .2vw, 1.1rem);
  color:rgba(255,255,255,.85);
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width:980px){
  .menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:44px;
    height:44px;
  }

  .site-header-inner{
    position:relative;
  }

  .top-nav{
    display:none;
    position:absolute;
    top:100%;
    left:0;
    right:0;
    padding:1rem;
    background:rgba(255,255,255,.98);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(11,44,65,.08);
    box-shadow:0 14px 30px rgba(8,31,47,.08);
    flex-direction:column;
    align-items:flex-start;
    gap:.85rem;
  }

  .top-nav.open{
    display:flex;
  }

  .top-link{
    width:100%;
  }

  .hero-bg{
    background-position:72% center;
  }

  .hero-bg-soft{
    filter:blur(14px) saturate(.92) brightness(.72);
    mask-image:linear-gradient(180deg, #000 0%, #000 52%, rgba(0,0,0,.4) 76%, transparent 100%);
    -webkit-mask-image:linear-gradient(180deg, #000 0%, #000 52%, rgba(0,0,0,.4) 76%, transparent 100%);
  }

  .hero-vignette{
    background:
      linear-gradient(180deg, rgba(8,31,47,.70) 0%, rgba(8,31,47,.78) 36%, rgba(8,31,47,.88) 100%),
      linear-gradient(180deg, rgba(8,31,47,.10) 0%, rgba(8,31,47,.20) 100%);
  }

  .hero-grid{
    grid-template-columns:1fr;
    gap:1rem;
    align-items:start;
  }

  .hero-copy{
    width:min(100%, 980px);
    max-width:none;
    padding:0;
  }

  .hero h1{
    max-width:13ch;
  }

  .hero-side{
    max-width:760px;
    margin-left:0;
    padding-left:0;
    padding-top:.25rem;
  }

  .hero-inline-cta .hero-button{
    width:100%;
  }

  .aufgabe-grid,
  .abgabe-grid,
  .uebernahme-grid,
  .partner-grid,
  .kosten-grid,
  .termin-grid,
  .grid-2,
  .pricing-layout,
  .fuerwen-grid{
    grid-template-columns:1fr;
  }

  .abgabe-quote{
    max-width:12ch;
  }

  .marke-tiles{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .about-list{
    columns:1;
  }

  .kosten-list{
    grid-template-columns:1fr 1fr;
  }

  .warum30-tiles{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }

  .fuerwen-quote-wrap{
    justify-content:center;
    text-align:center;
  }

  .testimonials-arrow{
  display:none;
}

.testimonials-slider-grid{
  grid-template-columns:minmax(0,1fr);
  gap:0;
}

.testimonial-slide-grid{
  grid-template-columns:1fr;
  min-height:auto;
  gap:1rem;
  padding:1.15rem;
  border-radius:24px;
  background:rgba(255,255,255,.9);
  border:1px solid rgba(11,44,65,.08);
  box-shadow:0 12px 28px rgba(8,31,47,.08);
}

.testimonial-grid-left{
  align-items:center;
  text-align:center;
  gap:.75rem;
}

.testimonial-grid-right{
  align-items:center;
  text-align:center;
  padding-top:0;
}

.testimonial-photo-wrap{
  max-width:180px;
  margin-inline:auto;
  border-radius:20px;
}

.testimonial-role{
  max-width:30ch;
}

.testimonial-link{
  margin-top:.15rem;
}

.testimonial-text{
  padding-left:0;
  font-size:clamp(1rem, .96rem + .25vw, 1.08rem);
  line-height:1.65;
}

.testimonial-text::before{
  position:static;
  display:block;
  margin-bottom:.25rem;
  font-size:2.2rem;
  line-height:1;
}

.testimonial-name{
  margin-top:.9rem;
}

.testimonial-more{
  margin-top:.7rem;
}

.testimonials-dots{
  margin-top:1rem;
}

@media (max-width:640px){
  :root{
    --space-section-y:clamp(3rem, 2.5rem + 1.5vw, 4.2rem);
    --space-head-bottom:1.25rem;
    --space-head-bottom-lg:1.6rem;
    --space-grid-gap:1rem;
    --space-card-pad:1.15rem;
    --space-copy-gap:.72rem;
  }

  .site-header-inner{
    min-height:60px;
  }

  .hero{
    min-height:auto;
  }

  .hero-bg{
    background-position:74% center;
  }

  .hero-bg-soft{
    filter:blur(10px) saturate(.92) brightness(.72);
  }

  .hero-inner{
    padding:1rem 0 1.6rem;
  }

  .hero h1{
    max-width:12ch;
    font-size:clamp(2.3rem, 1.9rem + 2.8vw, 3.9rem);
  }

  .hero-headline-full{
    margin-bottom:.55rem;
  }

  .hero-text{
    margin-top:.9rem;
  }

  .hero-text p + p{
    margin-top:.85rem;
  }

  .hero-inline-cta{
    margin-top:1rem;
  }

  .hero-side{
    padding-top:.15rem;
  }

  .button-primary,
  .hero-inline-cta .hero-button{
    width:100%;
  }

.marke-tile,
.warum30-tile{
  min-height:none;
  padding:.9rem 1.1rem;
  border-radius:18px;
}

  .warum30-tiles,
  .marke-tiles,
  .kosten-list{
    grid-template-columns:1fr;
  }

  .fuerwen-list{
    width:100%;
  }
  
  .testimonial-slide-grid{
  padding:1rem .95rem;
  border-radius:20px;
  gap:.9rem;
}

.testimonial-photo-wrap{
  max-width:150px;
  border-radius:18px;
}

.testimonial-role{
  font-size:.96rem;
  line-height:1.4;
}

.testimonial-text{
  font-size:1rem;
  line-height:1.58;
}

.testimonial-name{
  font-size:1.02rem;
}

.testimonial-link{
  width:100%;
  max-width:260px;
}

.testimonials-dots{
  gap:.5rem;
  margin-top:.85rem;
}

.testimonials-dot{
  width:9px;
  height:9px;
}
  

  .footer-inner{
    flex-direction:column;
    align-items:flex-start;
  }

  .footer-right{
    justify-content:flex-start;
  }
}

