/* =========================================================
   Geld – Leben – Zukunft  ·  styles.css
   Markenfarben: Rot #cb3a3a (Hauptfarbe) + Blau #586dfa (Akzent)
   inkl. abgestimmter Abstufungen und Rot-zu-Blau-Verlauf
   Schrift: System-Stack (schnell, keine externen Requests, DSGVO-sauber)
   ========================================================= */

:root{
  --ink:#1d2235;
  --ink-soft:#4c5168;
  --green:#cb3a3a;        /* Markenrot – primäre Aktionsfarbe */
  --green-deep:#2d3680;   /* dunkles Markenblau – dunkle Flächen / Texte */
  --green-700:#b23131;    /* dunkleres Rot – Text/Icons auf Hell */
  --red-deep:#a82f2f;     /* Hover-Rot */
  --mint:#eef0fe;         /* helle blaue Fläche */
  --mint-200:#dfe3fc;
  --paper:#FFFFFF;
  --paper-2:#FAFBFF;
  --gold:#586dfa;         /* Markenblau – Akzentfarbe */
  --gold-soft:#e8ebfe;
  --gold-deep:#3a4fd1;    /* dunkleres Blau – Text/Hover */
  --line:#e7e6f2;
  --danger:#b1342f;

  --radius:20px;
  --radius-sm:13px;
  --radius-pill:999px;
  --maxw:1140px;
  --shadow:0 18px 40px -22px rgba(28,30,70,.30);
  --shadow-sm:0 6px 18px -10px rgba(28,30,70,.25);
  --grad:linear-gradient(90deg,var(--green) 0%, var(--gold) 100%);

  --font:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:90px}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--font);
  color:var(--ink);
  background:var(--paper);
  line-height:1.62;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%;height:auto;display:block}
a{color:var(--green);text-underline-offset:3px}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:22px}
.wrap--narrow{max-width:820px}
.section{padding-block:clamp(54px,8vw,104px)}
.section--mint{background:var(--mint)}
.section--paper2{background:var(--paper-2)}
.section--green{background:var(--green-deep);color:#eef0fb}

.eyebrow{
  display:inline-flex;align-items:center;gap:9px;
  font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--green-700);
}
.section--green .eyebrow{color:var(--gold)}
.eyebrow::before{content:"";width:30px;height:3px;background:var(--grad);border-radius:2px}

h1,h2,h3{line-height:1.1;letter-spacing:-.02em;font-weight:800;margin:0}
h2.title{font-size:clamp(1.7rem,3.6vw,2.6rem);margin:.55rem 0 .9rem}
h3{font-size:1.22rem;letter-spacing:-.01em}
.lede{font-size:clamp(1.02rem,1.6vw,1.18rem);color:var(--ink-soft);max-width:60ch}
.section--green .lede{color:#c8cef1}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font:inherit;font-weight:700;font-size:1rem;
  padding:.85em 1.5em;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;text-decoration:none;
  transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--gold);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:#4a5ef5;color:#fff}
.btn--ghost{background:transparent;border-color:var(--gold);color:var(--gold)}
.btn--ghost:hover{background:var(--gold);color:#fff}
.btn--ondark{background:#fff;color:var(--green-deep)}
.btn--ondark:hover{background:var(--gold);color:#fff}
.btn--lg{padding:1.02em 1.9em;font-size:1.06rem}
.btn--block{width:100%}

:where(a,button):focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:8px}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad);z-index:1}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;height:70px}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none;color:var(--ink)}
.brand img{height:40px;width:auto}
.brand strong{font-weight:800;letter-spacing:-.02em;font-size:1.02rem;white-space:nowrap}
.brand span{display:block;font-size:.72rem;color:var(--ink-soft);font-weight:600;letter-spacing:.02em}
.header-cta{display:flex;align-items:center;gap:10px}
.nav-link{display:none}
@media(min-width:880px){
  .nav-link{display:inline-block;color:var(--ink-soft);font-weight:600;text-decoration:none;font-size:.96rem}
  .nav-link:hover{color:var(--green)}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(120% 90% at 90% -12%, var(--gold-soft) 0%, transparent 48%),
  radial-gradient(100% 80% at -5% 0%, #fbe6e6 0%, transparent 42%),
  linear-gradient(180deg,#F5F6FF 0%, #FFFFFF 72%);}
.hero-grid{display:grid;gap:34px;align-items:center;padding-block:clamp(40px,7vw,76px)}
@media(min-width:920px){.hero-grid{grid-template-columns:1.05fr .95fr;gap:48px}}
.hero h1{font-size:clamp(2.1rem,5.4vw,3.5rem)}
.hero .lede{margin-top:1rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:13px;margin-top:1.7rem}
.trust-row{display:flex;flex-wrap:wrap;gap:10px 20px;margin-top:1.7rem;padding:0;list-style:none}
.trust-row li{display:flex;align-items:center;gap:8px;font-weight:600;font-size:.93rem;color:var(--ink-soft)}
.trust-row svg{flex:0 0 auto;color:var(--green)}

.hero-card{
  position:relative;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:10px;
}
.hero-card img{border-radius:13px;width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--mint)}
.hero-badge{
  position:absolute;left:-12px;bottom:18px;background:var(--green);color:#fff;
  font-weight:700;font-size:.9rem;padding:.7em 1.1em;border-radius:14px;box-shadow:var(--shadow-sm);
}
.hero-badge b{display:block;font-size:1.15rem}

/* ---------- "Warum" Problem-Liste ---------- */
.split{display:grid;gap:34px;align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr;gap:48px}}
.split--rev .split-media{order:-1}
@media(min-width:900px){.split--rev .split-media{order:0}}
.split-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;aspect-ratio:4/3;object-fit:cover;background:var(--mint)}
.check-list{list-style:none;margin:1.1rem 0 0;padding:0;display:grid;gap:.7rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start}
.check-list svg{flex:0 0 auto;margin-top:3px;color:var(--green)}

