/*
Theme Name:   Silke Abt 2026
Template:     kadence
Version:      1.0.0
Description:  Premium Design 2026. Glasmorphismus · Gradient-Hero ·
              Poppins · Pantone-Markenfarben. Kein SVG-Waves.
*/

/* ============================================================
   DESIGN TOKENS
   --global-palette1–8 werden von functions.php via wp_head
   aus den gespeicherten Customizer-Einstellungen generiert.
   ============================================================ */
:root {
  /* ── PALETTE (Fallbacks = Markenfarben Pantone) ─────── */
  --teal-950: #071e1b;
  --teal-900: #0b3835;
  --teal-800: #0d4a46;
  --teal-700: #006358;   /* Pantone 7720 */
  --teal-600: #00796b;
  --teal-500: #009688;
  --teal-400: #26a69a;
  --teal-300: #4db6ac;
  --teal-200: #80cbc4;
  --teal-100: #b2dfdb;
  --teal-50:  #e0f2f1;
  --teal-25:  #f0faf9;

  --navy:      #2E4D58;   /* Pantone 2216 */
  --sage:      #B7CDC2;   /* Pantone 622  */
  --blue-soft: #8394B8;   /* Pantone 2136 */

  /* ── NEUTRALS ───────────────────────────────────────── */
  --cream:    #F5F0EB;
  --cream-2:  #EDE8DF;
  --linen:    #F9F6F2;
  --mist:     #EEF3F2;
  --stone:    #D4CFC8;

  /* ── TEXT ───────────────────────────────────────────── */
  --ink:      #1A1A2E;
  --ink-70:   rgba(26,26,46,.70);
  --ink-40:   rgba(26,26,46,.40);
  --on-dark:  rgba(255,255,255,.92);
  --on-dark-60: rgba(255,255,255,.60);
  --on-dark-30: rgba(255,255,255,.30);

  /* ── GLASS ──────────────────────────────────────────── */
  --glass-white:  rgba(255,255,255,.60);
  --glass-teal:   rgba(0,99,88,.18);
  --glass-dark:   rgba(7,30,27,.55);
  --glass-border: rgba(255,255,255,.22);
  --blur-sm: 12px;
  --blur-md: 20px;
  --blur-lg: 32px;

  /* ── GRADIENTS ──────────────────────────────────────── */
  --grad-hero:    linear-gradient(135deg, #071e1b 0%, #006358 50%, #26a69a 100%);
  --grad-teal:    linear-gradient(135deg, var(--teal-700), var(--teal-400));
  --grad-section: linear-gradient(180deg, var(--cream) 0%, var(--linen) 100%);
  --grad-glass:   linear-gradient(135deg, rgba(255,255,255,.18) 0%, rgba(255,255,255,.04) 100%);
  --grad-number:  linear-gradient(135deg, var(--teal-700), var(--teal-400));

  /* ── SEMANTISCH ─────────────────────────────────────── */
  --success: #2d7a4f; --success-bg: #edf7f1;
  --warning: #b45309; --warning-bg: #fef3c7;
  --info:    #1d4ed8; --info-bg:    #eff6ff;

  /* ── SPACING (4px-Raster) ───────────────────────────── */
  --sp-1:  4px;  --sp-2:  8px;  --sp-3:  12px; --sp-4:  16px;
  --sp-5:  20px; --sp-6:  24px; --sp-8:  32px; --sp-10: 40px;
  --sp-12: 48px; --sp-16: 64px; --sp-20: 80px; --sp-24: 96px;
  --sp-32: 128px;

  /* ── BORDER-RADIUS ──────────────────────────────────── */
  --r-xs:   4px;  --r-sm:   8px;  --r-md:   12px;
  --r-lg:   16px; --r-xl:   24px; --r-2xl:  32px;
  --r-full: 9999px;

  /* ── SHADOWS ────────────────────────────────────────── */
  --sh-xs: 0 1px 3px rgba(7,30,27,.06);
  --sh-sm: 0 2px 8px rgba(7,30,27,.08), 0 1px 3px rgba(7,30,27,.04);
  --sh-md: 0 8px 24px rgba(7,30,27,.10), 0 2px 8px rgba(7,30,27,.05);
  --sh-lg: 0 16px 48px rgba(7,30,27,.14), 0 4px 16px rgba(7,30,27,.06);
  --sh-xl: 0 32px 80px rgba(7,30,27,.18), 0 8px 24px rgba(7,30,27,.08);
  --sh-glass: 0 8px 32px rgba(7,30,27,.14), inset 0 1px 0 rgba(255,255,255,.15);
  --sh-glow:  0 0 48px rgba(0,99,88,.30);

  /* ── TYPE SCALE ─────────────────────────────────────── */
  /* Reduziert: klar und prägnant, nicht überdimensioniert */
  --fs-display: clamp(1.9rem, 3.2vw + .4rem, 3.0rem);   /* Hero H1: max 48px */
  --fs-h1:      clamp(1.6rem, 2.4vw + .2rem, 2.4rem);   /* Page H1: max 38px */
  --fs-h2:      clamp(1.25rem, 1.8vw + .1rem, 1.9rem);  /* Sections: max 30px */
  --fs-h3:      clamp(1.05rem, 1.2vw, 1.3rem);          /* Cards: max 21px */
  --fs-h4:      clamp(.95rem, 1vw, 1.1rem);              /* Labels: max 18px */
  --fs-lg:      clamp(1.0625rem, 1vw + .3rem, 1.125rem);/* Lead: max 18px */
  --fs-body:    clamp(1rem, .8vw + .4rem, 1.0625rem);    /* Body: 16–17px */
  --fs-sm:      clamp(.9375rem, .6vw + .4rem, 1rem);     /* Small: 15–16px */
  --fs-label:   .75rem;
  --fs-caption: .8125rem;

  /* ── EASING ─────────────────────────────────────────── */
  --ease-out:   cubic-bezier(.22,1,.36,1);
  --ease-in:    cubic-bezier(.4,0,1,1);
  --ease-io:    cubic-bezier(.4,0,.2,1);

  /* ── LAYOUT ─────────────────────────────────────────── */
  --max-w:      1200px;
  --max-w-text: 720px;
  --pad-x:      clamp(20px, 5vw, 80px);
  --f:          'Poppins', system-ui, sans-serif;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--f);
  font-size: var(--fs-body);
  font-weight: 400;
  line-height: 1.75;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img, video, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--teal-700); text-decoration: none; transition: color var(--dur-mid,280ms) var(--ease-out); }
