/* ==================================================
   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(78svh - 64px);
  overflow:hidden;
  background:var(--blue-deep);
  isolation:isolate;
  display:flex;
  align-items:center;
}

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

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

/* Das neue Hero-Bild trägt Licht und Stimmung bereits im Motiv.
   Deshalb werden die früheren Zusatzebenen deaktiviert. */
.hero-bg-soft,
.hero-glow{
  display:none;
}

.hero-vignette{
  position:absolute;
  inset:0;
  z-index:2;
  background:
    linear-gradient(
      90deg,
      rgba(7,26,40,.48) 0%,
      rgba(7,26,40,.34) 24%,
      rgba(7,26,40,.16) 42%,
      rgba(7,26,40,0) 64%
    );
  pointer-events:none;
}

.hero::after{
  content:none;
}

.hero-inner{
  position:relative;
  z-index:4;
  padding:clamp(1.8rem, 1.2rem + 2vw, 3rem) 0 clamp(1.8rem, 1.2rem + 2vw, 3rem);
}

.hero-headline-full{
  width:min(100%, 1180px);
  margin:0 0 clamp(.7rem, .55rem + 1.2vw, 1.1rem) 0;
  padding:0;
}

.hero-headline-full h1,
.hero h1{
  max-width:27ch;
  margin:0;
  font-size:clamp(2.35rem, 1.65rem + 2.7vw, 4.25rem);
  line-height:1.04;
  letter-spacing:-.038em;
  color:#fff;
  font-weight:650;
  text-wrap:balance;
  text-shadow:0 2px 22px rgba(0,0,0,.3);
}

.hero-kicker{
  max-width:54ch;
  margin-top:clamp(1.15rem, .9rem + .7vw, 1.65rem);
  font-size:clamp(1.16rem, 1rem + .55vw, 1.55rem);
  line-height:1.25;
  color:rgba(255,255,255,.92);
  font-weight:600;
  text-wrap:balance;
  text-shadow:0 2px 18px rgba(0,0,0,.28);
}

.hero-statement{
  max-width:44ch;
  margin-top:.45rem;
  font-size:clamp(1.16rem, 1rem + .55vw, 1.55rem);
  line-height:1.25;
  color:var(--gold-soft);
  font-weight:600;
  text-wrap:balance;
  text-shadow:0 2px 18px rgba(0,0,0,.28);
}

.hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1.5fr) minmax(520px, 1fr);
  gap:clamp(.8rem, .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:.6rem;
}

.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:.6rem;
}

.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.6rem;
}

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

.hero-footnote{
  max-width:350ch;
  margin-top:.75rem;
  color:rgba(255,255,255,.72);
  font-size:clamp(.52rem, .52rem + .12vw, .68rem);
  line-height:1.45;
  text-shadow:0 2px 14px rgba(0,0,0,.28);
}

.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,.36) 0%, rgba(8,31,47,.52) 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.35rem 1.45rem;
}

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

.hero-benefits li{
  font-size:clamp(.96rem, .92rem + .12vw, 1.04rem);
  line-height:1.5;
}

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

.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(300px, .9fr) minmax(0, 2.6fr);
  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;
  min-width:300px;
}

.testimonial-photo-wrap{
  width:72%;
  max-width:260px;
  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;
  width:100%;
  max-width:300px;
  font-size:clamp(.98rem, .94rem + .14vw, 1.04rem);
  line-height:1.42;
  color:var(--muted);
  text-align:center;
}

.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{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:
    linear-gradient(
      180deg,
      rgba(8,31,47,.68) 0%,
      rgba(8,31,47,.78) 100%
    ),
    url('/assets/img/hero_dunkel.webp');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  color:var(--white);
}

.section-cta-final::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(circle at 50% 30%, rgba(198,165,112,.14), transparent 38%),
    linear-gradient(90deg, rgba(8,31,47,.78) 0%, rgba(8,31,47,.42) 50%, rgba(8,31,47,.7) 100%);
  pointer-events:none;
}

.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;
}

.section-cta-final .section-head h3{
  margin:0 auto;
  max-width:58ch;
  color:var(--white);
  font-size:clamp(1.45rem, 1.12rem + 1vw, 2.18rem);
  line-height:1.26;
  font-weight:700;
  text-wrap:balance;
}

.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-vignette{
    background:
      linear-gradient(
        180deg,
        rgba(8,31,47,.64) 0%,
        rgba(8,31,47,.72) 42%,
        rgba(8,31,47,.84) 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;
  min-width:0;
}

.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-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;
  }
}

/* =========================
   AKTUALISIERTE BEREICHE – AUS HTML AUSGELAGERT
========================= */

