  :root {
    --paper:#F7F1E8; --card:#FFFFFF; --tint:#EFE6D7;
    --border:#E8DCC9; --border2:#E2D5C0;
    --ink:#2E2528; --muted:#5C5248; --muted2:#4A4038; --caption:#8E8278;
    --magenta:#C00070; --magenta-hover:#A30060; --magenta-tint:#F3CFE2;
    --yellow:#EFD83B; --yellow-hover:#E5CE32; --yellow-text:#5C541F;
    --ocher:#D08F30; --teal:#30A090; --orange:#EE6537;
    --dark:#2E2528; --dark-muted:#AB9CA4; --dark-muted2:#C9BEB2; --dark-border:#5C4C55;
    --serif:'Source Serif 4', Georgia, serif;
    --sans:'Work Sans', system-ui, sans-serif;
    --maxw:1200px;
    --nav-h:69px;
  }

  * { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    margin: 0; padding: 0;
    background: var(--paper); color: var(--ink);
    font-family: var(--sans); -webkit-font-smoothing: antialiased;
  }
  img { display: block; max-width: 100%; }
  a { color: inherit; }

  .wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 32px; }
  section, header.hero { scroll-margin-top: var(--nav-h); }

  /* ---- Reusable ---- */
  .eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 13px; font-weight: 600; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--caption);
  }
  .dot { border-radius: 50%; display: inline-block; flex: none; }
  .pill-shape { border-radius: 999px; display: inline-block; flex: none; }
  .h2 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 40px; line-height: 1.15; color: var(--ink); }
  .lead { margin: 0; font-size: 15px; line-height: 1.55; color: var(--muted); }

  .btn {
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--sans); font-weight: 600; text-decoration: none;
    border-radius: 10px; cursor: pointer; border: none;
    transition: background .15s ease, color .15s ease;
  }
  .btn-primary { font-size: 16px; color: var(--paper); background: var(--magenta); padding: 15px 28px; }
  .btn-primary:hover { background: var(--magenta-hover); }
  .btn-outline { font-size: 16px; color: var(--ink); background: transparent; border: 1.5px solid var(--ink); padding: 13.5px 28px; }
  .btn-outline:hover { background: var(--tint); }
  .link-accent { font-weight: 600; font-size: 15px; color: var(--magenta); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
  .link-accent:hover { color: var(--magenta-hover); }

  .card { background: var(--card); border: 1px solid var(--border); border-radius: 14px; }

  .section-head {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: 24px; flex-wrap: wrap;
  }
  .section-head .titles { display: flex; flex-direction: column; gap: 12px; max-width: 640px; }

  /* ---- Logo lockup ---- */
  .logo { display: inline-flex; align-items: center; gap: 11px; text-decoration: none; }
  .logo-word { font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); }
  .logo-cluster { display: inline-flex; gap: 4px; align-items: center; }
  .logo-tag { font-size: 13px; color: var(--caption); border-left: 1px solid var(--border2); padding-left: 11px; }

  /* ---- Navigation ---- */
  .nav { position: sticky; top: 0; z-index: 50; background: var(--paper); border-bottom: 1px solid var(--border); }
  .nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding: 16px 32px; max-width: var(--maxw); margin: 0 auto; }
  .nav-links { display: flex; align-items: center; gap: 28px; }
  .nav-links a { font-size: 15px; font-weight: 500; color: var(--muted2); text-decoration: none; transition: color .15s ease; }
  .nav-links a:hover { color: var(--magenta); }
  .nav-cta { font-size: 15px; font-weight: 600; color: #FFFFFF; background: var(--magenta); border-radius: 10px; padding: 11px 20px; text-decoration: none; transition: background .15s ease; }
  .nav-cta:hover { background: var(--magenta-hover); }
  .hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; }
  .hamburger span { width: 24px; height: 2px; background: var(--ink); border-radius: 2px; }

  /* ---- Hero ---- */
  .hero { border-bottom: 1px solid var(--border); }
  .hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; padding: 80px 32px 72px; max-width: var(--maxw); margin: 0 auto; }
  .hero-col { display: flex; flex-direction: column; gap: 24px; }
  .hero h1 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 58px; line-height: 1.08; color: var(--ink); text-wrap: pretty; }
  .hero-sub { margin: 0; font-size: 18px; line-height: 1.55; color: var(--muted); max-width: 48ch; }
  .hero-btns { display: flex; gap: 12px; flex-wrap: wrap; }
  .hero-stats { display: flex; gap: 28px; flex-wrap: wrap; margin-top: 8px; }
  .stat { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 500; color: var(--muted); }
  .hero-media { position: relative; }
  .hero-media img { width: 100%; height: 440px; object-fit: cover; border-radius: 14px; border: 1px solid var(--border2); }
  .hero-deco-1 { position: absolute; top: -18px; right: -14px; width: 52px; height: 52px; background: var(--yellow); }
  .hero-deco-2 { position: absolute; bottom: -14px; left: -12px; width: 30px; height: 30px; background: var(--magenta); }

  /* ---- Generic section ---- */
  .sec { border-bottom: 1px solid var(--border); }
  .sec-inner { padding: 80px 32px; display: flex; flex-direction: column; gap: 40px; max-width: var(--maxw); margin: 0 auto; }

  /* ---- Nutzen ---- */
  .benefits { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
  .benefit { padding: 26px; display: flex; flex-direction: column; gap: 14px; border-radius: 12px; }
  .benefit-dots { display: inline-flex; align-items: flex-end; gap: 4px; height: 26px; }
  .benefit h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 20px; color: var(--ink); }

  .tabs-card { padding: 36px; display: flex; flex-direction: column; gap: 24px; }
  .tabs-head { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; }
  .tabs-label { font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); }
  .tablist { display: flex; gap: 8px; flex-wrap: wrap; }
  .tab {
    font-family: var(--sans); font-weight: 600; font-size: 14.5px;
    border: 1.5px solid var(--ink); border-radius: 999px; padding: 9px 18px;
    cursor: pointer; background: transparent; color: var(--ink); transition: background .15s ease, color .15s ease;
  }
  .tab[aria-selected="true"] { background: var(--ink); color: var(--paper); }
  .tabpanel { display: flex; flex-direction: column; gap: 18px; align-items: flex-start; }
  .tabpanel[hidden] { display: none; }
  .tabpanel p { margin: 0; font-size: 17px; line-height: 1.6; color: var(--muted2); max-width: 70ch; }

  /* ---- Angebote ---- */
  .offers { display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 18px; }
  .offer { border-radius: 14px; padding: 36px; display: flex; flex-direction: column; gap: 18px; justify-content: space-between; }
  .offer .top { display: flex; flex-direction: column; gap: 16px; }
  .offer h3 { margin: 0; font-family: var(--serif); font-weight: 600; line-height: 1.2; }
  .offer p { margin: 0; font-size: 15px; line-height: 1.55; }
  .badge { align-self: flex-start; font-size: 13px; font-weight: 600; border-radius: 999px; padding: 6px 13px; }
  .offer-feature { background: var(--magenta); }
  .offer-feature h3 { font-size: 30px; line-height: 1.15; color: var(--paper); }
  .offer-feature p { font-size: 16px; color: var(--magenta-tint); }
  .offer-feature .badge { color: var(--ink); background: var(--yellow); }
  .offer-feature .btn-light { align-self: flex-start; font-size: 15px; color: var(--magenta); background: var(--paper); border-radius: 10px; padding: 13px 24px; text-decoration: none; font-weight: 600; transition: background .15s ease; }
  .offer-feature .btn-light:hover { background: #FFFFFF; }
  .offer-white { background: var(--card); border: 1px solid var(--border); }
  .offer-white h3 { font-size: 24px; color: var(--ink); }
  .offer-white p { color: var(--muted); }
  .offer-dark { background: var(--dark); }
  .offer-dark h3 { font-size: 24px; color: var(--paper); }
  .offer-dark p { color: var(--dark-muted); }
  .offer-dark .badge { color: var(--paper); border: 1px solid var(--dark-border); }
  .offer-dark a { font-weight: 600; font-size: 15px; color: var(--yellow); text-decoration: none; }
  .three-dots { display: inline-flex; gap: 4px; }

  /* ---- Team ---- */
  .team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .member { padding: 22px; display: flex; flex-direction: column; gap: 18px; }
  .member img { width: 100%; height: 260px; object-fit: cover; border-radius: 10px; }
  .member .meta { display: flex; flex-direction: column; gap: 6px; }
  .member h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); }
  .member .role { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--magenta); }
  .member p { margin: 8px 0 0; font-size: 15px; line-height: 1.55; color: var(--muted); }

  /* ---- Partner & Testimonials ---- */
  .proof-inner { padding: 80px 32px; display: flex; flex-direction: column; gap: 56px; max-width: var(--maxw); margin: 0 auto; }
  .partner-block { display: flex; flex-direction: column; gap: 24px; }
  .partner-label { text-align: center; }
  .partner-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; }
  .partner-cell { height: 64px; border-radius: 8px; background: var(--tint); display: flex; align-items: center; justify-content: center; color: var(--caption); }
  .testimonials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .testimonial { padding: 30px; display: flex; flex-direction: column; gap: 20px; justify-content: space-between; }
  .testimonial blockquote { margin: 0; font-family: var(--serif); font-style: italic; font-size: 19px; line-height: 1.5; color: var(--ink); }
  .testimonial .who { display: flex; align-items: center; gap: 14px; }
  .testimonial .who img { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; flex: none; }
  .testimonial .who .name { font-weight: 600; font-size: 14.5px; color: var(--ink); }
  .testimonial .who .sub { font-size: 13px; color: var(--caption); }

  /* ---- Dark band ---- */
  .dark-band { background: var(--dark); }
  .dark-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; padding: 72px 32px; max-width: var(--maxw); margin: 0 auto; }
  .dark-col { display: flex; flex-direction: column; gap: 18px; }
  .dark-col .eyebrow { color: var(--dark-muted); }
  .dark-col h2 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 34px; line-height: 1.2; color: var(--paper); }
  .dark-col p { margin: 0; font-size: 16px; line-height: 1.6; color: var(--dark-muted2); }
  .dark-links { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
  .dark-links a { font-weight: 600; font-size: 15px; color: var(--yellow); text-decoration: none; }
  .values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .value { border: 1px solid var(--dark-border); border-radius: 12px; padding: 22px; display: flex; flex-direction: column; gap: 10px; }
  .value .label { font-family: var(--serif); font-weight: 600; font-size: 19px; color: var(--paper); }
  .value p { margin: 0; font-size: 13.5px; line-height: 1.5; color: var(--dark-muted); }

  /* ---- CTA band ---- */
  .cta-band { background: var(--yellow); }
  .cta-inner { padding: 72px 32px; display: flex; flex-direction: column; align-items: center; gap: 22px; text-align: center; max-width: var(--maxw); margin: 0 auto; }
  .cta-inner h2 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 42px; line-height: 1.15; color: var(--ink); max-width: 22ch; text-wrap: pretty; }
  .cta-inner p { margin: 0; font-size: 17px; line-height: 1.55; color: var(--yellow-text); max-width: 56ch; }
  .cta-btns { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }
  .cta-band .btn-outline:hover { background: var(--yellow-hover); }

  /* ---- Footer ---- */
  .footer { background: var(--paper); border-top: 1px solid var(--border); }
  .footer-inner { padding: 64px 32px 32px; display: flex; flex-direction: column; gap: 48px; max-width: var(--maxw); margin: 0 auto; }
  .footer-cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.3fr; gap: 40px; }
  .footer-col { display: flex; flex-direction: column; gap: 12px; }
  .footer-brand { display: flex; flex-direction: column; gap: 14px; }
  .footer-brand .row { display: flex; align-items: center; gap: 10px; }
  .footer-word { font-family: var(--serif); font-weight: 600; font-size: 20px; color: var(--ink); }
  .footer-blurb { margin: 0; font-size: 14px; line-height: 1.55; color: var(--caption); max-width: 36ch; }
  .footer-col .head { font-size: 13px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--caption); }
  .footer-col a { font-size: 14.5px; color: var(--muted2); text-decoration: none; }
  .footer-col a:hover { color: var(--magenta); }
  .footer-linkedin { font-weight: 600; font-size: 14px; color: var(--muted2); text-decoration: none; }
  .news-blurb { margin: 0; font-size: 14px; line-height: 1.5; color: var(--caption); }
  .news-form { display: flex; gap: 8px; }
  .news-form input { flex: 1; min-width: 0; font-family: var(--sans); font-size: 14.5px; color: var(--ink); background: var(--card); border: 1px solid var(--border2); border-radius: 10px; padding: 12px 14px; outline: none; }
  .news-form input:focus-visible { border-color: var(--magenta); }
  .news-form button { font-weight: 600; font-size: 14.5px; color: var(--paper); background: var(--ink); border: none; border-radius: 10px; padding: 12px 18px; cursor: pointer; }
  .news-msg { font-size: 13px; min-height: 1em; }
  .news-msg.ok { color: var(--teal); }
  .news-msg.err { color: var(--magenta); }
  .footer-bottom { border-top: 1px solid var(--border); padding-top: 24px; display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; }
  .footer-bottom span { font-size: 13px; color: var(--caption); }

  /* ---- Focus visibility ---- */
  a:focus-visible, button:focus-visible, input:focus-visible {
    outline: 2px solid var(--magenta); outline-offset: 2px; border-radius: 4px;
  }

  /* ---- Mobile menu panel ---- */
  .mobile-menu { display: none; }

  /* ===== Responsive ===== */
  @media (max-width: 980px) {
    .hero-grid { grid-template-columns: 1fr; gap: 40px; }
    .hero h1 { font-size: 46px; }
    .hero-media img { height: 360px; }
    .benefits { grid-template-columns: repeat(2, 1fr); }
    .offers { grid-template-columns: 1fr; }
    .team-grid { grid-template-columns: 1fr; }
    .testimonials { grid-template-columns: 1fr; }
    .partner-grid { grid-template-columns: repeat(3, 1fr); }
    .dark-grid { grid-template-columns: 1fr; gap: 40px; }
    .footer-cols { grid-template-columns: 1fr 1fr; }
    .h2 { font-size: 34px; }
    .cta-inner h2 { font-size: 34px; }
  }

  @media (max-width: 820px) {
    .nav-links { display: none; }
    .hamburger { display: flex; }
    .mobile-menu.open { display: flex; flex-direction: column; gap: 4px; padding: 8px 32px 20px; border-bottom: 1px solid var(--border); background: var(--paper); }
    .mobile-menu a { padding: 10px 0; font-size: 16px; font-weight: 500; color: var(--muted2); text-decoration: none; border-bottom: 1px solid var(--border); }
    .mobile-menu a.cta { color: var(--magenta); font-weight: 600; border-bottom: none; }
  }

  @media (max-width: 560px) {
    .wrap, .nav-inner, .hero-grid, .sec-inner, .proof-inner, .dark-grid, .cta-inner, .footer-inner { padding-left: 20px; padding-right: 20px; }
    .benefits { grid-template-columns: 1fr; }
    .partner-grid { grid-template-columns: repeat(2, 1fr); }
    .footer-cols { grid-template-columns: 1fr; }
    .hero h1 { font-size: 38px; }
    .footer-bottom { flex-direction: column; gap: 8px; }
  }

  @media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    * { transition: none !important; }
  }

  /* ============================================================
     SUBPAGE COMPONENTS
     ============================================================ */

  /* ---- Page hero (subpages) ---- */
  .page-hero { border-bottom: 1px solid var(--border); }
  .page-hero-inner { max-width: var(--maxw); margin: 0 auto; padding: 56px 32px 64px; display: flex; flex-direction: column; gap: 20px; }
  .breadcrumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--caption); flex-wrap: wrap; }
  .breadcrumb a { color: var(--caption); text-decoration: none; }
  .breadcrumb a:hover { color: var(--magenta); }
  .breadcrumb span { color: var(--border2); }
  .page-hero h1 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 50px; line-height: 1.1; color: var(--ink); text-wrap: pretty; max-width: 18ch; }
  .page-hero .sub { margin: 0; font-size: 18px; line-height: 1.55; color: var(--muted); max-width: 60ch; }
  .page-hero .hero-btns { margin-top: 4px; }

  /* ---- Generic prose / two-col content ---- */
  .lead-lg { margin: 0; font-size: 17px; line-height: 1.6; color: var(--muted2); max-width: 70ch; }
  .twocol { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: start; }
  .twocol-13 { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 56px; align-items: start; }

  /* ---- Audience navigator cards ---- */
  .audience-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .audience-card { padding: 30px; display: flex; flex-direction: column; gap: 12px; border-radius: 14px; }
  .audience-card .tag { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--magenta); }
  .audience-card h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); }
  .audience-card p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--muted); flex: 1; }
  .audience-card a { margin-top: 6px; }

  /* ---- Numbered module / step cards ---- */
  .modules { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .module { padding: 28px; display: flex; flex-direction: column; gap: 12px; border-radius: 14px; position: relative; }
  .module .num { display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 50%; background: var(--magenta); color: var(--paper); font-family: var(--serif); font-weight: 600; font-size: 16px; }
  .module h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 20px; color: var(--ink); }
  .module p { margin: 0; font-size: 15px; line-height: 1.55; color: var(--muted); }
  .module.tbd { border-style: dashed; }
  .module .tbd-note { font-size: 12.5px; color: var(--ocher); font-weight: 600; }

  /* ---- Info tiles (Ablauf / Termine / Preise) ---- */
  .info-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .info-tile { padding: 28px; display: flex; flex-direction: column; gap: 8px; border-radius: 14px; }
  .info-tile .k { font-size: 13px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--caption); }
  .info-tile .v { font-family: var(--serif); font-weight: 600; font-size: 24px; color: var(--ink); line-height: 1.2; }
  .info-tile p { margin: 0; font-size: 14px; line-height: 1.5; color: var(--muted); }

  /* ---- Pricing / booking band ---- */
  .booking { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 18px; }
  .booking-main { background: var(--magenta); border-radius: 14px; padding: 36px; display: flex; flex-direction: column; gap: 16px; justify-content: space-between; }
  .booking-main h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 28px; color: var(--paper); }
  .booking-main p { margin: 0; font-size: 16px; line-height: 1.55; color: var(--magenta-tint); }
  .booking-main .price { font-family: var(--serif); font-size: 22px; color: var(--paper); }
  .booking-aside { background: var(--card); border: 1px solid var(--border); border-radius: 14px; padding: 36px; display: flex; flex-direction: column; gap: 14px; }
  .booking-aside h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 20px; color: var(--ink); }
  .checklist { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
  .checklist li { display: flex; align-items: flex-start; gap: 10px; font-size: 15px; line-height: 1.5; color: var(--muted); }
  .checklist li::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--teal); margin-top: 7px; flex: none; }

  /* ---- FAQ accordion ---- */
  .faq { display: flex; flex-direction: column; gap: 12px; max-width: 820px; }
  .faq details { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 4px 22px; }
  .faq summary { list-style: none; cursor: pointer; padding: 18px 0; font-family: var(--serif); font-weight: 600; font-size: 18px; color: var(--ink); display: flex; justify-content: space-between; align-items: center; gap: 16px; }
  .faq summary::-webkit-details-marker { display: none; }
  .faq summary::after { content: "+"; font-family: var(--sans); font-weight: 400; font-size: 24px; color: var(--magenta); flex: none; line-height: 1; }
  .faq details[open] summary::after { content: "–"; }
  .faq details p { margin: 0 0 18px; font-size: 15.5px; line-height: 1.6; color: var(--muted); }

  /* ---- Filter pills (blog categories / offers) ---- */
  .filters { display: flex; gap: 10px; flex-wrap: wrap; }
  .filter { font-family: var(--sans); font-weight: 600; font-size: 14px; border: 1.5px solid var(--border2); border-radius: 999px; padding: 8px 16px; cursor: pointer; background: transparent; color: var(--muted2); transition: border-color .15s, color .15s; }
  .filter[aria-pressed="true"] { border-color: var(--ink); color: var(--ink); background: var(--tint); }
  .filter:hover { border-color: var(--ink); }

  /* ---- Blog / post cards ---- */
  .blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .post-card { display: flex; flex-direction: column; overflow: hidden; border-radius: 14px; }
  .post-card .thumb { width: 100%; height: 180px; object-fit: cover; background: var(--tint); }
  .post-card .body { padding: 24px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
  .cat-tag { align-self: flex-start; font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--magenta); background: var(--magenta-tint); border-radius: 999px; padding: 4px 11px; }
  .post-card h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 20px; line-height: 1.25; color: var(--ink); }
  .post-card .excerpt { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--muted); flex: 1; }
  .post-meta { font-size: 13px; color: var(--caption); display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

  /* ---- Author cards ---- */
  .authors { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .author { padding: 22px; display: flex; align-items: center; gap: 16px; border-radius: 14px; }
  .author img { width: 64px; height: 64px; border-radius: 50%; object-fit: cover; flex: none; }
  .author .name { font-family: var(--serif); font-weight: 600; font-size: 18px; color: var(--ink); }
  .author .role { font-size: 13px; color: var(--magenta); font-weight: 600; }

  /* ---- Team detail (large) ---- */
  .person { display: grid; grid-template-columns: 0.7fr 1.3fr; gap: 40px; align-items: start; padding: 40px; border-radius: 16px; }
  .person img { width: 100%; height: 340px; object-fit: cover; border-radius: 12px; }
  .person .bio { display: flex; flex-direction: column; gap: 12px; }
  .person h2 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 30px; color: var(--ink); }
  .person .role { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--magenta); }
  .person p { margin: 0; font-size: 15.5px; line-height: 1.65; color: var(--muted); }
  .person.flip { grid-template-columns: 1.3fr 0.7fr; }
  .person.flip .img-wrap { order: 2; }

  /* ---- Tinted section variant ---- */
  .sec-tint { background: #FBF6EE; border-bottom: 1px solid var(--border); }

  /* ---- Note / placeholder banner ---- */
  .draft-note { font-size: 13px; color: var(--ocher); background: #FBF3E4; border: 1px dashed var(--ocher); border-radius: 8px; padding: 10px 14px; }

  /* ---- Subpage responsive ---- */
  @media (max-width: 980px) {
    .page-hero h1 { font-size: 40px; }
    .twocol, .twocol-13 { grid-template-columns: minmax(0, 1fr); gap: 32px; }
    .audience-cards { grid-template-columns: 1fr; }
    .modules { grid-template-columns: 1fr; }
    .info-grid { grid-template-columns: 1fr; }
    .booking { grid-template-columns: 1fr; }
    .blog-grid { grid-template-columns: 1fr; }
    .authors { grid-template-columns: 1fr; }
    .person, .person.flip { grid-template-columns: 1fr; gap: 24px; }
    .person.flip .img-wrap { order: 0; }
    .person img { height: 300px; }
  }
  @media (max-width: 560px) {
    .page-hero-inner { padding-left: 20px; padding-right: 20px; }
    .page-hero h1 { font-size: 34px; }
    .person { padding: 24px; }
    .values { grid-template-columns: 1fr; }
    .dark-grid { padding-left: 20px; padding-right: 20px; }
  }

  /* ============================================================
     UMBAU: Landing-Page-Bausteine (Story-Branding, Buchung, Signup)
     ============================================================ */

  /* Story-Branding: Held → Guide → Hafen */
  .story { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .story-step { padding: 30px; border-radius: 14px; display: flex; flex-direction: column; gap: 12px; }
  .story-step .role-tag { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--magenta); }
  .story-step h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 22px; color: var(--ink); }
  .story-step p { margin: 0; font-size: 15px; line-height: 1.6; color: var(--muted); }
  .story-step.hafen { background: var(--dark); }
  .story-step.hafen .role-tag { color: var(--yellow); }
  .story-step.hafen h3 { color: var(--paper); }
  .story-step.hafen p { color: var(--dark-muted2); }

  /* Voraussetzungen */
  .req { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
  .req-card { padding: 28px; border-radius: 14px; display: flex; flex-direction: column; gap: 12px; }
  .req-card h3 { margin: 0; font-family: var(--serif); font-weight: 600; font-size: 20px; color: var(--ink); }
  .req-card p { margin: 0; font-size: 15px; line-height: 1.6; color: var(--muted); }

  /* Buchung */
  .booking-embed { border: 1.5px dashed var(--border2); border-radius: 14px; background: #FBF6EE; padding: 40px 28px; text-align: center; display: flex; flex-direction: column; gap: 10px; align-items: center; }
  .booking-embed .placeholder-label { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ocher); }
  .booking-embed p { margin: 0; font-size: 15px; color: var(--muted); max-width: 54ch; }
  .termine { display: flex; flex-direction: column; gap: 12px; }
  .termin { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 22px; border: 1px solid var(--border); border-radius: 12px; background: var(--card); flex-wrap: wrap; }
  .termin .when { font-family: var(--serif); font-weight: 600; font-size: 18px; color: var(--ink); }
  .termin .where { font-size: 14px; color: var(--caption); }
  .pay-note { font-size: 14px; line-height: 1.6; color: var(--muted); max-width: 60ch; }
  .pay-badges { display: flex; gap: 10px; flex-wrap: wrap; }
  .pay-badge { font-size: 13px; font-weight: 600; color: var(--muted2); border: 1px solid var(--border2); border-radius: 999px; padding: 6px 13px; }

  /* Signup (Community-Call, Newsletter) */
  .signup { display: flex; flex-direction: column; gap: 8px; max-width: 460px; }

  /* Trainings-Liste (4 Karten, 2x2) */
  .trainings-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
  @media (max-width: 760px) { .trainings-grid { grid-template-columns: 1fr; } }

  /* Lead-Magnet (KI-Score) */
  .leadmagnet { background: var(--yellow); border-radius: 16px; padding: 40px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 32px; align-items: center; }
  .leadmagnet h3 { margin: 0 0 10px; font-family: var(--serif); font-weight: 600; font-size: 28px; color: var(--ink); }
  .leadmagnet p { margin: 0; font-size: 16px; line-height: 1.6; color: var(--yellow-text); }
  .leadmagnet .lm-cta { display: flex; justify-content: flex-end; }
  .cta-band .btn-dark { font-size: 16px; color: var(--paper); background: var(--ink); padding: 15px 28px; }
  .cta-band .btn-dark:hover { background: #1f191b; }

  @media (max-width: 980px) {
    .story { grid-template-columns: 1fr; }
    .req { grid-template-columns: 1fr; }
    .leadmagnet { grid-template-columns: 1fr; gap: 20px; padding: 32px; }
    .leadmagnet .lm-cta { justify-content: flex-start; }
  }

  /* ============================================================
     LEBENDIGKEIT: Scroll-Reveal, Hover-Mikrointeraktionen, Nav-Schatten
     Tiefe über Schatten (keine Gradienten/Blur). Bewegung = Lebendigkeit.
     ============================================================ */

  /* ---- Scroll-Reveal (nur aktiv mit JS via .js-anim → kein FOUC ohne JS) ---- */
  .js-anim :is(
    .page-hero-inner > *, .hero-col > *, .hero-media, .titles,
    .benefit, .offer, .audience-card, .story-step, .module, .info-tile, .req-card,
    .termin, .booking-main, .booking-aside, .booking-embed, .person, .value,
    .partner-cell, .testimonial, .post-card, .author, .leadmagnet,
    .dark-col > *, .cta-inner > *
  ) {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 1s cubic-bezier(.16, 1, .3, 1), transform 1s cubic-bezier(.16, 1, .3, 1);
  }
  .js-anim :is(
    .page-hero-inner > *, .hero-col > *, .hero-media, .titles,
    .benefit, .offer, .audience-card, .story-step, .module, .info-tile, .req-card,
    .termin, .booking-main, .booking-aside, .booking-embed, .person, .value,
    .partner-cell, .testimonial, .post-card, .author, .leadmagnet,
    .dark-col > *, .cta-inner > *
  ).is-visible {
    opacity: 1;
    transform: none;
  }
  /* schon beim Laden sichtbare Elemente sofort zeigen (kein Flackern) */
  .js-anim .reveal-instant { transition: none !important; }

  /* ---- Hover-Mikrointeraktionen ---- */
  .card, .offer-white, .offer-feature, .offer-dark, .value, .leadmagnet, .termin, .partner-cell {
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  }
  /* helle, umrandete Karten: anheben + getönter Glow + Akzent-Rand */
  .card:hover, .offer-white:hover, .termin:hover {
    transform: translateY(-6px);
    box-shadow: 0 24px 48px -20px rgba(46, 37, 40, .32), 0 8px 18px -8px rgba(192, 0, 112, .2);
    border-color: var(--magenta);
  }
  /* farbige/dunkle Karten: anheben + weicher Schatten, kein Akzent-Rand */
  .offer-feature:hover { transform: translateY(-6px); box-shadow: 0 26px 52px -20px rgba(192, 0, 112, .5); }
  .offer-dark:hover, .story-step.hafen:hover { transform: translateY(-6px); box-shadow: 0 26px 52px -20px rgba(46, 37, 40, .55); }
  .value:hover { transform: translateY(-5px); box-shadow: 0 20px 40px -18px rgba(0, 0, 0, .45); border-color: var(--dark-muted); }
  .leadmagnet:hover { transform: translateY(-6px); box-shadow: 0 26px 52px -20px rgba(46, 37, 40, .34); }
  .partner-cell:hover { transform: translateY(-4px); box-shadow: 0 14px 28px -14px rgba(46, 37, 40, .24); }

  /* Buttons */
  .btn, .nav-cta, .btn-light, .btn-dark { transition: background .15s ease, color .15s ease, transform .2s ease, box-shadow .2s ease; }
  .btn-primary:hover { transform: translateY(-1px); box-shadow: 0 10px 22px -10px rgba(192, 0, 112, .55); }
  .btn-outline:hover { transform: translateY(-1px); box-shadow: 0 8px 18px -10px rgba(46, 37, 40, .25); }
  .nav-cta:hover { transform: translateY(-1px); box-shadow: 0 8px 18px -10px rgba(192, 0, 112, .5); }
  .btn-light:hover, .btn-dark:hover { transform: translateY(-1px); box-shadow: 0 8px 18px -10px rgba(46, 37, 40, .3); }

  /* Bilder / Thumbnails: stärker liften */
  .post-card .thumb { transition: transform .35s cubic-bezier(.16, 1, .3, 1); }
  .post-card:hover .thumb { transform: scale(1.05); }
  .person img, .member img, .hero-media img { transition: transform .35s ease, box-shadow .35s ease; }
  .person:hover img, .member:hover img { transform: translateY(-4px); box-shadow: 0 18px 36px -18px rgba(46, 37, 40, .35); }
  .hero-media:hover img { transform: translateY(-4px); box-shadow: 0 18px 36px -18px rgba(46, 37, 40, .3); }

  /* ---- Sticky-Nav: Schatten beim Scrollen (Tiefe) ---- */
  .nav { transition: box-shadow .25s ease; }
  .nav.scrolled { box-shadow: 0 4px 18px -10px rgba(46, 37, 40, .22); }

  /* ---- prefers-reduced-motion: Einblendungen & Hover-Transforms abschalten ---- */
  @media (prefers-reduced-motion: reduce) {
    .js-anim :is(
      .page-hero-inner > *, .hero-col > *, .hero-media, .titles,
      .benefit, .offer, .audience-card, .story-step, .module, .info-tile, .req-card,
      .termin, .booking-main, .booking-aside, .booking-embed, .person, .value,
      .partner-cell, .testimonial, .post-card, .author, .leadmagnet,
      .dark-col > *, .cta-inner > *
    ) { opacity: 1 !important; transform: none !important; }
    .card:hover, .offer-white:hover, .offer-feature:hover, .offer-dark:hover, .story-step.hafen:hover,
    .value:hover, .leadmagnet:hover, .partner-cell:hover, .termin:hover,
    .btn-primary:hover, .btn-outline:hover, .nav-cta:hover, .btn-light:hover, .btn-dark:hover,
    .post-card:hover .thumb, .person:hover img, .member:hover img, .hero-media:hover img {
      transform: none !important;
      box-shadow: none !important;
    }
  }