a:hover { color: var(--teal-500); }
p { max-width: 68ch; line-height: 1.8; }
strong { font-weight: 600; }

/* ── Skip-Link (Barrierefreiheit) ── */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--sp-4);
  background: var(--teal-700);
  color: #fff;
  padding: var(--sp-3) var(--sp-6);
  border-radius: 0 0 var(--r-md) var(--r-md);
  font-weight: 600;
  font-size: var(--fs-sm);
  z-index: 9999;
  transition: top .2s;
}
.skip-link:focus { top: 0; }

/* ── Fokus-Stile (WCAG 2.2) ── */
:focus-visible {
  outline: 3px solid var(--teal-400);
  outline-offset: 4px;
  border-radius: var(--r-xs);
}
:focus:not(:focus-visible) { outline: none; }

/* ── Reduzierte Bewegung ── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  .sa-reveal { opacity: 1 !important; transform: none !important; }
}

/* ============================================================
   KADENCE OVERRIDES – Layout-Korrekturen
   ============================================================ */
body, .site, .site-main, .entry-content,
#main, .content-area, #primary, .hentry {
  background: var(--cream) !important;
}
.entry-header { display: none !important; }
.site-container, .content-container, .site-content,
.kadence-container, .wp-site-blocks,
.has-global-padding, .entry-content-wrap {
  max-width: none !important;
  padding: 0 !important;
}

/* Direktkinder des Content ohne Margin + Padding */
.entry-content > *,
.page-content > * {
  max-width: none !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* wp:group Blocks: kein automatischer Block-Gap von WordPress */
.wp-block-group {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* wp:html Blöcke */
.wp-block-html {
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: block;
}

/* Gap zwischen Sticky-Header und erster Section entfernen */
#main > *:first-child,
.site-main > *:first-child,
.entry-content > *:first-child {
  margin-top: 0 !important;
}

/* Kein Bottom-Gap nach letztem HTML-Block (CTA) */
.entry-content > *:last-child,
.page-content > *:last-child {
  margin-bottom: 0 !important;
}

/* ============================================================
   TYPOGRAFIE
   ============================================================ */
h1, .sa-h1 {
  font-family: var(--f); font-weight: 800;
  font-size: var(--fs-h1);
  line-height: 1.08; letter-spacing: -.04em;
  color: var(--ink);
}
h2, .sa-h2 {
  font-family: var(--f); font-weight: 700;
  font-size: var(--fs-h2);
  line-height: 1.15; letter-spacing: -.03em;
  color: var(--ink);
}
h3, .sa-h3 {
  font-family: var(--f); font-weight: 600;
  font-size: var(--fs-h3);
  line-height: 1.3; letter-spacing: -.015em;
  color: var(--ink);
}
h4, .sa-h4 {
  font-family: var(--f); font-weight: 600;
  font-size: var(--fs-h4);
  line-height: 1.4;
  color: var(--ink);
}

/* Kicker / Micro-Label */
.sa-kicker {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--teal-700);
}
.sa-kicker::before {
  content: '';
  display: inline-block;
  width: 24px; height: 2px;
  background: var(--grad-teal);
  border-radius: var(--r-full);
  flex-shrink: 0;
}

/* Lead / Intro-Text */
.sa-lead {
  font-size: var(--fs-lg);
  font-weight: 400;
  line-height: 1.75;
  color: var(--ink-70);
  max-width: 60ch;
}

/* On-dark Varianten */
.on-dark h1, .on-dark h2, .on-dark h3, .on-dark h4,
.on-dark .wp-block-heading { color: var(--on-dark) !important; }
.on-dark p, .on-dark .sa-lead { color: var(--on-dark-60); }
.on-dark .sa-kicker { color: var(--teal-200); }
.on-dark .sa-kicker::before { background: var(--teal-200); }

/* ============================================================
   INNER WRAPPER – wiederverwendbarer Inhalts-Container
   ============================================================ */
.sa-inner {
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.sa-inner--narrow {
  max-width: var(--max-w-text);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}

/* ============================================================
   STICKY NAVIGATION
   ============================================================ */
#main-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: rgba(245,240,235,.85) !important;
  backdrop-filter: blur(var(--blur-md));
  -webkit-backdrop-filter: blur(var(--blur-md));
  border-bottom: 1px solid rgba(0,99,88,.10);
  transition: padding .3s var(--ease-io), box-shadow .3s var(--ease-io), background .3s;
}
#main-header.sa-scrolled {
  box-shadow: var(--sh-md);
  background: rgba(245,240,235,.96) !important;
}
#main-header .custom-logo { height: auto; }
#main-header .site-title {
  font-family: var(--f); font-weight: 800;
  font-size: 1.2rem; letter-spacing: -.04em;
  color: var(--teal-900);
}