/* Ergänzungen für die überarbeitete Angebots-, Kennenlern- und Referenzstruktur */
.angebot-inner{max-width:1180px;}
.angebot-single-box{
  padding:clamp(1.35rem, 1.1rem + .9vw, 2rem);
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(11,44,65,.96) 0%, rgba(8,31,47,.98) 100%);
  color:#fff;
  box-shadow:0 16px 36px rgba(8,31,47,.14);
  border:1px solid rgba(255,255,255,.06);
}
.angebot-single-box p{
  color:rgba(255,255,255,.92);
  line-height:1.72;
}
.angebot-single-box p + p{margin-top:1rem;}
.angebot-single-box strong{color:#fff;}
.angebot-inline-note{
  margin:1.15rem 0 !important;
  padding:1rem 1.1rem;
  border-radius:18px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.08);
  text-align:center;
}
.angebot-inline-note strong{
  display:block;
  color:var(--gold-soft);
  font-size:clamp(1.08rem, 1rem + .4vw, 1.32rem);
  line-height:1.4;
}
.angebot-access-head{
  width:100%;
  margin-top:clamp(2rem, 1.6rem + 1vw, 3rem);
  margin-bottom:var(--space-head-bottom);
  text-align:center;
}
.angebot-access-head h4{
  margin:0;
  width:100%;
  font-size:clamp(1.25rem, 1.05rem + .8vw, 1.9rem);
  line-height:1.25;
  color:var(--blue);
  font-weight:450;
  text-wrap:balance;
}
.angebot-cta{margin-top:clamp(2rem, 1.55rem + 1vw, 3rem);}

.section-ericadler{background:linear-gradient(180deg, rgba(11,44,65,.11) 0%, rgba(11,44,65,.16) 100%);}
.section-ericadler .content-card{background:rgba(255,255,255,.92);}

.kennenlernen-layout{
  display:grid;
  grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:var(--space-grid-gap);
  align-items:center;
}
.kennenlernen-copy-side{
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:clamp(1.2rem, 1rem + .8vw, 1.8rem);
}
.kennenlernen-copy-side h2{
  margin:0;
  max-width:31ch;
  color:#fff;
  font-size:clamp(1.45rem, 1.16rem + 1.15vw, 2.55rem);
  line-height:1.18;
  font-weight:350;
  letter-spacing:-.025em;
  text-wrap:balance;
}
.kennenlernen-buttons{
  display:flex;
  gap:clamp(.7rem,.6rem + .45vw,1rem);
  flex-wrap:wrap;
}
.kennenlernen-buttons .button{
  min-width:clamp(150px, 12vw, 190px);
  min-height:54px;
  padding-inline:1.15rem;
}
.reserved-place{
  margin-top:clamp(2rem, 1.5rem + 1.2vw, 3rem);
  display:grid;
  grid-template-columns:minmax(180px,.45fr) minmax(0,1fr);
  gap:var(--space-grid-gap);
  align-items:center;
  padding:var(--space-card-pad);
  border-radius:var(--radius-xl);
  background:linear-gradient(180deg, rgba(11,44,65,.92) 0%, rgba(8,31,47,.96) 100%);
  color:#fff;
  box-shadow:var(--shadow-soft);
}
.reserved-figure{
  display:grid;
  place-items:center;
  min-height:260px;
  border-radius:24px;
  background:radial-gradient(circle at 50% 24%, rgba(198,165,112,.2), transparent 36%), rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  position:relative;
  overflow:hidden;
}
.reserved-figure::before{
  content:"?";
  position:absolute;
  top:1rem;
  right:1.2rem;
  color:rgba(198,165,112,.9);
  font-size:clamp(3rem, 2rem + 3vw, 5rem);
  line-height:1;
  font-weight:300;
}
.reserved-silhouette{
  width:min(135px, 55%);
  aspect-ratio:3/4;
  border-radius:999px 999px 30px 30px;
  background:linear-gradient(180deg, rgba(255,255,255,.42), rgba(255,255,255,.08));
  filter:blur(.2px);
  opacity:.75;
  position:relative;
}
.reserved-silhouette::before{
  content:"";
  position:absolute;
  width:48%;
  aspect-ratio:1;
  border-radius:50%;
  background:rgba(255,255,255,.46);
  top:-18%;
  left:26%;
}
.reserved-copy h3{
  margin:0;
  color:#fff;
  font-size:clamp(1.55rem, 1.25rem + 1vw, 2.25rem);
  line-height:1.1;
  font-weight:350;
  text-wrap:balance;
}
.reserved-copy p{margin-top:.85rem;color:rgba(255,255,255,.88);}
.reserved-copy ul{margin-top:1rem;}

@media (max-width:980px){
  .kennenlernen-layout,
  .reserved-place{grid-template-columns:1fr;}
  .kennenlernen-copy-side{justify-content:flex-start;}
  .kennenlernen-copy-side h2{max-width:none;text-align:center;}
  .kennenlernen-buttons{justify-content:center;}
}
@media (max-width:640px){
  .reserved-figure{min-height:220px;}
}

/* =========================
   SCROLL-TOP-BUTTON
========================= */

.scroll-top-btn {
  position: fixed;
  right: 18px;
  bottom: 22px;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(11, 44, 65, 0.18);
  background: rgba(255, 255, 255, 0.94);
  color: #0b2c41;
  box-shadow: 0 12px 30px rgba(11, 44, 65, 0.18);
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition:
    opacity 0.2s ease,
    transform 0.2s ease,
    background 0.2s ease,
    box-shadow 0.2s ease;
}

.scroll-top-btn.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.scroll-top-btn:hover {
  background: #f8f6f1;
  box-shadow: 0 16px 36px rgba(11, 44, 65, 0.22);
}

.scroll-top-btn:focus-visible {
  outline: 3px solid rgba(198, 165, 112, 0.55);
  outline-offset: 3px;
}

@media (max-width: 640px) {
  .scroll-top-btn {
    right: 14px;
    bottom: 16px;
    width: 38px;
    height: 38px;
    font-size: 20px;
  }
}