/* ---------- Topic-Cards ---------- */
.cards{display:grid;gap:18px;margin-top:2.2rem}
@media(min-width:680px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow-sm);
  transition:transform .18s ease, box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card-ico{
  width:48px;height:48px;border-radius:13px;display:grid;place-items:center;
  background:var(--mint);color:var(--green-700);margin-bottom:14px;
}
.card h3{margin-bottom:.5rem}
.card ul{margin:0;padding-left:1.05rem;color:var(--ink-soft);font-size:.96rem}
.card ul li{margin:.25rem 0}

/* ---------- Für wen / Geschenk ---------- */
.pill-list{list-style:none;margin:1.1rem 0 0;padding:0;display:flex;flex-wrap:wrap;gap:10px}
.pill-list li{background:var(--mint);border:1px solid var(--mint-200);color:var(--green-deep);
  font-weight:600;padding:.55em 1em;border-radius:var(--radius-pill);font-size:.95rem}
.gift-note{
  margin-top:1.6rem;background:var(--gold-soft);border:1px solid #ccd3fd;
  border-radius:var(--radius);padding:20px 22px;display:flex;gap:14px;align-items:flex-start;
}
.gift-note svg{flex:0 0 auto;color:var(--gold-deep);margin-top:2px}
.gift-note strong{display:block;margin-bottom:.2rem}

/* ---------- Erwartet dich ---------- */
.expect-grid{display:grid;gap:16px;margin-top:2rem}
@media(min-width:760px){.expect-grid{grid-template-columns:repeat(2,1fr)}}
.expect{display:flex;gap:.85rem;align-items:flex-start;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:18px 18px;box-shadow:var(--shadow-sm)}
.expect svg{flex:0 0 auto;margin-top:2px;color:var(--green)}
.cert{
  margin-top:1.6rem;text-align:center;font-weight:700;color:var(--green-deep);
  background:var(--mint);border-radius:var(--radius-pill);padding:.9em 1.2em;
  display:inline-flex;gap:.6rem;align-items:center;
}

/* ---------- Über uns ---------- */
.about{display:grid;gap:34px;align-items:start}
@media(min-width:900px){.about{grid-template-columns:.85fr 1.15fr;gap:46px}}
.about-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;object-fit:cover;background:var(--mint)}
.bios{display:grid;gap:22px;margin-top:1.4rem}
@media(min-width:560px){.bios{grid-template-columns:1fr 1fr}}
.bio{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:20px;box-shadow:var(--shadow-sm)}
.bio h3{margin-bottom:.5rem}
.bio ul{margin:0;padding-left:1.05rem;color:var(--ink-soft);font-size:.92rem}