/* Nav-Links */
#main-header .kadence-navigation a,
#main-header .main-navigation a {
  font-family: var(--f);
  font-size: var(--fs-sm); font-weight: 600;
  letter-spacing: .02em;
  color: var(--ink-70);
  padding: var(--sp-2) var(--sp-3);
  position: relative;
  text-decoration: none;
  transition: color .2s var(--ease-out);
}
/* Underline-Reveal Hover */
#main-header .kadence-navigation a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: var(--sp-3);
  width: calc(100% - 2 * var(--sp-3));
  height: 2px;
  background: var(--grad-teal);
  border-radius: var(--r-full);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .25s var(--ease-out);
}
#main-header .kadence-navigation a:hover,
#main-header .kadence-navigation .current-menu-item > a { color: var(--teal-700); }
#main-header .kadence-navigation a:hover::after,
#main-header .kadence-navigation .current-menu-item > a::after { transform: scaleX(1); }

/* Nav CTA-Button */
.sa-nav-cta {
  background: var(--grad-teal) !important;
  color: #fff !important;
  padding: var(--sp-2) var(--sp-5) !important;
  border-radius: var(--r-full) !important;
  font-weight: 700 !important;
  font-size: var(--fs-sm) !important;
  box-shadow: var(--sh-sm), var(--sh-glow);
  transition: box-shadow .25s var(--ease-out), transform .25s var(--ease-out) !important;
}
.sa-nav-cta::after { display: none !important; }
.sa-nav-cta:hover { transform: translateY(-2px); box-shadow: var(--sh-md), var(--sh-glow); }

/* ============================================================
   BUTTONS
   ============================================================ */
.wp-block-button__link,
.wp-element-button,
.sa-btn {
  font-family: var(--f) !important;
  font-size: var(--fs-sm) !important;
  font-weight: 700 !important;
  letter-spacing: .03em;
  padding: 14px 36px !important;
  border-radius: var(--r-full) !important;
  cursor: pointer;
  transition: all .25s var(--ease-out) !important;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  min-height: 44px; /* Touch-Target */
}

/* Primary */
.wp-block-button:not(.is-style-outline) .wp-block-button__link {
  background: var(--grad-teal) !important;
  color: #fff !important;
  border: 2px solid transparent !important;
  box-shadow: var(--sh-sm), 0 0 0 0 rgba(0,99,88,0);
}
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-md), var(--sh-glow);
}

/* Outline / Ghost */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--teal-700) !important;
  border: 2px solid var(--teal-700) !important;
}
.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--teal-700) !important;
  color: #fff !important;
  transform: translateY(-3px);
}

/* Ghost on Dark */
.sa-btn-ghost-dark {
  background: transparent !important;
  color: var(--on-dark) !important;
  border: 2px solid rgba(255,255,255,.35) !important;
  backdrop-filter: blur(var(--blur-sm));
}
.sa-btn-ghost-dark:hover {
  background: rgba(255,255,255,.12) !important;
  border-color: rgba(255,255,255,.6) !important;
  transform: translateY(-3px);
}

/* Glass Button (auf dunklem Hintergrund – primär) */
.sa-btn-glass {
  background: rgba(255,255,255,.15) !important;
  backdrop-filter: blur(var(--blur-sm));
  color: #fff !important;
  border: 1.5px solid var(--glass-border) !important;
  box-shadow: var(--sh-glass);
}
.sa-btn-glass:hover {
  background: rgba(255,255,255,.25) !important;
  transform: translateY(-3px);
  box-shadow: var(--sh-lg);
}

/* ============================================================
   SECTION-SYSTEM
   Gradient-Übergänge statt SVG-Waves.
   Mehr vertikaler Abstand für klare visuelle Trennung.
   ============================================================ */
.sa-section {
  padding-top: clamp(72px, 9vw, 128px);
  padding-bottom: clamp(72px, 9vw, 128px);
  position: relative;
}
.sa-section--sm {
  padding-top: clamp(48px, 6vw, 88px);
  padding-bottom: clamp(48px, 6vw, 88px);
}

/* Sektionen mit gleichem Hintergrund erhalten einen subtilen Trenner */
.sa-bg-cream + .sa-bg-cream,
.sa-bg-linen + .sa-bg-linen {
  border-top: 1px solid var(--stone);
}

/* Abstand zwischen wp:group Blöcken mit unterschiedlichem BG */
.wp-block-group.sa-bg-linen + .wp-block-group.sa-bg-cream,
.wp-block-group.sa-bg-cream + .wp-block-group.sa-bg-linen {
  /* sanfter visueller Wechsel – kein border nötig */
}

/* Background-Varianten */
.sa-bg-cream    { background: var(--cream); }
.sa-bg-linen    { background: var(--linen); }
.sa-bg-mist     { background: var(--mist); }
.sa-bg-gradient { background: var(--grad-section); }

/* Dunkle Sections */
.sa-bg-dark {
  background: linear-gradient(160deg, var(--teal-950) 0%, var(--teal-900) 50%, var(--navy) 100%);
  color: var(--on-dark);
  position: relative;
  overflow: hidden;
}
.sa-bg-dark::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 15% 40%, rgba(0,150,136,.25) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 85% 70%, rgba(46,77,88,.4) 0%, transparent 60%);
  pointer-events: none;
}
.sa-bg-dark > * { position: relative; z-index: 1; }

/* Gradient-Übergang nach unten (kein harter Schnitt) */
.sa-section--fade-down::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 80px;
  background: linear-gradient(to bottom, transparent, var(--cream));
  pointer-events: none;
}
.sa-bg-dark.sa-section--fade-down::after {
  background: linear-gradient(to bottom, transparent, var(--cream));
}

/* ============================================================
   HERO – GRADIENT MIT SPLIT (S-01)
   ============================================================ */
.sa-hero-main {
  background: var(--grad-hero);
  /* min-height reduziert – war 100svh, wirkte zu dominant */
  min-height: 80svh;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding-top: clamp(64px, 8vw, 100px);
  padding-bottom: clamp(64px, 8vw, 100px);
  /* Gap zwischen Header und Hero entfernen */
  margin-top: 0 !important;
}

/* Animierter Gradient-Hintergrund */
@keyframes gradientShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.sa-hero-main {
  background-size: 200% 200%;
  animation: gradientShift 20s ease infinite;
}

/* Dekorative Radial-Highlights */
.sa-hero-main::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 10% 30%, rgba(0,150,136,.35) 0%, transparent 55%),
    radial-gradient(ellipse 50% 60% at 85% 75%, rgba(7,30,27,.6) 0%, transparent 55%);
  pointer-events: none;
}

/* Hero-Inhalt */
.sa-hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: clamp(40px, 6vw, 96px);
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  position: relative;
  z-index: 2;
  width: 100%;
}

.sa-hero-text { max-width: 560px; }
.sa-hero-text h1 {
  font-size: var(--fs-display);
  color: var(--on-dark);
  letter-spacing: -.04em;
  line-height: 1.05;
  margin-bottom: var(--sp-5);
  text-shadow: 0 2px 20px rgba(7,30,27,.3);
}
.sa-hero-text .sa-lead {
  color: rgba(255,255,255,.72);
  margin-bottom: var(--sp-8);
  max-width: 52ch;
  font-size: var(--fs-body);
}

.sa-hero-btns { display: flex; gap: var(--sp-4); flex-wrap: wrap; }

/* Hero-Bild / Glass-Card */
.sa-hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
}
.sa-hero-visual img {
  width: 100%;
  max-width: 460px;
  aspect-ratio: 3/4;
  object-fit: cover;
  border-radius: var(--r-2xl);
  filter: grayscale(100%);
  mix-blend-mode: luminosity;
  opacity: .75;
}
/* Teal-Overlay auf Bild */
.sa-hero-visual::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-2xl);
  background: linear-gradient(160deg, rgba(0,99,88,.45) 0%, rgba(0,150,136,.2) 100%);
  max-width: 460px;
  margin: 0 auto;
}