/* ---------- Infos ---------- */
.info-grid{display:grid;gap:16px;margin-top:2rem}
@media(min-width:760px){.info-grid{grid-template-columns:repeat(3,1fr)}}
.info{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);padding:22px}
.section--green .info-grid .info h3{color:#fff;margin-bottom:.35rem}
.info .ico{color:var(--gold);margin-bottom:12px}
.info p{margin:0;color:#c8cef1}
.info small{color:#a7aedb}

/* ---------- Booking ---------- */
.booking-card{
  max-width:760px;margin:2rem auto 0;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(22px,4vw,38px);text-align:center;
}
.booking-card h2{font-size:clamp(1.5rem,3vw,2rem)}
.booking-embed{margin-top:1.4rem}
.embed-placeholder{
  border:1.5px dashed var(--mint-200);border-radius:var(--radius);padding:30px 22px;background:var(--paper-2);
}
.embed-placeholder p{color:var(--ink-soft);margin:.4rem 0 1.2rem;font-size:.96rem}
.secure-note{display:inline-flex;align-items:center;gap:8px;color:var(--ink-soft);font-size:.86rem;margin-top:1rem}
.secure-note svg{color:var(--green)}
.pay-badges{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:1.1rem}
.pay-badges span{font-size:.78rem;font-weight:700;color:var(--ink-soft);background:var(--mint);
  border:1px solid var(--mint-200);border-radius:8px;padding:.35em .7em;letter-spacing:.02em}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:2rem auto 0;display:grid;gap:12px}
.faq details{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{
  list-style:none;cursor:pointer;padding:18px 52px 18px 20px;position:relative;
  font-weight:700;font-size:1.03rem;color:var(--ink);
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"";position:absolute;right:20px;top:50%;width:11px;height:11px;
  border-right:2.5px solid var(--green);border-bottom:2.5px solid var(--green);
  transform:translateY(-65%) rotate(45deg);transition:transform .2s ease;
}
.faq details[open] summary::after{transform:translateY(-35%) rotate(-135deg)}
.faq .faq-body{padding:0 20px 20px;color:var(--ink-soft)}
.faq .faq-body a{font-weight:600}

/* ---------- Sternchen-Anker ---------- */
a.asterisk{
  display:inline-block;vertical-align:super;font-size:.65em;line-height:1;
  color:var(--gold);font-weight:700;text-decoration:none;margin-left:1px;
  transition:color .15s;
}
a.asterisk:hover{color:var(--gold-deep);text-decoration:underline}
.badge-asterisk{color:rgba(255,255,255,.9);text-decoration:none;font-weight:700}
.badge-asterisk:hover{color:#fff;text-decoration:underline}
.asterisk--label{color:var(--gold);font-weight:700;font-size:.9em;vertical-align:baseline;margin-right:4px}

/* ---------- Warteliste ---------- */
.waitlist-card{
  display:flex;align-items:flex-start;gap:20px;
  background:var(--paper);border:1.5px solid var(--mint-200);
  border-radius:var(--radius);padding:28px 32px;
  box-shadow:var(--shadow-sm);max-width:820px;margin:0 auto;
}
.waitlist-ico{
  flex:0 0 auto;width:52px;height:52px;border-radius:50%;
  background:var(--gold-soft);display:flex;align-items:center;justify-content:center;
  color:var(--gold-deep);margin-top:3px;
}
.waitlist-card h3{font-size:1.15rem;margin:0 0 .45rem;color:var(--ink)}
.waitlist-card p{margin:0 0 1.1rem;color:var(--ink-soft)}
.waitlist-actions{display:flex;flex-wrap:wrap;gap:12px}
@media(max-width:600px){
  .waitlist-card{flex-direction:column}
  .waitlist-actions{flex-direction:column}
  .waitlist-actions .btn{text-align:center}
}

/* ---------- Final CTA ---------- */
.final{text-align:center}
.final h2{font-size:clamp(1.7rem,3.6vw,2.5rem);max-width:18ch;margin-inline:auto}
.final p{max-width:54ch;margin:1rem auto 1.8rem}

/* ---------- Footer ---------- */
.site-footer{background:#232a66;color:#c8cdee;padding-block:46px 30px;font-size:.95rem}
.footer-top{display:grid;gap:26px}
@media(min-width:760px){.footer-top{grid-template-columns:1.4fr 1fr 1fr}}
.footer-brand img{height:42px;filter:brightness(0) invert(1);opacity:.92}
.footer-brand p{margin:.9rem 0 0;max-width:36ch;color:#9aa0cf}
.footer h4{color:#fff;font-size:.95rem;margin:0 0 .7rem;letter-spacing:.02em}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.footer a{color:#d2d6f1;text-decoration:none}
.footer a:hover{color:#fff;text-decoration:underline}
.footer-bottom{margin-top:34px;padding-top:20px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;flex-wrap:wrap;gap:10px 18px;justify-content:space-between;align-items:center;color:#9095c4;font-size:.86rem}
.footer-bottom button{background:none;border:none;color:#d2d6f1;font:inherit;cursor:pointer;text-decoration:underline;padding:0}

/* ---------- Cookie-Consent ---------- */
.cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:200;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 24px 60px -20px rgba(8,28,20,.55);padding:20px 22px;
  max-width:560px;margin-inline:auto;display:none;
}
.cookie-banner.is-open{display:block}
.cookie-banner h3{font-size:1.1rem;margin-bottom:.4rem}
.cookie-banner p{font-size:.92rem;color:var(--ink-soft);margin:0 0 1rem}
.cookie-banner p a{font-weight:600}
.cookie-actions{display:flex;flex-wrap:wrap;gap:10px}
.cookie-actions .btn{flex:1 1 auto;font-size:.95rem;padding:.7em 1.1em}
.btn--soft{background:var(--mint);color:var(--green-deep)}
.btn--soft:hover{background:var(--mint-200)}

/* ---------- Legal pages ---------- */
.legal{padding-block:clamp(40px,6vw,72px)}
.legal h1{font-size:clamp(1.8rem,4vw,2.5rem);margin-bottom:.4rem}
.legal .updated{color:var(--ink-soft);font-size:.9rem;margin-bottom:2rem}
.legal h2{font-size:1.3rem;margin:2.2rem 0 .6rem}
.legal h3{font-size:1.08rem;margin:1.4rem 0 .4rem}
.legal p,.legal li{color:var(--ink-soft)}
.legal ul{padding-left:1.2rem}
.legal a{word-break:break-word}
.legal .note{background:var(--gold-soft);border:1px solid #ccd3fd;border-radius:var(--radius-sm);
  padding:16px 18px;color:#2c357a;margin:1.6rem 0;font-size:.92rem}
.back-home{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;margin-bottom:1.4rem;text-decoration:none}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