/* Badge-Ring (rotierender Text) */
.sa-badge-ring {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 120px;
  height: 120px;
  z-index: 3;
}
.sa-badge-ring svg { animation: spin 18s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.sa-badge-ring-center {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  margin: auto;
  background: var(--grad-teal);
  border-radius: 50%;
  box-shadow: var(--sh-glow);
}

/* Scroll-Indikator */
.sa-scroll-hint {
  position: absolute;
  bottom: var(--sp-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
  color: var(--on-dark-30);
  font-size: var(--fs-label);
  letter-spacing: .12em;
  text-transform: uppercase;
  animation: scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce {
  0%,100% { transform: translateX(-50%) translateY(0); }
  50%      { transform: translateX(-50%) translateY(8px); }
}
.sa-scroll-hint::after {
  content: '';
  width: 1px;
  height: 40px;
  background: linear-gradient(to bottom, var(--on-dark-30), transparent);
}

/* ============================================================
   HERO UNTERSEITEN – Split, heller Hintergrund (S-09)
   ============================================================ */
.sa-hero-sub {
  background: var(--linen);
  padding-top: clamp(48px, 6vw, 80px);
  padding-bottom: clamp(48px, 6vw, 80px);
  position: relative;
  overflow: hidden;
  /* Direkt nach Header ohne Gap */
  margin-top: 0 !important;
}
.sa-hero-sub::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 80% at -10% 50%, rgba(0,99,88,.06) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 110% 50%, rgba(183,205,194,.15) 0%, transparent 60%);
  pointer-events: none;
}

.sa-hero-sub-inner {
  display: grid;
  grid-template-columns: 55% 1fr;
  align-items: center;
  gap: clamp(32px, 5vw, 72px);
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
  position: relative;
  z-index: 1;
}

.sa-hero-sub-text h1 {
  color: var(--ink);
  margin-bottom: var(--sp-4);
  /* Explizit begrenzen damit kein Überlauf */
  font-size: clamp(1.5rem, 2.8vw + .2rem, 2.2rem);
  line-height: 1.1;
}
.sa-hero-sub-text .sa-lead {
  margin-bottom: var(--sp-6);
  font-size: var(--fs-body);
}

/* Kategorie-Dot Marker */
.sa-cat-dot {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.sa-cat-dot::before {
  content: '';
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--grad-teal);
  box-shadow: var(--sh-glow);
  flex-shrink: 0;
}

/* Bild Unterseiten */
.sa-hero-sub-img {
  position: relative;
}
.sa-hero-sub-img img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: var(--r-xl);
  filter: grayscale(80%);
  box-shadow: var(--sh-xl);
}
.sa-hero-sub-img::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-xl);
  background: linear-gradient(160deg, rgba(0,99,88,.3) 0%, rgba(183,205,194,.15) 100%);
  z-index: 1;
}

/* Glassmorphismus-Overlay Karte */
.sa-glass-card {
  background: var(--glass-white);
  backdrop-filter: blur(var(--blur-md));
  -webkit-backdrop-filter: blur(var(--blur-md));
  border: 1px solid var(--glass-border);
  border-radius: var(--r-xl);
  padding: var(--sp-6) var(--sp-8);
  box-shadow: var(--sh-glass);
}
.sa-glass-card--dark {
  background: var(--glass-dark);
  border-color: rgba(255,255,255,.10);
}
.sa-glass-card--teal {
  background: rgba(0,99,88,.15);
  border-color: rgba(0,150,136,.25);
}

/* ============================================================
   TRUST BAR (S-02)
   ============================================================ */
.sa-trust-bar {
  background: #fff;
  border-top: 1px solid var(--stone);
  border-bottom: 1px solid var(--stone);
  padding: clamp(20px, 3vw, 32px) 0;
}
.sa-trust-bar-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(var(--sp-8), 4vw, var(--sp-16));
  flex-wrap: wrap;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 var(--pad-x);
}
.sa-trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  text-align: center;
}
.sa-trust-item-number {
  font-size: clamp(1.1rem, 1.6vw, 1.5rem);
  font-weight: 800;
  letter-spacing: -.03em;
  background: var(--grad-teal);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.1;
}
.sa-trust-item-label {
  font-size: .7rem;
  font-weight: 500;
  color: var(--ink-40);
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
}

/* ============================================================
   LEISTUNGS-KARTEN (S-03)
   2×2 Grid für exakt 4 Karten – kein Orphan
   ============================================================ */
.sa-cards-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-5);
}
/* Ab 900px: alle 4 nebeneinander wenn Platz */
@media (min-width: 1100px) {
  .sa-cards-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.sa-card {
  background: #fff;
  border-radius: var(--r-xl);
  padding: var(--sp-8) var(--sp-6);
  border: 1px solid var(--stone);
  box-shadow: var(--sh-sm);
  transition:
    transform .28s var(--ease-out),
    box-shadow .28s var(--ease-out),
    border-color .28s;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.sa-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: var(--card-accent, var(--grad-teal));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s var(--ease-out);
}
.sa-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--sh-lg);
  border-color: var(--teal-100);
}
.sa-card:hover::before { transform: scaleX(1); }

/* Kategorie-Dot auf Karte */
.sa-card-dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--card-accent, var(--grad-teal));
  box-shadow: 0 0 8px var(--card-accent-glow, rgba(0,99,88,.3));
}

.sa-card h3 { font-size: 1rem; margin: 0; font-weight: 600; line-height: 1.35; }
.sa-card p  { font-size: .9rem; color: var(--ink-70); flex: 1; line-height: 1.7; }

.sa-card-link {
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--teal-700);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  align-self: flex-start;
  margin-top: auto;
}
.sa-card-link::after {
  content: '→';
  transition: transform .2s var(--ease-out);
}
.sa-card:hover .sa-card-link::after { transform: translateX(4px); }

/* Karten-Akzentfarben */
.sa-card--teal  { --card-accent: var(--grad-teal); --card-accent-glow: rgba(0,99,88,.3); }
.sa-card--navy  { --card-accent: linear-gradient(135deg, var(--navy), #3d6878); --card-accent-glow: rgba(46,77,88,.3); }
.sa-card--sage  { --card-accent: linear-gradient(135deg, var(--sage), #9abdb5); --card-accent-glow: rgba(183,205,194,.5); }
.sa-card--blue  { --card-accent: linear-gradient(135deg, var(--blue-soft), #a8b5cc); --card-accent-glow: rgba(131,148,184,.4); }

/* ============================================================
   SECTION HEADING
   ============================================================ */
.sa-section-head {
  margin-bottom: clamp(var(--sp-12), 5vw, var(--sp-20));
}
.sa-section-head--center { text-align: center; }
.sa-section-head--center p { margin: var(--sp-4) auto 0; }
.sa-section-head p { margin-top: var(--sp-4); }

/* Accent-Bar über dem Heading */
.sa-accent-bar {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.sa-accent-bar::before {
  content: '';
  width: 40px; height: 3px;
  background: var(--grad-teal);
  border-radius: var(--r-full);
}

/* ============================================================
   PROZESS (S-04) – 3 Schritte
   ============================================================ */
.sa-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-8);
  position: relative;
}
/* Verbindungs-Linie */
.sa-steps::after {
  content: '';
  position: absolute;
  top: 28px;
  left: calc(50% / 3 + var(--sp-8));
  right: calc(50% / 3 + var(--sp-8));
  height: 2px;
  background: repeating-linear-gradient(
    90deg,
    var(--teal-200) 0, var(--teal-200) 6px,
    transparent 6px, transparent 14px
  );
}

.sa-step {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-4);
  position: relative;
  z-index: 1;
}
.sa-step-badge {
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--grad-teal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  box-shadow: var(--sh-sm), var(--sh-glow);
  flex-shrink: 0;
}
.sa-step h3 { font-size: var(--fs-h4); margin: 0; }
.sa-step p  { font-size: var(--fs-sm); color: var(--ink-70); }

/* ============================================================
   STATEMENT / ZITAT (S-05)
   ============================================================ */
.sa-statement {
  position: relative;
  z-index: 1;
  max-width: 780px;
  margin: 0 auto;
}
.sa-statement-card {
  background: var(--grad-glass);
  backdrop-filter: blur(var(--blur-lg));
  -webkit-backdrop-filter: blur(var(--blur-lg));
  border: 1px solid var(--glass-border);
  border-radius: var(--r-2xl);
  padding: clamp(var(--sp-10), 5vw, var(--sp-16));
  box-shadow: var(--sh-glass);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.sa-statement-card::before {
  content: '\201C';
  position: absolute;
  top: -20px; left: var(--sp-8);
  font-size: 12rem; line-height: 1;
  font-weight: 800;
  color: rgba(255,255,255,.06);
  font-family: var(--f);
  pointer-events: none;
  user-select: none;
}
.sa-statement-card blockquote {
  font-size: var(--fs-h3);
  font-weight: 600;
  line-height: 1.45;
  letter-spacing: -.02em;
  color: var(--on-dark);
  font-style: normal;
  border: none; padding: 0;
  margin: 0 0 var(--sp-6);
}
.sa-statement-card cite {
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--teal-200);
  font-style: normal;
}

/* ============================================================
   PROFIL-TEASER (S-06)
   ============================================================ */
.sa-profile-split {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: clamp(var(--sp-12), 6vw, var(--sp-24));
  align-items: center;
}
.sa-profile-img {
  position: relative;
}
.sa-profile-img img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: var(--r-2xl);
  filter: grayscale(60%);
  box-shadow: var(--sh-xl);
}
.sa-profile-img::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-2xl);
  background: linear-gradient(160deg, rgba(0,99,88,.2) 0%, transparent 50%);
}
/* Deko-Shape hinter Bild */
.sa-profile-img::before {
  content: '';
  position: absolute;
  inset: -16px -16px 16px 16px;
  border-radius: var(--r-2xl);
  border: 2px solid var(--teal-100);
  z-index: -1;
}

/* Qualifikations-Liste */
.sa-qual-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  margin: var(--sp-6) 0 var(--sp-8);
}
.sa-qual-list li {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-70);
}
.sa-qual-list li::before {
  content: '';
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--grad-teal);
  flex-shrink: 0;
}

/* ============================================================
   CTA-DARK SEKTION (S-07)
   ============================================================ */
.sa-cta-dark {
  text-align: center;
}
.sa-cta-dark h2 {
  color: var(--on-dark);
  font-size: var(--fs-h1);
  margin-bottom: var(--sp-4);
}
.sa-cta-dark .sa-lead {
  color: var(--on-dark-60);
  margin: 0 auto var(--sp-10);
}

/* Glass-Overlay-Karte im CTA */
.sa-cta-contact-card {
  display: inline-grid;
  grid-template-columns: repeat(3, auto);
  gap: var(--sp-6) var(--sp-12);
  align-items: center;
  padding: var(--sp-8) var(--sp-12);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(var(--blur-md));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: var(--r-xl);
  margin: 0 auto var(--sp-10);
}
.sa-contact-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
}
.sa-contact-item-label {
  font-size: var(--fs-label);
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--on-dark-30);
}
.sa-contact-item-value {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--on-dark);
}
.sa-contact-item-value a { color: var(--teal-200); }
.sa-contact-item-value a:hover { color: #fff; }

.sa-cta-btns { display: flex; gap: var(--sp-4); justify-content: center; flex-wrap: wrap; }

/* ============================================================
   FAQ ACCORDION (S-08)
   ============================================================ */
.sa-faq { display: flex; flex-direction: column; gap: var(--sp-3); }

.sa-faq details {
  background: #fff;
  border: 1px solid var(--stone);
  border-radius: var(--r-lg);
  overflow: hidden;
  transition: box-shadow .2s var(--ease-out);
}
.sa-faq details[open] {
  box-shadow: var(--sh-md);
  border-color: var(--teal-100);
}

.sa-faq summary {
  cursor: pointer;
  padding: var(--sp-5) var(--sp-6);
  font-weight: 600;
  font-size: var(--fs-body);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  list-style: none;
  min-height: 44px;
  user-select: none;
  transition: color .2s;
}
.sa-faq summary::-webkit-details-marker { display: none; }
.sa-faq details[open] summary { color: var(--teal-700); }

.sa-faq summary::after {
  content: '';
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--mist);
  border: 1.5px solid var(--stone);
  flex-shrink: 0;
  position: relative;
  transition: background .2s, transform .3s var(--ease-out);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M5 2v6M2 5h6' stroke='%231a1a2e' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}
.sa-faq details[open] summary::after {
  transform: rotate(45deg);
  background-color: var(--teal-700);
  border-color: var(--teal-700);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M5 2v6M2 5h6' stroke='white' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
}

.sa-faq-body {
  padding: 0 var(--sp-6) var(--sp-6);
  color: var(--ink-70);
  font-size: var(--fs-sm);
  line-height: 1.8;
}

/* ============================================================
   NOTFALL-BOX (wichtige Hinweise)
   ============================================================ */
.sa-emergency-box {
  background: linear-gradient(135deg, rgba(255,237,237,.8), rgba(255,245,245,.95));
  border: 1.5px solid rgba(180,83,9,.25);
  border-left: 4px solid var(--warning);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-8);
}
.sa-emergency-box h3 { color: var(--warning); font-size: var(--fs-h4); margin-bottom: var(--sp-3); }
.sa-emergency-box p  { font-size: var(--fs-sm); color: var(--ink-70); max-width: none; }
.sa-emergency-box strong { color: var(--ink); }

/* Infobox (Standard) */
.sa-info-box {
  background: var(--teal-25);
  border: 1px solid var(--teal-100);
  border-left: 4px solid var(--teal-700);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-8);
}
.sa-info-box p { font-size: var(--fs-sm); color: var(--ink-70); max-width: none; }
.sa-info-box strong { color: var(--teal-800); }

/* ============================================================
   PHASEN-KARTEN (Notfall Coaching – 3 Phasen)
   ============================================================ */
.sa-phases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
}
.sa-phase-card {
  background: #fff;
  border-radius: var(--r-xl);
  padding: var(--sp-8) var(--sp-6);
  box-shadow: var(--sh-sm);
  border: 1.5px solid var(--stone);
  position: relative;
  transition: box-shadow .25s var(--ease-out), border-color .25s;
}
.sa-phase-card--highlight {
  border-color: var(--teal-500);
  box-shadow: var(--sh-md), 0 0 0 3px rgba(0,150,136,.12);
}
.sa-phase-num {
  font-size: 3rem;
  font-weight: 800;
  letter-spacing: -.06em;
  background: var(--grad-teal);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: .25;
  line-height: 1;
  margin-bottom: var(--sp-3);
  font-variant-numeric: tabular-nums;
}
.sa-phase-card--highlight .sa-phase-num { opacity: .5; }

/* ============================================================
   BADGES / CREDENTIALS
   ============================================================ */
.sa-badge-list { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.sa-badge-item {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  background: var(--mist);
  border: 1px solid var(--teal-100);
  border-radius: var(--r-full);
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--fs-label);
  font-weight: 600;
  color: var(--teal-800);
  letter-spacing: .02em;
  transition: all .2s var(--ease-out);
}
.sa-badge-item::before {
  content: '✓';
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--grad-teal);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: .6rem; font-weight: 800;
  flex-shrink: 0;
}
.sa-badge-item:hover {
  background: var(--teal-25);
  border-color: var(--teal-300);
  transform: translateY(-1px);
}

/* ============================================================
   FOOTER
   ============================================================ */
#colophon, .site-footer {
  background: var(--teal-950);
  color: var(--on-dark-60);
  padding: var(--sp-12) 0 var(--sp-6);
  font-family: var(--f);
  font-size: var(--fs-sm);
}
.site-footer a { color: var(--teal-200); }
.site-footer a:hover { color: #fff; }
.site-footer .site-info { text-align: center; padding-top: var(--sp-6); border-top: 1px solid rgba(255,255,255,.08); }

/* ============================================================
   COLUMNS
   ============================================================ */
.wp-block-columns { gap: clamp(var(--sp-6), 3vw, var(--sp-10)) !important; }
.wp-block-columns.are-vertically-aligned-center { align-items: center; }
.wp-block-column { min-width: 0; }

/* ============================================================
   LISTEN
   ============================================================ */
.sa-check-list { list-style: none; padding: 0; display: flex; flex-direction: column; gap: var(--sp-3); }
.sa-check-list li {
  display: flex; gap: var(--sp-3); align-items: flex-start;
  font-size: var(--fs-sm); color: var(--ink-70); line-height: 1.65;
}
.sa-check-list li::before {
  content: '';
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--grad-teal);
  flex-shrink: 0;
  margin-top: 1px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='8' viewBox='0 0 10 8'%3E%3Cpath d='M1 4l3 3 5-6' stroke='white' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
}
.sa-check-list.on-dark li { color: var(--on-dark-60); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.sa-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s var(--ease-out), transform .6s var(--ease-out);
}
.sa-reveal.is-visible { opacity: 1; transform: none; }
.sa-reveal--delay-1 { transition-delay: .1s; }
.sa-reveal--delay-2 { transition-delay: .2s; }
.sa-reveal--delay-3 { transition-delay: .3s; }
.sa-reveal--delay-4 { transition-delay: .4s; }

/* Hero: immer sichtbar */
.sa-hero-main *,
.sa-hero-sub * { opacity: 1 !important; transform: none !important; }

/* ============================================================
   MOBILE-CTA-BAR (sticky, nur mobile)
   ============================================================ */
.sa-mobile-cta {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 100;
  padding: var(--sp-3) var(--sp-4) calc(var(--sp-3) + env(safe-area-inset-bottom));
  background: rgba(245,240,235,.95);
  backdrop-filter: blur(var(--blur-md));
  border-top: 1px solid var(--stone);
  box-shadow: 0 -4px 20px rgba(7,30,27,.10);
}
.sa-mobile-cta a {
  display: flex; align-items: center; justify-content: center;
  background: var(--grad-teal);
  color: #fff;
  font-weight: 700; font-size: var(--fs-sm);
  border-radius: var(--r-full);
  padding: 14px;
  text-align: center;
  box-shadow: var(--sh-sm);
  min-height: 52px;
}

/* ============================================================
   RESPONSIVE BREAKPOINTS
   ============================================================ */
@media (max-width: 1024px) {
  .sa-hero-inner { grid-template-columns: 1fr 1fr; gap: var(--sp-10); }
  .sa-hero-sub-inner { grid-template-columns: 1fr 1fr; }
  .sa-profile-split { grid-template-columns: 1fr 1fr; }
  .sa-steps { gap: var(--sp-6); }
  .sa-phases-grid { grid-template-columns: 1fr; }
  .sa-cta-contact-card { grid-template-columns: 1fr 1fr; }
  .sa-cards-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  :root { --pad-x: 20px; }
  .sa-hero-main { min-height: unset; padding: 64px 0 52px; }
  .sa-hero-inner { grid-template-columns: 1fr; }
  .sa-hero-visual { display: none; }
  .sa-hero-sub-inner { grid-template-columns: 1fr; }
  .sa-hero-sub-img { display: none; }
  .sa-cards-grid { grid-template-columns: 1fr; }
  .sa-steps { grid-template-columns: 1fr; }
  .sa-steps::after { display: none; }
  .sa-profile-split { grid-template-columns: 1fr; }
  .sa-profile-img { max-width: 340px; }
  .sa-phases-grid { grid-template-columns: 1fr; }
  .sa-cta-contact-card { grid-template-columns: 1fr; padding: var(--sp-8); gap: var(--sp-4); }
  .wp-block-columns { flex-direction: column !important; }
  .sa-mobile-cta { display: block; }
  body { padding-bottom: 80px; }
  .sa-faq summary { padding: var(--sp-4) var(--sp-4); }
  /* Hero H1 auf Mobile explizit kleiner */
  .sa-hero-text h1 { font-size: clamp(1.6rem, 6vw, 2.2rem); }
  /* Sub-Hero H1 auf Mobile */
  .sa-hero-sub-text h1 { font-size: clamp(1.5rem, 5.5vw, 2rem); }
  /* Section H2 auf Mobile */
  h2, .wp-block-heading:is(h2) { font-size: clamp(1.2rem, 4vw, 1.6rem); }
}

@media (max-width: 480px) {
  .sa-hero-btns { flex-direction: column; }
  .sa-hero-btns .wp-block-button__link { width: 100%; justify-content: center; }
  .sa-badge-list { gap: var(--sp-2); }
  .sa-hero-text h1 { font-size: 1.6rem; }
}

/* Kein ungewollter Whitespace nach letzten HTML-Blöcken */
.sa-bg-dark:last-child,
.wp-block-html:last-child { margin-bottom: 0 !important; }
/* Gap zwischen Header und erster Section entfernen */
#main-header + * { margin-top: 0 !important; }
.sa-hero-main,
.sa-hero-sub { margin-top: 0 !important; }
