:root {
  color-scheme: light dark;
  --bg-light: #f7f7f5;
  --fg-light: #0b0b0f;
  --muted-light: #6f7582;
  --primary-light: #1f3c88;
  --accent-light: #d4af37;
  --surface-light: #ffffffcc;
  --surface-elev-light: rgba(255, 255, 255, 0.8);
  --shadow-elev-1-light: 0 6px 16px rgba(15, 23, 42, 0.08);
  --shadow-elev-2-light: 0 12px 32px rgba(15, 23, 42, 0.12);
  --shadow-elev-3-light: 0 24px 64px rgba(15, 23, 42, 0.16);
  --hero-bg-image: url("../../Bilder/imageohnetext.png");
  --bg-dark: #05070a;
  --fg-dark: #eef1f8;
  --muted-dark: #939ab8;
  --primary-dark: #7aa2ff;
  --accent-dark: #f7d07a;
  --surface-dark: rgba(15, 19, 24, 0.85);
  --surface-elev-dark: rgba(18, 22, 29, 0.7);
  --shadow-elev-1-dark: 0 6px 16px rgba(0, 8, 20, 0.5);
  --shadow-elev-2-dark: 0 12px 32px rgba(0, 8, 20, 0.55);
  --shadow-elev-3-dark: 0 24px 64px rgba(0, 8, 20, 0.6);
  --bg: var(--bg-light);
  --fg: var(--fg-light);
  --muted: var(--muted-light);
  --primary: var(--primary-light);
  --accent: var(--accent-light);
  --surface: var(--surface-light);
  --surface-elev: var(--surface-elev-light);
  --shadow-elev-1: var(--shadow-elev-1-light);
  --shadow-elev-2: var(--shadow-elev-2-light);
  --shadow-elev-3: var(--shadow-elev-3-light);
  --space-3xs: clamp(0.35rem, 0.6vw, 0.55rem);
  --radius-xs: 0.25rem;
  --radius-sm: 0.4rem;
  --radius-md: 0.6rem;
  --radius-lg: 1rem;
  --space-2xs: 0.375rem;
  --space-xs: 0.75rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --space-xl: 4rem;
  --space-2xl: 6rem;
  --layout-gutter: clamp(var(--space-sm), 4vw, var(--space-2xl));
  --section-gap: clamp(calc(var(--space-xl) * 1.4), 10vw, calc(var(--space-2xl) * 1.6));
  --header-edge-padding: 1.5rem;
  --speed-fast: 140ms;
  --speed-med: 260ms;
  --speed-slow: 420ms;
  --hero-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --header-height: clamp(72px, 6vw, 88px);
  font-size: 16px;
}

/* Disable horizontal overscroll bounce where supported */
html,
body {
  overscroll-behavior-x: none;
}

/* Einheitliches Box-Modell, beugt Überläufen vor */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* Global: horizontales Scrollen/Bounce unterbinden */
html {
  max-width: 100vw;
  overflow-x: clip;
  /* clip statt hidden, damit die vertikale Scrollbar nicht verschwindet */
  overscroll-behavior-x: none;
}

body {
  max-width: 100vw;
  overscroll-behavior-x: none;
  /* overflow-x intentionally NOT set on body: setting it promotes overflow-y
     from visible to auto, turning body into a self-sizing scroll container
     that never overflows → no scrollbar. html overflow-x: clip handles
     horizontal clipping for the entire viewport. */
}

@font-face {
  font-family: "Satoshi";
  src: url("../Fonts/Satoshi_Complete/Fonts/WEB/fonts/Satoshi-Variable.woff2") format("woff2"),
    url("../Fonts/Satoshi_Complete/Fonts/WEB/fonts/Satoshi-Variable.woff") format("woff");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Satoshi";
  src: url("../Fonts/Satoshi_Complete/Fonts/WEB/fonts/Satoshi-VariableItalic.woff2") format("woff2"),
    url("../Fonts/Satoshi_Complete/Fonts/WEB/fonts/Satoshi-VariableItalic.woff") format("woff");
  font-weight: 100 900;
  font-style: italic;
  font-display: swap;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: var(--bg-dark);
    --fg: var(--fg-dark);
    --muted: var(--muted-dark);
    --primary: var(--primary-dark);
    --accent: var(--accent-dark);
    --surface: var(--surface-dark);
    --surface-elev: var(--surface-elev-dark);
    --shadow-elev-1: var(--shadow-elev-1-dark);
    --shadow-elev-2: var(--shadow-elev-2-dark);
    --shadow-elev-3: var(--shadow-elev-3-dark);
  }
}

body[data-theme="system"] {
  --bg-current: var(--bg);
  --fg-current: var(--fg);
  --muted-current: var(--muted);
  --surface-current: var(--surface);
  --surface-elev-current: var(--surface-elev);
}

body[data-theme="dark"] {
  color-scheme: only dark;
  --bg: var(--bg-dark);
  --fg: var(--fg-dark);
  --muted: var(--muted-dark);
  --primary: var(--primary-dark);
  --accent: var(--accent-dark);
  --surface: var(--surface-dark);
  --surface-elev: var(--surface-elev-dark);
  --shadow-elev-1: var(--shadow-elev-1-dark);
  --shadow-elev-2: var(--shadow-elev-2-dark);
  --shadow-elev-3: var(--shadow-elev-3-dark);
  --bg-current: var(--bg-dark);
  --fg-current: var(--fg-dark);
  --muted-current: var(--muted-dark);
  --surface-current: var(--surface-dark);
  --surface-elev-current: var(--surface-elev-dark);
}

body[data-theme="light"] {
  color-scheme: only light;
  --bg: var(--bg-light);
  --fg: var(--fg-light);
  --muted: var(--muted-light);
  --primary: var(--primary-light);
  --accent: var(--accent-light);
  --surface: var(--surface-light);
  --surface-elev: var(--surface-elev-light);
  --shadow-elev-1: var(--shadow-elev-1-light);
  --shadow-elev-2: var(--shadow-elev-2-light);
  --shadow-elev-3: var(--shadow-elev-3-light);
  --bg-current: var(--bg-light);
  --fg-current: var(--fg-light);
  --muted-current: var(--muted-light);
  --surface-current: var(--surface-light);
  --surface-elev-current: var(--surface-elev-light);
}

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

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  position: relative;
  z-index: 0;
  --bg-current: var(--bg);
  --fg-current: var(--fg);
  --muted-current: var(--muted);
  --surface-current: var(--surface);
  --surface-elev-current: var(--surface-elev);
  background-color: var(--bg-current, var(--bg));
  color: var(--fg-current, var(--fg));
  font-family: "Satoshi", -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", sans-serif;
  font-size: clamp(1rem, 0.26vw + 0.94rem, 1.1rem);
  line-height: 1.6;
  letter-spacing: 0.01em;
  /* overflow-x NOT set here — see comment in body block above */
}

body>* {
  position: relative;
  z-index: 1;
}

body::before,
body::after {
  content: "";
  position: fixed;
  z-index: 0;
  pointer-events: none;
}

body::before {
  inset: -25vh -35vw -25vh -20vw;
  background: radial-gradient(ellipse at top right, rgba(127, 140, 169, 0.08), transparent 70%);
}

body::after {
  top: -32vh;
  left: 50%;
  width: clamp(900px, 110vw, 1600px);
  height: clamp(900px, 110vw, 1600px);
  background-image: var(--hero-bg-image);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  filter: blur(18px);
  opacity: 0.48;
  transform: translate3d(-50%, 0, 0);
  animation: backgroundFloat 38s ease-in-out infinite alternate;
  -webkit-mask-image: linear-gradient(#000 0 0), radial-gradient(circle at 71% 64%, transparent 0 3.4%, #000 3.6%), radial-gradient(circle at 84% 45%, transparent 0 4.2%, #000 4.4%), radial-gradient(circle at 94% 22%, transparent 0 6.4%, #000 6.6%);
  -webkit-mask-composite: source-over, destination-out, destination-out;
  mask-image: linear-gradient(#000 0 0), radial-gradient(circle at 71% 64%, transparent 0 3.4%, #000 3.6%), radial-gradient(circle at 84% 45%, transparent 0 4.2%, #000 4.4%), radial-gradient(circle at 94% 22%, transparent 0 6.4%, #000 6.6%);
  mask-composite: add, subtract, subtract;
}

html::before,
html::after,
main::before {
  content: "";
  position: fixed;
  top: -32vh;
  left: 50%;
  width: clamp(900px, 110vw, 1600px);
  height: clamp(900px, 110vw, 1600px);
  background-image: var(--hero-bg-image);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  filter: blur(18px);
  opacity: 0;
  transform: translate3d(-50%, 0, 0);
  pointer-events: none;
  z-index: 0;
}

html::before {
  -webkit-mask-image: radial-gradient(circle at 71% 64%, rgba(0, 0, 0, 1) 0 3.2%, transparent 3.6%);
  mask-image: radial-gradient(circle at 71% 64%, rgba(0, 0, 0, 1) 0 3.2%, transparent 3.6%);
  animation: backgroundFloat 38s ease-in-out infinite alternate, dot-small 8s ease-in-out infinite;
}

html::after {
  -webkit-mask-image: radial-gradient(circle at 84% 45%, rgba(0, 0, 0, 1) 0 3.9%, transparent 4.4%);
  mask-image: radial-gradient(circle at 84% 45%, rgba(0, 0, 0, 1) 0 3.9%, transparent 4.4%);
  animation: backgroundFloat 38s ease-in-out infinite alternate, dot-medium 8s ease-in-out infinite;
}

main::before {
  -webkit-mask-image: radial-gradient(circle at 94% 22%, rgba(0, 0, 0, 1) 0 5.6%, transparent 6.2%);
  mask-image: radial-gradient(circle at 94% 22%, rgba(0, 0, 0, 1) 0 5.6%, transparent 6.2%);
  animation: backgroundFloat 38s ease-in-out infinite alternate, dot-large 8s ease-in-out infinite;
}

@keyframes backgroundFloat {
  0% {
    transform: translate3d(-52%, -6%, 0) scale(1.03);
  }

  50% {
    transform: translate3d(-48%, 3%, 0) scale(1.06);
  }

  100% {
    transform: translate3d(-51%, 1%, 0) scale(1.04);
  }
}

@keyframes dot-small {

  0%,
  12% {
    opacity: 0;
  }

  20%,
  72% {
    opacity: 1;
  }

  84%,
  100% {
    opacity: 0;
  }
}

@keyframes dot-medium {

  0%,
  26% {
    opacity: 0;
  }

  34%,
  72% {
    opacity: 1;
  }

  84%,
  100% {
    opacity: 0;
  }
}

@keyframes dot-large {

  0%,
  40% {
    opacity: 0;
  }

  48%,
  72% {
    opacity: 1;
  }

  84%,
  100% {
    opacity: 0;
  }
}

img,
picture {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--speed-med) ease, opacity var(--speed-med) ease;
}

a:hover,
a:focus-visible {
  color: var(--primary);
}

button,
input,
textarea {
  font: inherit;
  color: inherit;
}

svg {
  fill: currentColor;
}

.skip-link {
  position: absolute;
  inset-inline-start: var(--space-sm);
  top: var(--space-sm);
  padding: var(--space-2xs) var(--space-sm);
  background: var(--primary);
  color: var(--bg);
  border-radius: var(--radius-sm);
  transform: translateY(-150%);
  transition: transform var(--speed-fast) ease;
  /* Keep skip link above sticky header */
  z-index: 3000;
}

.skip-link:focus-visible {
  transform: translateY(0);
}

:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 3px;
}

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

.container {
  width: 100%;
  margin-inline: 0;
  padding-inline: var(--layout-gutter);
}

.section {
  padding-block: clamp(var(--space-xl), 6vw, var(--space-2xl));
}

.section+.section {
  margin-block-start: var(--section-gap);
}

/* Direktes Anschließen: Kein äußerer Abstand zwischen Trustbar und Angebot */
.trustbar+#angebot {
  margin-block-start: 0;
  /* noch tiefer: mehr Luft unter der Trustbar */
  padding-block-start: clamp(5rem, 11vw, 9rem);
}

/* Angebot: größere Überschrift */
#angebot .offer__header h2 {
  font-size: clamp(2.6rem, 6vw, 4rem);
  line-height: 1.05;
}

.section__head {
  display: grid;
  gap: var(--space-xs);
  margin-bottom: clamp(var(--space-lg), 4vw, var(--space-xl));
}

.section__head p {
  max-width: 48ch;
  color: var(--muted-current, var(--muted));
}

/* CTA-Überschrift oberhalb des grünen Abschnitts: mittig und größer */
#cta-title {
  text-align: center;
  font-size: clamp(2.6rem, 6vw, 3.6rem);
  line-height: 1.06;
  /* mehr Luft nach oben und moderater Abstand nach unten */
  margin: clamp(var(--space-xl), 6vw, var(--space-2xl)) 0 clamp(var(--space-md), 3vw, var(--space-lg));
  position: relative;
  z-index: 20;
  /* Überschrift stets vor dem Umschlag */
}

/* roter Punkt am Ende wie bei anderen Überschriften: via .hero__dot im Markup */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2xs);
  padding: var(--space-2xs) var(--space-md);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: background-color var(--speed-med) ease, color var(--speed-med) ease,
    box-shadow var(--speed-med) ease, border-color var(--speed-med) ease, transform var(--speed-fast) ease;
  cursor: pointer;
}

.btn:focus-visible {
  outline-offset: 4px;
}

.btn--primary {
  background: var(--primary);
  color: var(--bg);
  box-shadow: var(--shadow-elev-1);
}

.cursor-dot {
  position: fixed;
  top: 0;
  left: 0;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  pointer-events: none;
  opacity: 0;
  transform: translate(-50%, -50%) scale(var(--cursor-scale, 0.35));
  background: rgba(225, 67, 63, 0.92);
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.42), 0 16px 32px -18px rgba(225, 67, 63, 0.58);
  transition: transform 200ms var(--hero-ease), opacity 180ms var(--hero-ease), box-shadow 220ms var(--hero-ease),
    background-color 220ms var(--hero-ease);
  /* Ensure the red cursor dot sits above header and mobile menu */
  z-index: 4000;
  will-change: transform, opacity;
}

.cursor-dot.is-visible {
  opacity: 1;
  --cursor-scale: 1;
}

.cursor-dot.is-pressed {
  --cursor-scale: 0.82;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.5), 0 12px 26px -18px rgba(225, 67, 63, 0.5);
}

.cursor-dot.is-reduced-motion {
  transition: none;
}

body[data-theme="dark"] .cursor-dot {
  background: rgba(225, 115, 110, 0.92);
  box-shadow: 0 0 0 2px rgba(12, 16, 24, 0.55), 0 16px 32px -18px rgba(225, 115, 110, 0.55);
}

@media (prefers-reduced-motion: reduce) {
  .cursor-dot {
    transition: none;
  }
}

body.has-custom-cursor a,
body.has-custom-cursor button,
body.has-custom-cursor [role="button"],
body.has-custom-cursor .btn,
body.has-custom-cursor .offerings-card,
body.has-custom-cursor .site-nav__list a,
body.has-custom-cursor .nav-toggle,
body.has-custom-cursor .carousel__btn,
body.has-custom-cursor .site-logo {
  cursor: none !important;
}

.btn--primary:hover,
.btn--primary:focus-visible {
  transform: translateY(-1px);
  box-shadow: var(--shadow-elev-2);
}

.btn--ghost {
  background: transparent;
  color: var(--fg-current, var(--fg));
  border-color: currentColor;
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
  color: var(--primary);
  border-color: var(--primary);
}

.card {
  display: grid;
  gap: var(--space-sm);
  padding: clamp(var(--space-sm), 3vw, var(--space-lg));
  background: var(--surface-current, var(--surface));
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-elev-1);
  transition: transform var(--speed-med) ease, box-shadow var(--speed-med) ease, border-color var(--speed-med) ease;
  border: 1px solid transparent;
  position: relative;
  /* allow anchoring logo to bottom-right */
}

.card:hover,
.card:focus-within {
  transform: translateY(-4px);
  box-shadow: var(--shadow-elev-2);
  border-color: rgba(127, 140, 169, 0.2);
}

.card__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2xs);
  font-weight: 600;
}

.card__toggle {
  appearance: none;
  background: none;
  border: 0;
  padding: var(--space-2xs) var(--space-sm);
  color: inherit;
  font: inherit;
  border: 1px solid currentColor;
  border-radius: var(--radius-md);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Match ghost button interaction */
.card__toggle:hover,
.card__toggle:focus-visible {
  color: var(--primary);
  border-color: var(--primary);
}

/* Mentalität: Toggle-Buttons optisch wie Buttons */
.mentality-card__toggle {
  appearance: none;
  background: none;
  border: 1px solid currentColor;
  border-radius: var(--radius-md);
  padding: var(--space-2xs) var(--space-sm);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.mentality-card__toggle:hover,
.mentality-card__toggle:focus-visible {
  color: var(--primary);
  border-color: var(--primary);
}

/* Card actions row with logo to the right of the button */
.card__actions {
  display: block;
}

.card__logo {
  position: absolute;
  right: clamp(var(--space-sm), 3vw, var(--space-lg));
  bottom: clamp(var(--space-sm), 2.5vw, var(--space-lg));
  height: 47px;
  /* +30% for both logos (desktop) */
  width: auto;
  object-fit: contain;
  filter: saturate(0.95);
}

/* Left card logo +30% on top (desktop) */
.cases__grid>.card:first-child .card__logo {
  height: 61px;
}

@media (max-width: 540px) {
  .card__logo {
    height: 40px;
    /* +30% for both logos (mobile) */
  }

  .cases__grid>.card:first-child .card__logo {
    height: 52px;
  }

  /* Headline sofort sichtbar (keine Fade/Slide-In-Animation auf Mobile) */
  .hero-animate[data-hero-stage="slogan"] {
    opacity: 1 !important;
    transform: none !important;
  }

  .hero[data-hero-active="true"] .hero-animate[data-hero-stage="slogan"] {
    animation: none !important;
  }
}

/* Desktop/tablet: Align logos to the same row as the action link and right-align within the card */
@media (min-width: 541px) {
  .card__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
  }

  /* Position logos further right and lower on desktop/tablet */
  .card__logo {
    position: absolute;
    right: clamp(0.4rem, 1.5vw, 1rem);
    bottom: clamp(0.25rem, 1.5vw, 0.9rem);
    margin-left: 0;
  }

  /* Left card: minimal extra Tiefe, damit beide optisch bündig wirken */
  .cases__grid>.card:first-child .card__logo {
    bottom: clamp(0.15rem, 1.2vw, 0.7rem);
  }
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.35em 1.25em;
  border-radius: 999px;
  background: rgba(127, 140, 169, 0.1);
  color: var(--muted-current, var(--muted));
  font-size: clamp(0.75rem, 0.18vw + 0.72rem, 0.85rem);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site-header {
  position: sticky;
  top: 0;
  inset-inline: 0;
  /* Raise above all content so the dropdown inside isn't hidden */
  z-index: 2500;
  width: 100%;
  background-color: var(--surface-current, var(--surface));
  transition: background-color var(--speed-slow) ease, box-shadow var(--speed-slow) ease,
    backdrop-filter var(--speed-slow) ease;
  backdrop-filter: blur(6px);
  box-shadow: none;
}

.site-header__inner-wrap {
  width: 100%;
  margin-inline: 0;
  /* Mehr Luft links und rechts am Rand */
  padding-inline-start: calc(var(--header-edge-padding) + env(safe-area-inset-left));
  padding-inline-end: calc(var(--header-edge-padding) + env(safe-area-inset-right));
}

.site-header.is-scrolled {
  background-color: var(--surface-elev-current, var(--surface-elev));
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-elev-1);
}

.site-header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  column-gap: clamp(var(--space-sm), 3vw, var(--space-lg));
  min-height: var(--header-height);
  width: 100%;
  margin-inline: 0;
  padding-block: clamp(var(--space-2xs), 1.2vw, var(--space-sm));
}

.site-header__brand {
  grid-column: 1;
  justify-self: start;
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
}

.site-header__controls {
  grid-column: 3;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: clamp(0.75rem, 1.8vw, 1.25rem);
}

.site-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  /* dichter an die Bildmarke rücken */
  font-weight: 700;
  font-size: clamp(1.05rem, 0.5vw + 1rem, 1.35rem);
  line-height: 1;
  white-space: nowrap;
  flex-shrink: 0;
}

.site-logo__mark {
  display: inline-flex;
  width: 3.2rem;
  /* kompakter, verhindert Überlappung */
  height: 3.2rem;
  border-radius: 999px;
  background-color: var(--site-logo-bg, var(--surface-elev-current, var(--surface)));
  background-image: var(--site-logo-image, var(--hero-bg-image));
  background-repeat: no-repeat;
  background-position: center;
  background-size: 70%;
  box-shadow: var(--site-logo-shadow,
      0 18px 30px -20px rgba(12, 24, 36, 0.4)),
    inset 0 0 0 1px rgba(127, 140, 169, 0.25);
  position: relative;
  overflow: hidden;
  transition: background-color 240ms var(--hero-ease), box-shadow 240ms var(--hero-ease),
    filter 240ms var(--hero-ease);
  flex-shrink: 0;
}

@media (max-width: 768px) {
  .site-logo__mark {
    width: 3.0rem;
    height: 3.0rem;
  }
}

/* Image replacement for logo text */
.site-logo__text {
  display: inline-block;
  height: 2.2em;
  /* kompakter, verhindert Kollision mit Navigation */
  width: auto;
  object-fit: contain;
  vertical-align: middle;
}

@media (min-width: 900px) {

  /* Kopfbereich: Mitte gibt Navigation mehr Raum, Logo/CTA bleiben kompakt */
  .site-header__inner {
    grid-template-columns: auto 1fr auto;
  }

  .site-logo__text {
    height: 2.6em;
    /* moderat größer auf Desktop, trotzdem kompakt */
  }
}

.site-header.is-scrolled .site-logo__mark {
  background-color: var(--surface-elev-current, var(--surface-elev));
  box-shadow: 0 20px 32px -22px rgba(12, 24, 36, 0.4), inset 0 0 0 1px rgba(127, 140, 169, 0.25);
}

.site-logo__mark::after {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 30%, rgba(255, 255, 255, 0.35), transparent 65%);
  pointer-events: none;
  opacity: 0.65;
}

.site-logo:hover .site-logo__mark,
.site-logo:focus-visible .site-logo__mark {
  filter: brightness(1.12);
  box-shadow: 0 26px 40px -24px rgba(12, 24, 36, 0.45), inset 0 0 0 1px rgba(127, 140, 169, 0.35);
}

.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(127, 140, 169, 0.25);
  border-radius: var(--radius-sm);
  background: transparent;
  padding: 0;
  cursor: pointer;
  box-shadow: none;
  position: relative;
  /* Keep the toggle above the dropdown menu */
  z-index: 2700;
  margin: 0;
}

.nav-toggle::before,
.nav-toggle::after,
.nav-toggle__label::before {
  content: "";
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
  transition: transform var(--speed-med) ease, opacity var(--speed-med) ease;
}

.nav-toggle__label {
  display: contents;
}

.nav-toggle.is-active::before {
  transform: translateY(8px) rotate(45deg);
}

.nav-toggle.is-active::after {
  transform: translateY(-8px) rotate(-45deg);
}

.nav-toggle.is-active .nav-toggle__label::before {
  opacity: 0;
}

.site-nav {
  grid-column: 2;
  justify-self: stretch;
  align-self: stretch;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  min-height: 100dvh;
  min-height: 100vh;
  /* full-viewport overlay */
  transform: none;
  background: var(--surface-current, var(--surface));
  backdrop-filter: none;
  z-index: 2600;
  /* under the toggle, above page */
  display: none;
  padding: calc(var(--header-height) + var(--space-lg)) var(--space-md) var(--space-xl);
  box-shadow: 0 18px 28px -20px rgba(12, 24, 36, 0.35);
  border-radius: 0;
  max-height: none;
  overflow-y: auto;
}

/* Force fully opaque background for the mobile menu */
body[data-theme="light"] .site-nav {
  background-color: #ffffff;
}

body[data-theme="dark"] .site-nav {
  background-color: #0a2342;
}

.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-md);
  font-size: clamp(1.4rem, 4vw, 2rem);
  text-transform: uppercase;
  letter-spacing: 0.2em;
  justify-items: center;
  align-content: start;
}

/* Mobile: Subnav unter "Angebot" als Dropdown mit Plus-Toggle */
@media (max-width: 899.98px) {
  .site-nav__item.has-submenu {
    position: relative;
    width: 100%;
  }

  .site-nav__item.has-submenu>.site-nav__link {
    display: block;
    text-align: center;
    width: 100%;
  }

  .site-subnav__toggle {
    position: absolute;
    right: var(--space-sm);
    top: 50%;
    transform: translateY(-50%);
    appearance: none;
    border: 1px solid rgba(127, 140, 169, 0.25);
    background: rgba(127, 140, 169, 0.06);
    color: inherit;
    border-radius: var(--radius-sm);
    width: 34px;
    height: 34px;
    display: inline-grid;
    place-items: center;
    cursor: pointer;
  }

  .site-subnav__icon {
    font-size: 1.1rem;
    line-height: 1;
  }

  .site-subnav {
    list-style: none;
    margin: var(--space-xs) 0 0 0;
    padding: 0;
    display: none;
    gap: var(--space-2xs);
    justify-items: center;
  }

  .site-nav__item.has-submenu.is-open>.site-subnav {
    display: grid;
  }

  .site-subnav>li>a {
    text-transform: none;
    letter-spacing: 0.02em;
    font-size: clamp(0.92rem, 0.5vw + 0.86rem, 1rem);
    padding: 0.2rem 0.4rem;
    display: inline-block;
  }
}

.site-nav__cta {
  margin-top: clamp(var(--space-sm), 6vw, var(--space-lg));
  width: min(20rem, 80vw);
}

.site-nav__cta .btn {
  width: 100%;
  justify-content: center;
  font-size: clamp(1rem, 0.6vw + 0.95rem, 1.1rem);
  letter-spacing: 0.08em;
}

.site-nav.is-open {
  display: block;
}

/* Prevent background scroll when the nav is open */
body.is-nav-open {
  overflow: hidden;
}

/* Remove backdrop-filter from header when nav is open so the fixed nav
   uses the viewport as its containing block (backdrop-filter otherwise
   creates a new containing block in Chrome/Safari, clipping/misplacing the nav) */
body.is-nav-open .site-header {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  /* Skip the transition so backdrop-filter is removed instantly — a transitioning
     blur() still creates a new containing block, which mis-positions the fixed nav */
  transition: none;
}

.site-header__cta {
  display: none;
}

.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3xs);
  padding: var(--space-3xs);
  width: auto;
  height: auto;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(127, 140, 169, 0.25);
  background: rgba(255, 255, 255, 0.04);
  cursor: pointer;
  position: relative;
  transition: border-color var(--speed-fast) ease, background var(--speed-fast) ease, box-shadow var(--speed-fast) ease;
  margin: 0;
}

.theme-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(127, 140, 169, 0.35);
}

.theme-icon {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  opacity: 0.35;
  transition: opacity var(--speed-med) ease, transform var(--speed-med) ease;
}

.theme-icon svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
  stroke-width: 1.6;
  fill: none;
}

.theme-icon--moon svg {
  fill: currentColor;
  stroke: none;
}

.theme-toggle[data-active-theme="light"] .theme-icon--sun,
.theme-toggle[data-active-theme="dark"] .theme-icon--moon {
  opacity: 1;
  transform: scale(1.05);
}

.theme-toggle[data-active-theme="dark"] .theme-icon--sun,
.theme-toggle[data-active-theme="light"] .theme-icon--moon {
  opacity: 0.2;
}

.hero {
  position: relative;
  display: grid;
  align-items: center;
  min-height: calc(100vh - var(--header-height));
  padding-block-start: max(calc(var(--header-height) + var(--space-xs)),
      clamp(var(--space-lg), 6vw, var(--space-xl)));
  padding-block-end: clamp(var(--space-lg), 6vw, var(--space-xl));
  overflow: visible;
  --hero-portrait-width: clamp(440px, 58vw, 780px);
  --hero-band-base-offset: 0px;
  --hero-band-thickness: clamp(2px, 0.45vw, 6px);
  --hero-band-dynamic-offset: 0px;
  --hero-band-overlap: 4px;
  --hero-band-horizontal-margin: var(--layout-gutter);
}

/* Startseite: Weniger Abstand unter dem Portrait-Bereich, damit die Trustbar näher rückt */
#hero {
  /* Hero auf Inhalts-Höhe, damit Trustbar oben genau am Portrait startet */
  min-height: auto;
  /* Unterkante bündig mit Trustbar-Beginn (keine Lücke) */
  padding-block-end: 0;
}

.hero__inner {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  align-items: start;
  gap: clamp(var(--space-md), 4vw, var(--space-xl));
  z-index: 2;
}

.hero__copy {
  position: relative;
  z-index: 3;
  display: grid;
  gap: 0;
  max-width: clamp(320px, 65%, 48rem);
  width: 100%;
  justify-items: flex-start;
  text-align: left;
  align-content: start;
  padding-right: clamp(0.75rem, 4.5vw, 3rem);
  align-self: center;
}

.hero__headline {
  font-size: clamp(3.4rem, 5.8vw, 5.8rem);
  font-weight: 800;
  line-height: 0.97;
  letter-spacing: -0.015em;
  margin: 0 0 2.5rem;
  color: var(--fg-current, var(--fg));
}

.hero__headline-inner {
  display: inline-flex;
  flex-direction: column;
  gap: clamp(0.35rem, 0.6vw, 0.75rem);
  align-items: flex-start;
  animation: none;
  transform-origin: 50% 50%;
}

.hero__headline-line {
  display: block;
}

.hero__dot {
  display: inline-block;
  color: #e1433f;
}

.hero__headline-line--wide {
  white-space: nowrap;
}

.hero__profile {
  display: grid;
  gap: clamp(0.3rem, 0.6vw, 0.8rem);
  max-width: clamp(320px, 52%, 34rem);
  justify-items: flex-start;
  text-align: left;
}

.hero__name {
  margin: 0 0 1.8rem;
  font-size: clamp(1.4rem, 2vw, 2rem);
  line-height: 1.35;
  color: var(--fg-current, var(--fg));
  display: inline-flex;
  flex-direction: column;
  gap: clamp(0.2rem, 0.4vw, 0.5rem);
}

.hero__name-main {
  white-space: nowrap;
  font-weight: 400;
}

.hero__name-line {
  display: block;
  font-size: inherit;
  line-height: 1.3;
}

.hero__name-line--accent,
.hero__name-line--sub {
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 90%, transparent);
}

.hero__sub {
  margin: 0 0 2rem;
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 70%, transparent);
  font-size: clamp(0.98rem, 0.35vw + 0.92rem, 1.05rem);
  line-height: 1.5;
  max-width: clamp(320px, 75%, 36rem);
}

.hero__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(0.9rem, 1.4vw, 1.3rem);
  width: 100%;
  max-width: clamp(320px, 80%, 40rem);
  margin-top: clamp(1.2rem, 2vw, 1.8rem);
}

.hero__actions .btn {
  width: 100%;
  min-width: 0;
  font-size: clamp(0.88rem, 0.4vw + 0.82rem, 0.95rem);
  font-weight: 600;
  justify-content: center;
  white-space: nowrap;
  transition: transform 320ms var(--hero-ease), box-shadow 320ms var(--hero-ease), filter 320ms var(--hero-ease), background-color 320ms var(--hero-ease);
}

.hero__actions .btn:hover,
.hero__actions .btn:focus-visible {
  transform: translateY(-2px) scale(1.03);
  box-shadow: 0 20px 36px -18px rgba(12, 60, 110, 0.35);
  filter: brightness(1.05);
}

.hero__media {
  position: relative;
  justify-self: center;
  align-self: end;
  width: var(--hero-portrait-width);
  margin-bottom: 0;
  margin-left: clamp(-10rem, -24vw, -6.5rem);
  margin-right: auto;
  z-index: 1;
  pointer-events: none;
  will-change: transform, opacity;
}

.hero__portrait {
  position: relative;
  width: 100%;
  max-width: clamp(440px, 62vw, 760px);
  filter: drop-shadow(0 30px 48px rgba(12, 60, 110, 0.25));
  transform-origin: 50% 50%;
}

.hero__accent {
  position: absolute;
  display: block;
  pointer-events: none;
  mix-blend-mode: normal;
  z-index: 3;
  background: linear-gradient(90deg, rgba(12, 60, 110, 0.95) 0%, rgba(27, 164, 229, 0.88) 55%, rgba(225, 67, 63, 0.92) 100%);
  border-radius: 999px;
  box-shadow: 0 10px 24px -18px rgba(12, 60, 110, 0.45);
}

.hero__accent--horizontal {
  display: none;
}


@media (min-width: 1025px) {
  .hero__media {
    margin-left: clamp(-12rem, -28vw, -7.8rem);
    margin-right: auto;
    /* Portrait nicht anheben; bündig nach unten ausrichten */
    margin-top: 0;
  }
}

.hero__portrait::after {
  content: "";
  position: absolute;
  inset: -6% -8% -12%;
  background: radial-gradient(circle at 40% 20%, rgba(12, 60, 110, 0.28), transparent 60%);
  z-index: -1;
  opacity: 0.75;
  filter: blur(20px);
}

.hero__portrait img {
  display: block;
  width: 100%;
  height: auto;
  transform: translateZ(0);
}

.hero-animate {
  --hero-delay: 0s;
  --hero-duration: 1s;
  opacity: 0;
  will-change: transform, opacity, filter;
}

.hero-animate[data-hero-stage="slogan"] {
  --hero-duration: 2.1s;
  --hero-delay: 0s;
  transform: translateY(44px) scale(0.94);
}

.hero-animate[data-hero-stage="band"] {
  --hero-duration: 1.1s;
  --hero-delay: 0.55s;
  transform-origin: right center;
  transform: scaleX(0);
  opacity: 0;
}

.hero-animate[data-hero-stage="band-vertical"] {
  --hero-duration: 1s;
  --hero-delay: 0.7s;
  transform-origin: bottom center;
  transform: scaleY(0);
  opacity: 0;
}

.hero-animate[data-hero-stage="portrait"] {
  --hero-duration: 1.5s;
  --hero-delay: 1.05s;
  transform: translate3d(120px, 14px, 0) scale(0.9);
  filter: brightness(0.75);
  pointer-events: none;
}

.hero-animate[data-hero-stage="name"] {
  --hero-duration: 1s;
  --hero-delay: 1.4s;
  transform: translateY(36px);
}

.hero-animate[data-hero-stage="sub"] {
  --hero-duration: 1.2s;
  --hero-delay: 1.8s;
  transform: translateX(-28px);
}

.hero-animate[data-hero-stage="cta-primary"] {
  --hero-duration: 0.9s;
  --hero-delay: 2.2s;
  transform: translateY(32px);
}

.hero-animate[data-hero-stage="cta-secondary"] {
  --hero-duration: 0.9s;
  --hero-delay: 2.45s;
  transform: translateY(40px);
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="slogan"] {
  animation: heroSloganIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="band"] {
  animation: heroBandIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="band-vertical"] {
  animation: heroBandVerticalIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="portrait"] {
  animation: heroPortraitIn var(--hero-duration) cubic-bezier(0.33, 0.84, 0.42, 1) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="name"] {
  animation: heroNameIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="sub"] {
  animation: heroSubIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero-animate[data-hero-stage="cta-primary"],
.hero[data-hero-active="true"] .hero-animate[data-hero-stage="cta-secondary"] {
  animation: heroCtaIn var(--hero-duration) var(--hero-ease) var(--hero-delay) forwards;
}

.hero[data-hero-active="true"] .hero__headline-inner {
  animation: heroSloganBreath 6.4s ease-in-out 2.4s infinite alternate;
}

@media (max-width: 1024px) {

  /* Prevent horizontal scroll/bounce on mobile/tablet */
  html {
    overflow-x: clip;
  }

  body {
    /* overflow-x NOT set — html handles horizontal clipping */
    /* Deaktiviert horizontalen Bounce/Over-Scroll */
    overscroll-behavior-x: none;
    max-width: 100vw;
  }

  /* Zusätzliches Clipping für gängige Wrapper, um seitliches "Ziehen" zu verhindern */
  .container,
  .section,
  .site-header,
  .site-footer,
  .hero__inner,
  .cases__layout,
  .about__layout {
    overflow-x: clip;
    max-width: 100%;
  }

  .hero__inner {
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
    gap: clamp(var(--space-md), 6vw, var(--space-xl));
  }

  .hero__copy {
    max-width: clamp(300px, 64%, 520px);
    padding-right: clamp(0.5rem, 3.5vw, 2.25rem);
  }

  .hero {
    --hero-portrait-width: clamp(360px, 74vw, 620px);
    --hero-band-base-offset: 0px;
    --hero-band-thickness: clamp(2px, 0.6vw, 6px);
    --hero-band-horizontal-margin: clamp(var(--space-sm), 6vw, var(--space-xl));
  }

  .hero__media {
    width: var(--hero-portrait-width);
    margin-left: 0;
    /* verhindert horizontales Überlaufen auf Mobil/Tablet */
    margin-right: auto;
  }

  /* Verhindert, dass die horizontale Akzentlinie seitlich übersteht */
  .hero__portrait {
    overflow: hidden;
  }

  .offerings__layout {
    grid-template-columns: minmax(0, 1fr);
    gap: clamp(var(--space-lg), 8vw, var(--space-2xl));
  }

  .offerings__intro {
    max-width: min(40rem, 92%);
  }

  .offerings__cards {
    grid-template-columns: minmax(0, 1fr);
    margin-top: clamp(1.4rem, 4vw, 2.8rem);
    gap: clamp(1.4rem, 3.2vw, 2.4rem);
  }

  .offerings-card {
    width: 100%;
  }

}

@media (max-width: 768px) {
  .site-header__inner-wrap {
    padding-inline-start: calc(clamp(1rem, 4vw, 1.5rem) + env(safe-area-inset-left));
    padding-inline-end: calc(clamp(1rem, 4vw, 1.5rem) + env(safe-area-inset-right));
  }

  .site-header__inner {
    grid-template-columns: auto 1fr auto;
    column-gap: clamp(var(--space-2xs), 3vw, var(--space-sm));
  }

  .site-header__brand {
    min-width: 0;
  }

  .site-logo {
    font-size: clamp(0.95rem, 4vw, 1.1rem);
    white-space: normal;
    line-height: 1.1;
  }

  .site-logo>span:last-child {
    display: inline-block;
    max-width: min(12rem, 70vw);
  }

  .site-header__controls {
    gap: clamp(0.5rem, 3vw, 0.85rem);
  }

  .site-header__controls .nav-toggle {
    order: -1;
  }

  .site-header__controls .site-header__cta {
    display: none;
  }

  .site-nav__cta {
    display: none;
  }

  .hero {
    padding-block-start: max(calc(var(--header-height) + var(--space-xs)),
        clamp(var(--space-lg), 12vw, var(--space-xl)));
    padding-block-end: clamp(var(--space-lg), 12vw, var(--space-xl));
    --hero-portrait-width: clamp(360px, 82vw, 560px);
    --hero-band-base-offset: 0px;
    --hero-band-thickness: clamp(2px, 0.9vw, 6px);
    --hero-band-horizontal-margin: clamp(var(--space-md), 10vw, var(--space-2xl));
    --hero-band-overlap: 3px;
  }

  .hero__inner {
    grid-template-columns: 1fr;
    gap: clamp(var(--space-md), 8vw, var(--space-xl));
    justify-items: stretch;
    align-items: start;
  }

  .hero__copy {
    max-width: 100%;
    padding-right: 0;
    gap: clamp(0.9rem, 3.5vw, 1.4rem);
    justify-items: flex-start;
    text-align: left;
  }

  .hero__profile {
    max-width: 100%;
    /* Mehr Abstand zum Button-Block darunter (Mobile) */
    margin-bottom: clamp(1.2rem, 6vw, 2rem);
  }

  .hero__headline,
  .hero__sub,
  .hero__name {
    width: 100%;
  }

  .hero__sub {
    max-width: 100%;
  }

  .hero__headline {
    font-size: clamp(2.4rem, 9.5vw, 3.6rem);
    line-height: 1.05;
    margin-bottom: clamp(1rem, 5vw, 1.4rem);
  }

  .hero__headline-inner {
    gap: clamp(0.3rem, 2vw, 0.6rem);
  }

  .hero__name {
    font-size: clamp(1.2rem, 4.8vw, 1.8rem);
    gap: clamp(0.15rem, 1.8vw, 0.35rem);
    margin-bottom: clamp(0.6rem, 2.8vw, 0.9rem);
  }

  .hero__name-main {
    white-space: normal;
  }

  .hero__name-line--accent,
  .hero__name-line--sub {
    font-size: clamp(1.05rem, 4.2vw, 1.4rem);
    letter-spacing: 0.06em;
  }

  .hero__sub {
    max-width: 100%;
    font-size: clamp(0.95rem, 3.4vw, 1.05rem);
    margin-bottom: clamp(1.5rem, 5.5vw, 1.75rem);
  }

  .hero__media {
    justify-self: center;
    align-self: end;
    /* Bild an Unterkante ausrichten */
    width: var(--hero-portrait-width);
    margin-left: 0;
    margin-bottom: 0;
    /* bündig zur Trustbar */
  }

  .hero__actions {
    width: 100%;
    max-width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: clamp(0.6rem, 3.5vw, 0.9rem);
    margin-top: clamp(0.6rem, 3vw, 0.9rem);
    justify-self: start;
    /* linksbündig */
  }

  .hero__inner {
    grid-template-columns: 1fr;
    grid-template-areas:
      "hero-headline"
      "hero-profile"
      "hero-sub"
      "hero-media"
      "hero-actions";
  }

  .hero__copy {
    display: contents;
  }

  .hero__headline {
    grid-area: hero-headline;
  }

  .hero__profile {
    grid-area: hero-profile;
    max-width: 100%;
  }

  .hero__sub {
    grid-area: hero-sub;
    max-width: 100%;
    width: 100%;
  }

  .hero__name,
  .hero__profile,
  .hero__sub,
  .hero__headline {
    width: 100%;
  }

  .hero__media {
    grid-area: hero-media;
    margin: clamp(0.5rem, 4vw, 1.2rem) auto 0;
    /* kein Spalt am unteren Rand */
    align-self: end;
  }

  .hero__actions {
    grid-area: hero-actions;
    justify-self: start;
    /* linksbündig */
    width: 100%;
  }

  .hero__actions .btn {
    width: 100%;
    min-width: 0;
  }

  .offerings__intro {
    max-width: 100%;
    gap: clamp(var(--space-sm), 5vw, var(--space-lg));
  }

  .offerings__quote {
    font-size: clamp(1.15rem, 1.6vw + 1rem, 1.4rem);
    text-align: left;
  }

  .offerings__body {
    max-width: 100%;
  }

  .offerings__cards {
    gap: clamp(1.6rem, 6vw, 2.8rem);
  }

  .offerings-card {
    grid-template-columns: auto 1fr;
  }

  .hero-animate[data-hero-stage="slogan"] {
    --hero-duration: 1.8s;
  }

  .hero-animate[data-hero-stage="band"] {
    --hero-delay: 0.5s;
  }

  .hero-animate[data-hero-stage="portrait"] {
    --hero-delay: 0.95s;
    --hero-duration: 1.2s;
  }

  .hero-animate[data-hero-stage="name"] {
    --hero-delay: 1.3s;
  }

  .hero-animate[data-hero-stage="sub"] {
    --hero-delay: 1.68s;
    --hero-duration: 1.05s;
  }

  .hero-animate[data-hero-stage="cta-primary"] {
    --hero-delay: 2.05s;
  }

  .hero-animate[data-hero-stage="cta-secondary"] {
    --hero-delay: 2.3s;
  }
}

@media (max-width: 540px) {
  .hero {
    --hero-portrait-width: clamp(300px, 92vw, 420px);
    --hero-band-base-offset: 0px;
    --hero-band-thickness: clamp(2px, 1vw, 5px);
    --hero-band-horizontal-margin: clamp(var(--space-md), 14vw, var(--space-2xl));
    --hero-band-overlap: 3px;
    padding-block-start: calc(var(--header-height) + 0.25rem);
    padding-block-end: 0;
    /* bündig zur Trustbar ohne Spalt */
    min-height: auto;
  }

  .hero__copy {
    max-width: 100%;
    gap: clamp(0.8rem, 4vw, 1.2rem);
    justify-items: flex-start;
    text-align: left;
  }

  /* Mobile: Reihenfolge anpassen: Titel -> Buttons -> Name -> Portrait */
  .hero__inner {
    grid-template-columns: 1fr;
    gap: clamp(0.2rem, 1.8vw, 0.5rem);
    /* noch enger zwischen Text und Portrait */
    grid-template-areas:
      "hero-headline"
      "hero-profile"
      "hero-actions"
      "hero-media";
  }

  .hero__headline,
  .hero__name,
  .hero__profile,
  .hero__sub {
    width: 100%;
  }

  .hero__profile {
    max-width: 100%;
    /* dichter an das Portrait heran – fast Überlappung */
    margin-top: clamp(0.7rem, 3vw, 1.1rem);
    margin-bottom: clamp(-0.8rem, -3vw, -0.2rem);
  }

  .hero__headline {
    font-size: clamp(2.3rem, 4.6vw + 1.3rem, 3.4rem);
    line-height: 1.12;
    /* mehr Zeilenhöhe für Unterlängen (g, j, p, q, y) */
    margin-bottom: clamp(0.4rem, 2.2vw, 0.8rem);
    overflow: hidden;
    /* für Marquee-Effekt auf einer Zeile */
    padding-bottom: clamp(2px, 0.8vw, 8px);
    /* verhindert Abschneiden der Unterkanten */
  }

  .hero__headline-inner {
    flex-direction: row;
    flex-wrap: nowrap;
    /* alles in eine Zeile */
    gap: clamp(0.6rem, 4vw, 1rem);
    white-space: nowrap;
    width: max-content;
    animation: heroMarquee 8s linear infinite;
    will-change: transform;
  }

  .hero__headline-inner .hero__headline-line {
    display: inline;
    white-space: nowrap;
  }

  .hero__headline-inner .hero__headline-line:nth-child(3) {
    flex-basis: auto;
  }

  /* Startseite: Portrait auf Handy weiter nach rechts rücken */
  #hero .hero__media {
    position: relative;
    left: 0;
    top: 0;
    /* keine Überlappung; Strich bleibt sichtbar */
  }

  /* Mobile: Portrait-Animation neu – von unten nach oben, ohne Abdunkeln */
  .hero-animate[data-hero-stage="portrait"] {
    transform: translateY(32px) scale(1);
    filter: none;
    opacity: 0;
  }

  .hero[data-hero-active="true"] .hero-animate[data-hero-stage="portrait"] {
    animation: heroPortraitUp 1000ms cubic-bezier(0.16, 1, 0.3, 1) 80ms forwards !important;
  }

  .hero__name {
    font-size: clamp(1.2rem, 4.2vw + 0.4rem, 1.6rem);
    gap: clamp(0.15rem, 2vw, 0.35rem);
    margin-bottom: clamp(0.2rem, 1.5vw, 0.4rem);
  }

  .hero__name-main {
    white-space: normal;
  }

  .hero__name-line--accent,
  .hero__name-line--sub {
    font-size: clamp(1.05rem, 3.8vw + 0.2rem, 1.35rem);
    letter-spacing: 0.05em;
  }

  .hero__sub {
    max-width: 100%;
    font-size: clamp(0.95rem, 3.4vw, 1rem);
    margin-bottom: clamp(1.5rem, 5.5vw, 1.75rem);
    text-align: left;
  }

  /* Mobile: Sub-Text im Hero ausblenden, damit alles weiter nach oben rutscht */
  #hero .hero__sub {
    display: none;
    margin: 0;
  }

  .hero__media {
    grid-area: hero-media;
    width: var(--hero-portrait-width);
    /* Voll sichtbar, damit keine verdunkelten PNG-Ränder entstehen */
    opacity: 1;
    /* stärker nach oben ziehen (gültige clamp-Reihenfolge: min < max) */
    margin: clamp(-1.8rem, -4vw, -0.9rem) auto 0;
    align-self: end;
  }

  /* Akzentlinie auf Mobile immer sichtbar innerhalb des Bildcontainers */
  .hero__accent--horizontal {
    display: none;
  }

  /* PNG-Rand auf Mobile unsichtbar halten: Schatten/Glow hinter dem Bild entfernen */
  .hero__portrait::after {
    content: none;
  }

  /* Zusätzlich: Drop-Shadow auf Mobile entfernen, um Halos am Rand zu vermeiden */
  .hero__portrait {
    filter: none;
  }

  /* Verschwommenes Hintergrund-Haar: tiefer (~20%) und etwas kleiner */
  body::after {
    /* Noch tiefer auf Mobile setzen */
    top: 8vh;
    width: clamp(680px, 90vw, 1200px);
    height: clamp(680px, 90vw, 1200px);
  }

  .hero__actions {
    grid-area: hero-actions;
    width: 100%;
    max-width: 100%;
    gap: clamp(0.35rem, 2vw, 0.6rem);
    justify-self: start;
    /* linksbündig */
    margin-top: clamp(0.5rem, 3vw, 0.9rem);
    /* dichter */
  }

  .hero__actions .btn {
    width: 100%;
  }

  .offerings__cards {
    gap: clamp(1.8rem, 7vw, 2.6rem);
  }

  .offerings-card {
    grid-template-columns: 1fr;
    gap: clamp(1rem, 5vw, 1.5rem);
    width: 100%;
  }

  .offerings-card__icon {
    width: clamp(3rem, 12vw, 3.4rem);
    height: clamp(3rem, 12vw, 3.4rem);
  }

  /* Duplikat nur mobil einblenden, sonst verstecken */
  .hero__headline-dup {
    display: inline !important;
  }

  /* Desktop-Breath-Animation auf Mobile überschreiben: nur Marquee laufen lassen */
  .hero-animate[data-hero-stage="slogan"] {
    opacity: 1 !important;
    transform: none !important;
  }

  .hero[data-hero-active="true"] .hero-animate[data-hero-stage="slogan"] {
    animation: none !important;
  }

  .hero[data-hero-active="true"] .hero__headline-inner {
    animation: heroMarquee 8s linear infinite !important;
  }
}

/* Standard: Duplikat ausblenden (nur mobil nutzen) */
.hero__headline-dup {
  display: none;
}

/* Marquee-Animation nur für Mobile benutzt */
@keyframes heroMarquee {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}

/* Mobile: neue Portrait-Animation von unten nach oben */
@keyframes heroPortraitUp {
  0% {
    opacity: 0;
    transform: translateY(32px) scale(1);
    filter: none;
  }

  60% {
    opacity: 1;
    transform: translateY(8px) scale(1);
    filter: none;
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: none;
  }
}

@keyframes heroSloganIn {
  0% {
    opacity: 0;
    transform: translateY(44px) scale(0.94);
    filter: blur(1px);
  }

  60% {
    opacity: 1;
    transform: translateY(-6px) scale(1.02);
    filter: blur(0);
  }

  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}

@keyframes heroSloganBreath {
  0% {
    transform: scale(1.02);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes heroBandIn {
  0% {
    opacity: 0;
    transform: scaleX(0.02);
  }

  60% {
    opacity: 1;
    transform: scaleX(1.06);
  }

  100% {
    opacity: 1;
    transform: scaleX(1);
  }
}

@keyframes heroBandVerticalIn {
  0% {
    opacity: 0;
    transform: scaleY(0.1);
  }

  60% {
    opacity: 1;
    transform: scaleY(1.05);
  }

  100% {
    opacity: 1;
    transform: scaleY(1);
  }
}

@keyframes heroPortraitIn {
  0% {
    opacity: 0;
    transform: translate3d(120px, 24px, 0) scale(0.9);
    filter: brightness(0.75);
  }

  65% {
    opacity: 1;
    filter: brightness(1.1);
  }

  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: brightness(1);
  }
}

@keyframes heroNameIn {
  0% {
    opacity: 0;
    transform: translateY(32px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes heroSubIn {
  0% {
    opacity: 0;
    transform: translateX(-28px);
  }

  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes heroCtaIn {
  0% {
    opacity: 0;
    transform: translateY(32px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}



.trustbar {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr auto;
  /* Logos oben, Platz in der Mitte, Button unten */
  gap: clamp(var(--space-3xs), 1vw, var(--space-sm));
  /* Inhalt noch etwas tiefer starten */
  padding-block-start: clamp(var(--space-xs), 2vw, var(--space-md));
  /* Button ganz unten mit leichtem Randabstand: unten nur wenig Padding */
  padding-block-end: clamp(0.25rem, 1vw, 0.6rem);
  /* Flacher: Blau nicht so tief */
  min-height: clamp(180px, 18vw, 320px);
  /* Standard (Light): Baby-Blauton wie im Abschnitt "Aktuelles & Beispiele aus der Praxis" */
  background: #cfe2f3;
}

/* Trustbar Theme-Overrides analog zum Footer */
body[data-theme="light"] .trustbar {
  background: #cfe2f3;
}

body[data-theme="dark"] .trustbar {
  /* Dunkle Blau-Nuance wie im Footer-Dark */
  background: #0a2342;
}

/* Trustbar direkt unter dem Hero deutlich näher heranrücken */
#hero+.trustbar {
  /* direkt unter den Hero (Portrait-Unterkante) */
  margin-block-start: 0;
}

/* Weicher Übergang von Trustbar (hellblau) zu Angebot: Fade im oberen Bereich von #angebot */
#angebot {
  position: relative;
  /* Light: Babyblau (Trustbar) nach transparent ausblenden */
  background: linear-gradient(to bottom,
      #cfe2f3 0%,
      rgba(207, 226, 243, 0) clamp(64px, 10vw, 200px));
}

body[data-theme="dark"] #angebot {
  background: linear-gradient(to bottom,
      #0a2342 0%,
      rgba(10, 35, 66, 0) clamp(64px, 10vw, 200px));
}

.trustbar__marquee {
  margin: 0;
  width: 100%;
  max-width: none;
}

.trustbar__copy {
  display: grid;
  justify-items: end;
  /* rechtsbündig */
  text-align: right;
  gap: 0;
  /* Button an das untere Ende der Trustbar setzen */
  grid-row: 3;
  align-self: end;
  margin-top: 0;
}

/* Überschrift und Text entfernt – nur Button bleibt */

.trustbar__cta {
  min-width: clamp(9rem, 16vw, 11rem);
  justify-self: end;
  /* dezenter Ghost-Button auf Blau: heller Rahmen/Text */
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.9);
  /* etwas kleiner */
  font-size: clamp(0.86rem, 0.3vw + 0.8rem, 0.95rem);
  padding: var(--space-2xs) var(--space-sm);
  /* etwas höher vom unteren Rand positionieren */
  margin-bottom: clamp(1rem, 2.4vw, 1.6rem);
}

.trustbar__cta:hover,
.trustbar__cta:focus-visible {
  color: #ffffff;
  border-color: #ffffff;
  transform: translateY(-1px);
}

.logo-marquee {
  overflow: hidden;
  position: relative;
  width: 100%;
  /* nur etwas tiefer als zuvor */
  margin-top: clamp(var(--space-xs), 2vw, var(--space-md));
}

.logo-marquee__mask {
  position: relative;
  overflow: hidden;
  width: 100%;
}

.logo-marquee__track {
  display: flex;
  align-items: center;
  gap: clamp(var(--space-md), 4vw, var(--space-xl));
  will-change: transform;
  /* Fallback/CSS-Marquee: sorgt für Bewegung auch wenn JS stoppt */
  animation: quote-marquee-scroll 16s linear infinite;
}

.logo-marquee__item {
  flex: 0 0 auto;
  min-width: clamp(160px, 18vw, 260px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(var(--space-2xs), 1.5vw, var(--space-sm));
  filter: none;
  opacity: 1;
  transition: transform var(--speed-fast) ease;
}

.logo-marquee__item:hover,
.logo-marquee__item:focus-within {
  transform: scale(1.05);
}

.logo-marquee__item img {
  height: clamp(48px, 9vw, 96px);
  max-width: clamp(160px, 24vw, 260px);
  width: auto;
  object-fit: contain;
  display: block;
}

/* Mobile: Logos in der Trustbar etwas größer darstellen */
@media (max-width: 540px) {

  /* Mobile: Hide original mailto action, show toggle when injected */
  .cases__grid>.card .card__actions .card__link[href^="mailto:"] {
    display: none;
  }

  .cases__grid>.card .card__toggle {
    display: inline-flex;
  }

  /* When open: show mailto as "Mehr erfahren" */
  .cases__grid>.card.is-open .card__actions .card__link[href^="mailto:"] {
    display: inline-flex;
  }

  /* Hide direct paragraphs initially until JS wraps them */
  .cases__grid>.card>p {
    display: none;
  }

  /* Actions row: left button, right logo aligned */
  .cases__grid>.card .card__actions {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    width: 100%;
    margin-top: clamp(0.5rem, 3vw, 0.8rem);
    flex-wrap: nowrap;
  }

  .cases__grid>.card .card__logo {
    position: static;
    margin-left: auto;
    height: clamp(36px, 8vw, 44px);
  }

  .trustbar {
    padding-block-start: clamp(0rem, 1.5vw, 0.5rem);
  }

  .logo-marquee__item {
    min-width: clamp(180px, 60vw, 240px);
    padding: clamp(var(--space-2xs), 2.2vw, var(--space-sm));
  }

  .logo-marquee__item img {
    height: clamp(58px, 14vw, 96px);
    max-width: clamp(180px, 52vw, 260px);
  }
}

.logo-marquee__fallback .badge {
  background: rgba(127, 140, 169, 0.08);
  color: var(--muted-current, var(--muted));
}


.offerings {
  position: relative;
  background: var(--surface-current, var(--surface));
  color: var(--fg-current, var(--fg));
  overflow: hidden;
}

.offerings__layout {
  display: grid;
  grid-template-columns: minmax(0, 0.44fr) minmax(0, 0.56fr);
  gap: clamp(var(--space-xl), 8vw, calc(var(--space-2xl) * 1.1));
  align-items: start;
}

.offerings__intro {
  display: grid;
  gap: clamp(var(--space-sm), 2vw, var(--space-lg));
  max-width: clamp(320px, 40vw, 32rem);
}

.offerings__intro h2 {
  margin: 0;
  font-size: clamp(2rem, 2.8vw, 2.8rem);
}

.offerings__quote {
  margin: 0;
  font-style: italic;
  font-size: clamp(1.2rem, 1.1vw + 1rem, 1.6rem);
  line-height: 1.5;
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 82%, transparent);
}

.offerings__body {
  margin: 0;
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 72%, transparent);
  line-height: 1.65;
  max-width: 36ch;
}

.offerings__cards {
  display: grid;
  gap: clamp(1.8rem, 4vw, 3rem);
  align-content: start;
}

.offerings-card {
  --card-bg: rgba(12, 60, 110, 0.08);
  --card-bg-hover: rgba(12, 60, 110, 0.14);
  --card-text: color-mix(in srgb, var(--fg-current, var(--fg)) 95%, transparent);
  --card-icon-color: var(--card-text);
  position: relative;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1.2rem, 2vw, 2.4rem);
  align-items: center;
  padding: clamp(2.1rem, 3vw, 3.2rem);
  border-radius: clamp(0.85rem, 1.2vw, 1.2rem);
  text-decoration: none;
  color: var(--card-text);
  background: var(--card-bg);
  border: none;
  box-shadow: none;
  transition: transform 240ms var(--hero-ease), background-color 240ms var(--hero-ease);
}

.offerings-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(2.6rem, 4.2vw, 3rem);
  height: clamp(2.6rem, 4.2vw, 3rem);
  color: var(--card-icon-color);
}

.offerings-card__icon svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
  fill: none;
}

.offerings-card__content {
  display: grid;
  gap: clamp(0.35rem, 1vw, 0.75rem);
  justify-items: flex-start;
}

.offerings-card__eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-size: clamp(0.92rem, 0.38vw + 0.85rem, 1.05rem);
  font-weight: 600;
  color: var(--card-text);
}

.offerings-card__description {
  margin: 0;
  font-size: clamp(0.98rem, 0.34vw + 0.9rem, 1.06rem);
  line-height: 1.58;
  color: var(--card-text);
}

.offerings-card:hover .offerings-card__eyebrow,
.offerings-card:focus-visible .offerings-card__eyebrow,
.offerings-card:hover .offerings-card__description,
.offerings-card:focus-visible .offerings-card__description {
  color: var(--card-text);
}

.offerings-card:hover,
.offerings-card:focus-visible {
  transform: scale(1.04);
  background: var(--card-bg-hover);
}

.offerings-card:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.3);
  outline-offset: 4px;
}

.offerings-card--unternehmen {
  --card-bg: color-mix(in srgb, var(--primary) 70%, rgba(12, 24, 36, 0.18));
  --card-bg-hover: color-mix(in srgb, var(--primary) 82%, rgba(12, 24, 36, 0.18));
  --card-text: rgba(248, 251, 255, 0.95);
  --card-icon-color: rgba(248, 251, 255, 0.95);
}

.offerings-card--sportler {
  --card-bg: color-mix(in srgb, #1ba4e5 58%, rgba(15, 40, 68, 0.12));
  --card-bg-hover: color-mix(in srgb, #1ba4e5 70%, rgba(15, 40, 68, 0.12));
  --card-text: rgba(10, 28, 40, 0.88);
  --card-icon-color: rgba(10, 28, 40, 0.88);
}

.offerings-card--privat {
  --card-bg: color-mix(in srgb, #228369 62%, rgba(12, 34, 28, 0.12));
  --card-bg-hover: color-mix(in srgb, #228369 74%, rgba(12, 34, 28, 0.12));
  --card-text: rgba(245, 250, 247, 0.96);
  --card-icon-color: rgba(245, 250, 247, 0.96);
}

.method {
  position: relative;
}

.method__wrapper {
  max-width: min(900px, 92vw);
  margin: 0 auto;
  display: grid;
  gap: clamp(2.4rem, 5vw, 3.4rem);
}

.method__header {
  display: grid;
  gap: clamp(0.8rem, 1.6vw, 1.2rem);
  align-content: start;
}

.method__header h2 {
  margin: 0;
  font-size: clamp(2.4rem, 4vw, 3.4rem);
}

.method__subtitle {
  margin: 0;
  font-size: clamp(1.05rem, 1.2vw, 1.3rem);
  color: var(--muted-current, var(--muted));
}

.method__block {
  background: var(--surface-current, var(--surface));
  box-shadow: var(--shadow-elev-1);
  border-radius: clamp(0.6rem, 1vw, 1rem);
  padding: clamp(1.6rem, 3vw, 2.6rem);
  display: grid;
  gap: clamp(0.8rem, 1.6vw, 1.2rem);
  position: relative;
}

.method__block+.method__block {
  margin-top: clamp(1.2rem, 3vw, 1.8rem);
}

.method__eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: clamp(0.75rem, 0.2vw + 0.72rem, 0.9rem);
  font-weight: 600;
  color: var(--muted-current, var(--muted));
}

.method__block p {
  margin: 0;
  line-height: 1.7;
}

.method__block--quote {
  background: linear-gradient(140deg, rgba(12, 60, 110, 0.12), rgba(12, 60, 110, 0.04) 70%),
    var(--surface-current, var(--surface));
  border-left: 4px solid rgba(12, 60, 110, 0.35);
  padding-inline-start: clamp(1.8rem, 3.2vw, 2.8rem);
}

.method__block--quote blockquote {
  margin: 0;
  font-size: clamp(1.1rem, 2vw, 1.5rem);
  font-style: italic;
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 78%, transparent);
}

.method__block--quote blockquote p {
  margin: 0;
}

@media (max-width: 640px) {
  .method__wrapper {
    text-align: center;
    gap: clamp(2rem, 6vw, 2.5rem);
  }

  .method__block {
    text-align: center;
  }
}

body[data-theme="dark"] .method__block--quote {
  background: linear-gradient(140deg, rgba(122, 162, 255, 0.14), rgba(122, 162, 255, 0.06) 70%),
    var(--surface-current, var(--surface));
  border-left-color: rgba(122, 162, 255, 0.45);
}

body[data-theme="dark"] .method__block--quote blockquote {
  color: rgba(240, 244, 255, 0.85);
}

.offerings__cards .offerings-card.reveal {
  transition-delay: var(--card-reveal-delay, 0s);
}

.offerings__cards .offerings-card.reveal:nth-of-type(1) {
  --card-reveal-delay: 0.1s;
}

.offerings__cards .offerings-card.reveal:nth-of-type(2) {
  --card-reveal-delay: 0.28s;
}

.offerings__cards .offerings-card.reveal:nth-of-type(3) {
  --card-reveal-delay: 0.46s;
}

.offerings__cards .offerings-card.reveal.is-visible {
  transition-delay: 0s;
}

.quote-marquee {
  margin-top: clamp(var(--space-lg), 4vw, var(--space-xl));
  position: relative;
}

.quote-marquee__mask {
  overflow: hidden;
  position: relative;
  mask-image: linear-gradient(90deg, transparent, rgba(0, 0, 0, 1) 10%, rgba(0, 0, 0, 1) 90%, transparent);
}

.quote-track {
  display: flex;
  align-items: stretch;
  gap: clamp(var(--space-sm), 3vw, var(--space-lg));
  animation: quote-marquee-scroll 26s linear infinite;
}

.quote-marquee:hover .quote-track,
.quote-marquee:focus-within .quote-track {
  animation-play-state: paused;
}

.quote-card {
  flex: 0 0 min(320px, 80vw);
  padding: clamp(var(--space-sm), 3vw, var(--space-lg));
  display: grid;
  gap: var(--space-sm);
  background: rgba(255, 255, 255, 0.04);
  border-radius: var(--radius-lg);
  border: 1px solid rgba(127, 140, 169, 0.15);
  box-shadow: var(--shadow-elev-1);
}

.quote-card__avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(127, 140, 169, 0.4), rgba(127, 140, 169, 0.12));
}

.quote-card blockquote {
  margin: 0;
  font-style: italic;
  color: var(--fg-current, var(--fg));
}

.quote-card footer {
  font-size: 0.85rem;
  color: var(--muted-current, var(--muted));
  line-height: 1.4;
}

@keyframes offer-card-in {
  0% {
    opacity: 0;
    transform: translateY(12px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes quote-marquee-scroll {
  0% {
    transform: translateX(0);
  }

  100% {
    transform: translateX(-50%);
  }
}


.cases__layout {
  display: grid;
  gap: clamp(var(--space-lg), 5vw, var(--space-2xl));
}

.cases__grid {
  display: grid;
  gap: var(--space-md);
}

/* Actions der ersten zwei Cards kompakt nebeneinander (alle Viewports) */
.cases__grid>.card:nth-child(-n+2) .card__actions {
  display: flex;
  align-items: center;
  gap: clamp(0.35rem, 1.2vw, 0.6rem);
  flex-wrap: nowrap;
}

.cases__grid>.card:nth-child(-n+2) .card__actions .card__link,
.cases__grid>.card:nth-child(-n+2) .card__actions .card__toggle {
  font-size: clamp(0.82rem, 0.3vw + 0.78rem, 0.95rem);
  padding: var(--space-3xs) var(--space-xs);
  border: 1px solid currentColor;
  border-radius: var(--radius-md);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.cases__grid>.card:nth-child(-n+2) .card__actions .card__link:hover,
.cases__grid>.card:nth-child(-n+2) .card__actions .card__link:focus-visible,
.cases__grid>.card:nth-child(-n+2) .card__actions .card__toggle:hover,
.cases__grid>.card:nth-child(-n+2) .card__actions .card__toggle:focus-visible {
  color: var(--primary);
  border-color: var(--primary);
}

/* Größere Überschrift für "Beispiele aus der Praxis" */
#cases #cases-title {
  font-size: clamp(2.2rem, 5.5vw, 3.4rem);
  line-height: 1.08;
}

/* Linke Cards: Überschrift/Copy-Abstände stark verringern */
.cases__grid>.card {
  gap: var(--space-3xs);
}

.cases__grid>.card h3,
.cases__grid>.card p {
  margin: 0;
}

.cases__right {
  display: grid;
  gap: var(--space-2xs);
  align-content: start;
}

/* Enge Abstände für Headline + Infotext direkt über der rechten Karte */
.cases__right .section__head {
  margin-bottom: var(--space-3xs);
  gap: var(--space-3xs);
}

.cases__right .section__head h3,
.cases__right .section__head p {
  margin: 0;
}

/* Smaller body copy for the two static cards under "Aktuelles & Stimmen" */
.cases__grid>.card p {
  font-size: clamp(0.9rem, 0.4vw + 0.84rem, 1rem);
  line-height: 1.45;
}

/* Cases cards: collapsible body via toggle */
.cases__grid>.card .card__body {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height 320ms ease, opacity 240ms ease, transform 240ms ease;
}

.cases__grid>.card.is-open .card__body {
  max-height: 1000px;
  /* groß genug, damit kompletter Text sichtbar wird */
  opacity: 1;
  transform: translateY(0);
  overflow: visible;
}

.cases__grid>.card .card__toggle[aria-expanded="true"] {
  font-weight: 600;
}

/* Abschnitt-Hintergrund bei "Aktuelles & Beispiele aus der Praxis" entfernen */
.cases {
  background: transparent;
}

/* Auch alle Hüllen im Bereich transparent halten (Karten behalten ihren eigenen Hintergrund) */
.cases .container,
.cases__layout,
.cases__right,
.cases__right .section__head {
  background: transparent;
}


.carousel {
  position: relative;
  --carousel-pad: clamp(var(--space-md), 4vw, var(--space-xl));
  padding: var(--carousel-pad);
  border-radius: var(--radius-md);
  background: var(--surface-current, var(--surface));
  box-shadow: var(--shadow-elev-1);
  overflow: hidden;
  touch-action: pan-y;
  /* avoid horizontal scroll conflict on mobile */
}

.carousel--compact {
  --carousel-pad: clamp(var(--space-sm), 3.2vw, calc(var(--space-xl) * 0.8));
}

.carousel__inner {
  display: flex;
  flex-wrap: nowrap;
  width: 100%;
  transition: transform var(--speed-slow) ease;
  will-change: transform;
}

.carousel__item {
  display: grid;
  gap: var(--space-sm);
  flex: 0 0 100%;
}

/* Kompaktere Karte: geringere Höhe und Footer (Name) immer unten bündig */
.carousel--compact .carousel__item {
  grid-template-rows: 1fr auto;
  /* Inhalt füllt, Footer unten */
  min-height: clamp(180px, 24vw, 260px);
}

.carousel--compact blockquote {
  margin: 0;
}

.carousel--compact .carousel__meta {
  margin-top: var(--space-xs);
}

.carousel__controls {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.carousel__dots {
  position: absolute;
  left: 50%;
  bottom: clamp(0.5rem, 2.5vw, 1.1rem);
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: var(--space-3xs);
  z-index: 3;
  pointer-events: auto;
}

.carousel__dot {
  width: 6px;
  height: 6px;
  border-radius: 2px;
  /* dezenter, nicht voll rund */
  border: 1px solid rgba(10, 35, 66, 0.35);
  background: transparent;
  cursor: pointer;
}

.carousel__dot.is-active {
  background: rgba(10, 35, 66, 0.85);
  border-color: rgba(10, 35, 66, 0.55);
}

.carousel__item[aria-hidden="true"] {
  visibility: hidden;
  pointer-events: none;
}

.carousel__btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(40px, 5vw, 50px);
  height: clamp(40px, 5vw, 50px);
  border-radius: 50%;
  border: 1px solid rgba(10, 35, 66, 0.18);
  background: rgba(255, 255, 255, 0.9);
  color: rgba(10, 35, 66, 0.7);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: background var(--speed-fast) ease, color var(--speed-fast) ease, transform var(--speed-fast) ease,
    border-color var(--speed-fast) ease;
  pointer-events: auto;
}

.carousel__btn:hover,
.carousel__btn:focus-visible {
  background: rgba(10, 35, 66, 0.14);
  border-color: rgba(10, 35, 66, 0.28);
  color: rgba(10, 35, 66, 0.88);
  outline: none;
  transform: translateY(-50%) scale(1.03);
}

.carousel__btn--prev {
  left: clamp(0.6rem, 2vw, 1.2rem);
}

.carousel__btn--next {
  right: clamp(0.6rem, 2vw, 1.2rem);
}

.carousel__icon {
  width: 1.15em;
  height: 1.15em;
}

.about__layout {
  display: grid;
  gap: clamp(28px, 5vw, 72px);
  align-items: start;
  /* Bild und Überschrift oben bündig */
  grid-template-columns: minmax(280px, 1fr) minmax(420px, 1.5fr);
  /* Wichtig: Kein Overflow beschneiden, damit sticky sicher greift */
  overflow: visible;
}

/* Linke Spalte auf Grid-Reihenhöhe strecken, damit Sticky bis Sektionsende wirkt */
.about__layout .col-left {
  align-self: stretch;
}

.sticky-layout .col-left {
  position: relative;
}

.sticky-layout .col-left .sticky-box {
  position: static;
}

/* Robust Sticky direkt am Porträt-Container */
.sticky-layout .col-left .portrait {
  margin: 0;
}

@media (min-width: 1024px) {

  /* JS steuert das Fixieren vollständig – keinen CSS-Sticky nutzen */
  .sticky-layout .col-left .sticky-box {
    position: static;
  }

  .sticky-layout .col-left .portrait img {
    max-width: 100%;
    height: auto;
    /* Luft oben (top: 2rem) + Platz für Caption (~4.5rem) unten */
    max-height: calc(100vh - 2rem - 4.5rem);
    object-fit: cover;
  }
}

@media (max-width: 1023px) {
  .about__layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .sticky-layout .col-left {
    position: static;
  }

  .sticky-layout .about__media {
    position: static;
  }

  .sticky-layout .col-left .sticky-box {
    position: static;
  }

  .sticky-layout .col-left .portrait {
    position: static;
    max-height: none;
    overflow: visible;
  }
}

/* Sticky Fallback Klassen */
.sticky-layout .col-left .sticky-box.is-fixed {
  position: fixed;
  top: var(--sticky-offset, 96px);
  left: var(--sticky-left, 0px);
  width: var(--sticky-width, auto);
}

.sticky-layout .col-left .sticky-box.is-fixed-bottom {
  position: fixed;
  bottom: var(--sticky-offset, 96px);
  left: var(--sticky-left, 0px);
  width: var(--sticky-width, auto);
}

.sticky-layout .col-left .sticky-box.is-bottom {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
}

.portrait {
  display: grid;
  gap: var(--space-xs);
}

.portrait {
  margin: 0;
}

.portrait img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-elev-2);
  /* Hintergrund in Weiß für saubere Kartenoptik, keine Farbe */
  background: #fff;
}

/* Bildunterschrift unter dem Porträt */
.portrait figcaption {
  font-size: 0.85rem;
  color: #444;
  text-align: center;
  line-height: 1.4;
}

/* About: zentrierter, begrenzter Abschnitt */
.about {
  overflow: visible;
}

.about .container {
  max-width: 1200px;
  margin-inline: auto;
}

/* Lesbarkeit in der rechten Spalte steigern */
.about__copy {
  max-width: 68ch;
}

/* About: nur die rechte Textspalte hellblau hinterlegen */
/* Entferne hellblauen Hintergrund in der rechten Textspalte (Über mich) */
body[data-theme="light"] .about__copy,
body[data-theme="dark"] .about__copy {
  background: transparent;
  border-radius: 0;
  padding: 0;
}

/* Mehr Luft zwischen Porträt/Caption und "Mentale Haltung" in der linken Spalte */
.about__media .about__section {
  /* Mehr Luft zwischen Porträt/Caption und dem Abschnitt „Mentale Haltung“ */
  margin-top: clamp(var(--space-xl), 8vw, var(--space-2xl));
}

/* Über mich – typografische Gliederung */
.about__copy {
  display: grid;
  gap: clamp(16px, 3vw, 40px);
}

.about__subtitle {
  margin: 0;
  color: rgba(10, 35, 66, 0.7);
  font-size: clamp(1rem, 0.5vw + 0.95rem, 1.2rem);
}

.about__section {
  display: grid;
  gap: clamp(var(--space-sm), 2.2vw, var(--space-md));
}

.about__section-title {
  margin: 0;
  font-size: clamp(1.15rem, 0.6vw + 1rem, 1.45rem);
  letter-spacing: 0.02em;
}

.about__list {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 0.35rem;
}

.about__divider {
  border: 0;
  height: 1px;
  background: rgba(10, 35, 66, 0.15);
  margin: clamp(var(--space-sm), 2.5vw, var(--space-md)) 0;
}

.about__quote {
  margin: 0;
}

.about__quote blockquote {
  margin: 0;
  font-size: clamp(1.15rem, 0.8vw + 1rem, 1.6rem);
  font-weight: 600;
  line-height: 1.35;
}

.about-quote {
  padding-block: clamp(var(--space-lg), 6vw, var(--space-2xl));
}

/* Disclosure Buttons + Panels (kompakt, seriös) */
.btn--disclosure {
  margin-top: var(--space-2xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  /* gleiche kompakte Höhe/Optik wie der CTA "Erstgespräch sichern" */
  padding: var(--space-3xs) var(--space-xs);
  border: 1px solid currentColor;
  border-radius: var(--radius-md);
}

.disclosure {
  display: grid;
  gap: var(--space-2xs);
}

.disclosure__panel {
  border: 1px solid rgba(10, 35, 66, 0.12);
  background: var(--surface-current, var(--surface));
  border-radius: var(--radius-sm);
  padding: clamp(var(--space-sm), 2vw, var(--space-md));
}

.about__values {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2xs);
}

.cta {
  position: relative;
  color: var(--fg-current, var(--fg));
  text-align: center;
  /* wieder größer, aber nicht ganz so hoch wie anfangs */
  padding-block-start: clamp(var(--space-xl), 8vw, var(--space-2xl));
  padding-block-end: clamp(4rem, 12vw, 14rem);
  overflow: visible;
  /* Bild darf herausragen */
  /* Hintergrundbild wird via ::before gelegt, damit es unten transparent ausfaden kann */
  background: none;
}

/* Hintergrundbild mit echter Transparenz nach unten (nur Bild wird ausgeblendet, Inhalt bleibt deckend) */
.cta::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../images/natur.jpg") center / cover no-repeat;
  z-index: 0;
  pointer-events: none;
  /* Längerer, weicherer Fade nach unten: beginnt früher und läuft bis 100% */
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 60%, rgba(0, 0, 0, 0) 100%);
  mask-image: linear-gradient(to bottom, #000 0%, #000 60%, rgba(0, 0, 0, 0) 100%);
}

/* Dark Mode: Hintergrundbild stärker abdunkeln */
body[data-theme="dark"] .cta::before {
  filter: brightness(0.5) contrast(1.05) saturate(0.9);
}

/* Kein Overlay-Gradient unten: Transparenz entsteht durch Mask des Hintergrundbilds */
.cta::after {
  display: none;
  content: none;
}

/* Dark-Mode nutzt automatisch var(--bg-current) */

.cta__inner {
  display: grid;
  gap: var(--space-sm);
  justify-items: center;
  position: relative;
  /* Heading above images */
  z-index: 3;
}

/* CTA: Fließtext in dunklem Grau statt Schwarz */
.cta__inner p {
  color: #444;
}

/* Mobile: CTA höher und Umschlag mittig über dem Text platzieren */
@media (max-width: 540px) {
  .cta {
    /* grünen Bereich deutlich vergrößern (ca. doppelt) */
    padding-block-start: clamp(var(--space-3xl), 28vw, var(--space-4xl));
    padding-block-end: clamp(8rem, 36vw, 16rem);
  }

  .cta__media {
    position: relative;
    /* im Fluss, damit Text darunter liegt */
    top: 0;
    right: auto;
    left: auto;
    margin: 0 auto;
    width: clamp(180px, 65vw, 360px);
    height: clamp(180px, 65vw, 360px);
    transform-origin: top center;
    transform: none;
    z-index: 1;
    /* unter #cta-title, Text folgt darunter */
    margin-bottom: clamp(6rem, 24vw, 12rem);
    /* viel tiefer: großer Abstand zum Text */
  }

  /* Text unter dem Umschlag, mehr Abstand */
  .cta__inner {
    z-index: 2;
    gap: clamp(var(--space-md), 5vw, var(--space-xl));
    margin-top: 0;
  }

  .cta__inner p {
    margin-top: clamp(1.2rem, 6vw, 2rem);
  }

  .cta__inner .btn {
    margin-top: clamp(1.8rem, 8vw, 3rem);
  }

  /* Bildausrichtung beim Crossfade mittig halten (kein Rechtsversatz) */
  .cta__media img {
    object-fit: contain;
    object-position: center top;
  }

  /* Aktivierung behält Zentrierung + Skaliert beim Öffnen */
  .cta:is(:hover, :focus-within) .cta__media,
  .cta.is-activated .cta__media {
    transform: scale(1.12);
  }

  /* Wenn geöffnet, zusätzlichen Abstand geben, damit nichts überlappt */
  .cta.is-activated .cta__media {
    margin-bottom: clamp(8rem, 30vw, 16rem);
  }
}

/* CTA: Textbereich schmaler (ca. halbe Breite auf Desktop) */
@media (min-width: 900px) {
  .cta__inner p {
    max-width: 50%;
  }
}

/* CTA – Briefbild oben rechts mit Cross‑Fade und Scale auf Hover */
.cta__media {
  position: absolute;
  top: -4rem;
  /* noch höher positionieren */
  right: clamp(var(--space-md), 6vw, var(--space-2xl));
  width: clamp(180px, 26vw, 340px);
  height: clamp(180px, 26vw, 340px);
  /* größere Box für prominenteres Bild */
  z-index: 2;
  transform-origin: bottom right;
}

/* beide Bilder exakt deckungsgleich platzieren */
.cta__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right bottom;
  transition: opacity 280ms ease, transform 320ms ease;
}

.cta__img {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.cta__img--alt {
  position: absolute;
  inset: 0;
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}

/* CTA title size */
.cta__inner h2 {
  font-size: clamp(2.2rem, 4.8vw, 3rem);
  line-height: 1.08;
}

/* Hover/focus effect and programmatic activation (.is-activated) */
.cta:is(:hover, :focus-within),
.cta.is-activated {}

.cta:is(:hover, :focus-within) .cta__media,
.cta.is-activated .cta__media {
  transform: scale(1.12);
}

.cta:is(:hover, :focus-within) .cta__img--alt,
.cta.is-activated .cta__img--alt {
  opacity: 1;
}

.cta:is(:hover, :focus-within) .cta__media .cta__img:not(.cta__img--alt),
.cta.is-activated .cta__media .cta__img:not(.cta__img--alt) {
  opacity: 0;
}

/* Mobile (strong override placed AFTER base CTA rules):
   - Keep envelope in normal flow at top
   - Push text + button far below
   - Ensure crossfade stays centered (no right shift)
*/
@media (max-width: 540px) {
  .cta {
    padding-block-start: clamp(var(--space-2xl), 22vw, var(--space-3xl));
    padding-block-end: clamp(7rem, 30vw, 14rem);
  }

  .cta__media {
    position: relative !important;
    top: 0 !important;
    left: auto !important;
    right: auto !important;
    margin: 0 auto;
    width: clamp(180px, 65vw, 360px);
    height: clamp(180px, 65vw, 360px);
    transform-origin: top center;
    transform: none !important;
    z-index: 1;
    margin-bottom: clamp(4.5rem, 18vw, 9rem);
  }

  .cta__media img {
    object-fit: contain !important;
    object-position: center top !important;
  }

  .cta__inner {
    z-index: 2;
    gap: clamp(var(--space-md), 5vw, var(--space-xl));
  }

  .cta__inner p {
    margin-top: clamp(0.9rem, 5vw, 1.6rem);
  }

  .cta__inner .btn {
    margin-top: clamp(1.4rem, 7vw, 2.4rem);
  }

  .cta:is(:hover, :focus-within) .cta__media,
  .cta.is-activated .cta__media {
    transform: scale(1.12) !important;
  }

  .cta.is-activated .cta__media {
    margin-bottom: clamp(6rem, 24vw, 12rem);
  }
}

.faq .accordion {
  display: grid;
  gap: var(--space-sm);
}

.accordion__item {
  border-radius: var(--radius-md);
  border: 1px solid rgba(127, 140, 169, 0.2);
  background: var(--surface-current, var(--surface));
  box-shadow: var(--shadow-elev-1);
}

.accordion__trigger {
  all: unset;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  padding: clamp(var(--space-sm), 2vw, var(--space-md)) clamp(var(--space-md), 3vw, var(--space-lg));
  cursor: pointer;
  font-weight: 600;
}

.accordion__trigger span:first-child {
  flex: 1;
  padding-inline-end: var(--space-sm);
}

.accordion__icon {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1px solid rgba(127, 140, 169, 0.4);
  position: relative;
}

.accordion__icon::before,
.accordion__icon::after {
  content: "";
  position: absolute;
  inset: 50%;
  width: 8px;
  height: 1px;
  background: currentColor;
  transform: translate(-50%, -50%);
  transition: transform var(--speed-fast) ease;
}

.accordion__icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.accordion__trigger[aria-expanded="true"] .accordion__icon::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.accordion__panel {
  display: none;
  padding: 0 clamp(var(--space-md), 3vw, var(--space-lg)) clamp(var(--space-md), 3vw, var(--space-lg));
  color: var(--muted-current, var(--muted));
}

.accordion__panel.is-open {
  display: block;
}

.contact__layout {
  display: grid;
  gap: clamp(var(--space-lg), 5vw, var(--space-2xl));
}

#kontakt {
  scroll-margin-top: calc(var(--header-height) + var(--space-lg));
}

.contact__details {
  display: grid;
  gap: var(--space-xs);
  color: var(--muted-current, var(--muted));
}

.contact__form {
  display: grid;
  gap: var(--space-sm);
  padding: clamp(var(--space-md), 4vw, var(--space-xl));
  background: var(--surface-current, var(--surface));
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-elev-1);
}

.form-field {
  display: grid;
  gap: var(--space-2xs);
}

.form-field--consent {
  display: grid;
  gap: var(--space-2xs);
  align-items: start;
}

.form-field--consent label {
  display: grid;
  gap: var(--space-2xs);
}

input[type="text"],
input[type="email"],
textarea {
  border: 1px solid rgba(127, 140, 169, 0.3);
  border-radius: var(--radius-sm);
  padding: var(--space-2xs) var(--space-sm);
  background: transparent;
  transition: border-color var(--speed-fast) ease, box-shadow var(--speed-fast) ease;
}

input[type="text"]:focus-visible,
input[type="email"]:focus-visible,
textarea:focus-visible {
  border-color: var(--primary);
  box-shadow: 0 0 0 4px rgba(31, 60, 136, 0.2);
}

.site-footer {
  padding-block: clamp(var(--space-lg), 4vw, var(--space-xl));
  border-top: 1px solid rgba(127, 140, 169, 0.15);
  background: rgba(5, 7, 10, 0.95);
  color: rgba(255, 255, 255, 0.85);
}

/* Footer Farbschema – Light Mode an die hellblauen Sportler-Cards (#cfe2f3) angelehnt */
body[data-theme="light"] .site-footer {
  background: #cfe2f3;
  border-top-color: rgba(10, 35, 66, 0.15);
  color: #0a2342;
}

/* Footer Farbschema – Dark Mode passende dunkle Blau-Nuance */
body[data-theme="dark"] .site-footer {
  background: #0a2342;
  border-top-color: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.9);
}

/* Links & Typografie im Footer an neue Farben angepasst */
body[data-theme="light"] .site-footer a {
  color: #0a2342;
  text-decoration: none;
  opacity: 0.9;
}

body[data-theme="light"] .site-footer a:hover,
body[data-theme="light"] .site-footer a:focus-visible {
  opacity: 1;
  text-decoration: underline;
}

body[data-theme="dark"] .site-footer a {
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
}

body[data-theme="dark"] .site-footer a:hover,
body[data-theme="dark"] .site-footer a:focus-visible {
  color: #ffffff;
  text-decoration: underline;
}

/* Dezente Anpassung der Meta-Texte für bessere Lesbarkeit je Theme */
body[data-theme="light"] .site-footer__copyright {
  color: rgba(10, 35, 66, 0.65);
}

body[data-theme="dark"] .site-footer__copyright {
  color: rgba(255, 255, 255, 0.7);
}

.site-footer__inner {
  display: grid;
  gap: var(--space-lg);
}

.site-footer__nav ul,
.site-footer__legal,
.site-footer__social {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-2xs);
}

.site-footer__social {
  grid-auto-flow: column;
  justify-content: start;
}

.site-footer__legal {
  grid-auto-flow: column;
  justify-content: start;
}

.site-footer__legal a {
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: clamp(0.75rem, 0.16vw + 0.72rem, 0.85rem);
}

.site-footer__meta {
  display: grid;
  gap: var(--space-sm);
}

.site-footer__copyright {
  color: rgba(255, 255, 255, 0.6);
  font-size: clamp(0.75rem, 0.16vw + 0.7rem, 0.9rem);
}

.legal-page {
  background: var(--bg-current, var(--bg));
  color: var(--fg-current, var(--fg));
}

.legal-header,
.legal-footer {
  background: transparent;
  border: none;
  box-shadow: none;
}

.legal-header__inner,
.legal-footer__inner,
.legal-content__inner {
  display: grid;
  gap: var(--space-lg);
}

.legal-content {
  padding-block: clamp(var(--space-lg), 6vw, var(--space-2xl));
}

.legal-content section {
  display: grid;
  gap: var(--space-2xs);
  padding-block: var(--space-sm);
}

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity var(--speed-slow) ease, transform var(--speed-slow) ease;
}

.reveal.is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .logo-marquee__track {
    animation: none;
  }

  .offer-panels {
    transition: none;
  }

  .offer-panel[hidden] {
    display: none !important;
  }

  .offer-card {
    opacity: 1;
    transform: none;
    animation: none !important;
  }

  .quote-track {
    animation: none;
    flex-wrap: wrap;
    justify-content: center;
  }

  html::before,
  html::after,
  main::before {
    animation: none !important;
    opacity: 1 !important;
  }

  .reveal {
    opacity: 1;
    transform: none;
  }

  .hero-animate {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
  }

  .hero__headline-inner {
    animation: none !important;
    transform: none !important;
  }

}

@media (min-width: 640px) {
  .site-header__inner {
    gap: clamp(var(--space-sm), 2.4vw, var(--space-lg));
  }

  .hero__actions {
    align-items: flex-start;
  }

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

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

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

  .site-footer__inner {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
  }
}

@media (min-width: 900px) {
  .site-header__controls {
    gap: clamp(1rem, 2vw, 1.5rem);
  }

  .site-nav {
    position: static;
    display: flex;
    justify-content: center;
    align-items: center;
    background: transparent;
    backdrop-filter: none;
    padding: 0;
    justify-self: center;
    align-self: center;
    width: auto;
    min-height: 0;
    transform: none;
    box-shadow: none;
    border-radius: 0;
    max-height: none;
    overflow: visible;
  }

  .site-nav__list {
    display: flex;
    justify-content: center;
    gap: clamp(0.4rem, 1.6vw, 1rem);
    flex-wrap: wrap;
    font-size: clamp(0.78rem, 0.2vw + 0.74rem, 0.95rem);
    letter-spacing: 0.12em;
  }

  .site-nav__list a {
    position: relative;
    padding: var(--space-2xs) var(--space-xs);
    display: inline-flex;
    align-items: center;
    line-height: 1.2;
  }

  .site-nav__list a::after {
    content: "";
    position: absolute;
    inset-inline: 20%;
    inset-block-end: -6px;
    height: 2px;
    background: currentColor;
    opacity: 0;
    transform: scaleX(0);
    transition: transform var(--speed-fast) ease, opacity var(--speed-fast) ease;
  }

  .site-nav__list a:focus-visible::after,
  .site-nav__list a:hover::after {
    opacity: 1;
    transform: scaleX(1);
  }

  .site-nav__list a[aria-current="page"]::after {
    opacity: 1;
    transform: scaleX(1);
  }

  /* Dropdown unter "Angebot" (Desktop) */
  .site-nav__item.has-submenu {
    position: relative;
  }

  .site-nav__item.has-submenu>.site-nav__link {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
  }

  .site-nav__item.has-submenu>.site-nav__link::after {
    content: "\25BE";
    /* ▼ */
    font-size: 0.8em;
    opacity: 0.7;
  }

  .site-subnav {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    min-width: 220px;
    list-style: none;
    margin: 0;
    padding: 0.5rem 0.4rem;
    background: var(--surface-current, var(--surface));
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-elev-2);
    border: 1px solid rgba(127, 140, 169, 0.18);
    display: none;
    z-index: 1200;
  }

  /* Hover-Bridge: verhindert Lücke zwischen Trigger und Dropdown */
  .site-subnav::before {
    content: "";
    position: absolute;
    top: -10px;
    left: 0;
    right: 0;
    height: 10px;
  }

  .site-subnav>li>a {
    display: block;
    padding: 0.5rem 0.8rem;
    white-space: nowrap;
    border-radius: var(--radius-xs);
  }

  .site-subnav>li>a:hover,
  .site-subnav>li>a:focus-visible {
    background: rgba(127, 140, 169, 0.12);
  }

  .site-nav__item.has-submenu:hover>.site-subnav,
  .site-nav__item.has-submenu:focus-within>.site-subnav {
    display: block;
  }

  .site-header__cta {
    display: inline-flex;
    min-width: clamp(9.5rem, 12vw, 12rem);
    justify-content: center;
  }

  .site-nav__cta {
    display: none;
  }

  .nav-toggle {
    display: none;
  }

  /* Hide mobile-only subnav toggle on desktop */
  .site-subnav__toggle {
    display: none;
  }

  .hero__inner {
    grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
    align-items: center;
  }

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

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

  .about__layout {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
    align-items: center;
  }
}

@media (min-width: 1200px) {
  .container {
    padding-inline: clamp(var(--space-md), 5vw, var(--space-2xl));
  }
}

/* Sicherstellen: In der Sticky-About-Section bleiben Grid-Items am oberen Rand ausgerichtet */
@media (min-width: 1024px) {
  .sticky-layout .about__layout {
    align-items: start;
  }
}

.about__copy #about-title {
  font-size: clamp(2.4rem, 4.2vw + 1.2rem, 3.6rem);
  /* deutlich größer mit rotem Punkt */
  line-height: 1.05;
  margin: 0;
}

/* Mentality (Method) section */
.mentality__wrap {
  display: grid;
  gap: clamp(1.6rem, 4vw, 2.6rem);
}

.mentality__head {
  display: grid;
  gap: clamp(0.4rem, 1.6vw, 0.9rem);
}

.mentality__head h2 {
  margin: 0;
  /* ein Tick kleiner als zuvor */
  font-size: clamp(3.1rem, 5.2vw, 5.2rem);
  font-weight: 800;
  line-height: 0.97;
  letter-spacing: -0.015em;
}

/* Panels: nur der geöffnete Inhalt bekommt Hintergrund */
.mentality {
  background: transparent;
}

body[data-theme="dark"] .mentality {
  background: transparent;
}

/* Active panel content on baby blue */
.mentality__panel.is-active .mentality__grid {
  background: #cfe2f3;
  border-radius: var(--radius-md);
  padding: clamp(var(--space-sm), 3vw, var(--space-lg));
  position: relative;
}

body[data-theme="dark"] .mentality__panel.is-active .mentality__grid {
  background: #0a2342;
}

/* Reduce line spacing inside the opened panel so text is more compact */
.mentality__panel.is-active .mentality__copy {
  gap: clamp(0.35rem, 1.4vw, 0.6rem);
}

.mentality__panel.is-active .mentality__copy p,
.mentality__panel.is-active .mentality__copy li {
  line-height: 1.45;
  margin-bottom: clamp(0.25rem, 1vw, 0.5rem);
}

/* New two-column cards layout for Mentality */
.mentality__cards {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  position: relative;
  z-index: 0;
  /* create stacking context for full-bleed background */
  /* oben moderat, unten mehr Platz, damit Fade großzügig auslaufen kann */
  padding-block-start: clamp(var(--space-md), 4vw, var(--space-xl));
  /* deutlich mehr Tiefe nach unten für einen längeren Fade-Bereich */
  padding-block-end: clamp(10rem, 18vw, 32rem);
  background: none;
  /* background handled by ::before full-bleed */
}

@media (max-width: 768px) {
  .mentality__cards {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Full-bleed background: solid baby blue at top, fades to transparent downwards */
.mentality__cards::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  /* extend beyond container to screen edges */
  height: 100%;
  pointer-events: none;
  z-index: -1;
  /* Babyblau beginnt erst weiter unten auszufaden und hat mehr Raum nach unten */
  background: linear-gradient(to bottom, #cfe2f3 0%, #cfe2f3 85%, rgba(207, 226, 243, 0) 100%);
}

/* Dark Mode: same concept with dark tone */
body[data-theme="dark"] .mentality__cards::before {
  background: linear-gradient(to bottom, #0a2342 0%, #0a2342 85%, rgba(10, 35, 66, 0) 100%);
}

/* Desktop: früher mit Transparenz beginnen für längeren, weicheren Fade */
@media (min-width: 769px) {
  .mentality__cards::before {
    background: linear-gradient(to bottom, #cfe2f3 0%, #cfe2f3 65%, rgba(207, 226, 243, 0) 100%);
  }

  body[data-theme="dark"] .mentality__cards::before {
    background: linear-gradient(to bottom, #0a2342 0%, #0a2342 65%, rgba(10, 35, 66, 0) 100%);
  }
}

.mentality-card__grid {
  display: grid;
  gap: clamp(0.9rem, 2.5vw, 1.4rem);
  grid-template-columns: minmax(0, 1.1fr) minmax(220px, 0.9fr);
  align-items: center;
}

@media (max-width: 768px) {
  .mentality-card__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.mentality-card__body {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height 320ms ease, opacity 240ms ease, transform 240ms ease;
}

.mentality-card.is-open .mentality-card__body {
  max-height: 2000px;
  opacity: 1;
  transform: translateY(0);
}

.mentality-card__visual {
  /* Show the visual thumbnail by default next to the teaser */
  max-height: none;
  opacity: 1;
  overflow: visible;
}

.mentality-card.is-open .mentality-card__visual {
  /* Keep same state when opened to avoid layout jump */
  max-height: none;
  opacity: 1;
}

.mentality-card__actions {
  margin-top: clamp(0.4rem, 1.6vw, 0.9rem);
}

/* Close button inside panel (top-right) */
.mentality__close {
  position: absolute;
  top: clamp(0.4rem, 1.2vw, 0.8rem);
  right: clamp(0.4rem, 1.2vw, 0.8rem);
  appearance: none;
  border: 1px solid rgba(10, 35, 66, 0.2);
  background: rgba(255, 255, 255, 0.8);
  color: #0a2342;
  border-radius: var(--radius-sm);
  padding: 0.2rem 0.5rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

body[data-theme="dark"] .mentality__close {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.25);
}

/* Placeholder under tabs when nothing open */
.mentality__placeholder {
  display: none;
  text-align: center;
  color: var(--muted-current, var(--muted));
  margin: clamp(0.6rem, 2vw, 1rem) 0;
}

.mentality__placeholder.is-visible {
  display: block;
}

.mentality__sub {
  margin: 0 0 clamp(0.6rem, 1.6vw, 1rem);
  color: color-mix(in srgb, var(--fg-current, var(--fg)) 70%, transparent);
  font-size: clamp(0.98rem, 0.35vw + 0.92rem, 1.05rem);
  /* wie Hero-Sub */
  line-height: 1.5;
  max-width: clamp(320px, 75%, 36rem);
}

.mentality__tabs {
  display: inline-flex;
  gap: clamp(0.35rem, 1.2vw, 0.75rem);
  flex-wrap: wrap;
}

.mentality__tab {
  /* Button-Design an Plattform-Buttons angelehnt */
  appearance: none;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  padding: var(--space-2xs) var(--space-md);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: var(--surface-current, var(--surface));
  color: inherit;
  transition: background-color var(--speed-med) ease, color var(--speed-med) ease,
    box-shadow var(--speed-med) ease, border-color var(--speed-med) ease, transform var(--speed-fast) ease;
}

.mentality__tab[data-offer-target="sport"] {
  background: #cfe2f3;
  color: #0a2342;
  border-color: rgba(10, 35, 66, 0.18);
}

.mentality__tab[data-offer-target="business"] {
  background: var(--primary);
  color: var(--bg);
  border-color: var(--primary);
}

.mentality__tab[data-offer-target="sport"].is-active {
  background: #cfe2f3;
  color: #0a2342;
}

.mentality__tab[data-offer-target="business"].is-active {
  background: var(--primary);
  color: var(--bg);
}

.mentality__tab[data-offer-target="business"]:hover,
.mentality__tab[data-offer-target="business"]:focus-visible {
  filter: brightness(1.05);
}

.mentality__tab[data-offer-target="sport"]:hover,
.mentality__tab[data-offer-target="sport"]:focus-visible {
  filter: brightness(0.98);
}

.mentality__tab:hover,
.mentality__tab:focus-visible {
  border-color: rgba(10, 35, 66, 0.28);
  box-shadow: var(--shadow-elev-1);
}

.mentality__tab.is-active {
  border-color: rgba(10, 35, 66, 0.28);
  box-shadow: var(--shadow-elev-1);
}

.mentality__panels {
  position: relative;
}

/* Robuster Panelswitch: nur Opacity animieren; hidden erzwingen */
.mentality__panel {
  display: none;
  opacity: 0;
  transition: opacity 220ms ease;
  pointer-events: none;
}

.mentality__panel.is-active {
  display: block;
  opacity: 1;
  pointer-events: auto;
}

.mentality__panel.is-exiting {
  display: block;
  opacity: 0;
  pointer-events: none;
}

.mentality__panel[hidden] {
  display: none !important;
}

.mentality__grid {
  display: grid;
  gap: clamp(1.2rem, 3vw, 2rem);
  align-items: center;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
}

@media (max-width: 768px) {
  .mentality__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

.mentality__copy {
  display: grid;
  gap: clamp(0.6rem, 2vw, 1rem);
}

.mentality__panel-title {
  margin: 0;
  font-size: clamp(1.2rem, 0.8vw + 1rem, 1.6rem);
}

.mentality__list {
  margin: 0;
  padding-left: 1.2rem;
  display: grid;
  gap: 0.3rem;
}

.mentality__quote {
  margin: 0.4rem 0;
}

.mentality__quote blockquote {
  margin: 0;
  font-weight: 700;
  color: #0a2342;
}

.mentality__core {
  font-weight: 600;
}

.mentality__visual {
  min-height: clamp(220px, 36vw, 420px);
  display: grid;
  place-items: center;
}

.mentality-illustration {
  width: min(100%, 520px);
  height: clamp(220px, 36vw, 420px);
  border-radius: 18px;
  box-shadow: var(--shadow-elev-2);
  position: relative;
  overflow: hidden;
}

.mentality-illustration--sport {
  background: linear-gradient(180deg, #dfeeff 0%, #cfe2f3 100%);
}

.mentality-illustration--sport::after {
  content: "";
  position: absolute;
  inset: 10% 6%;
  border-radius: 24px;
  border: 2px solid rgba(31, 60, 136, 0.25);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.4);
  transform: rotate(-3deg);
}

.mentality-illustration--business {
  background: linear-gradient(180deg, #eef3fb 0%, #dfe7f7 100%);
}

.mentality-illustration--business::after {
  content: "";
  position: absolute;
  inset: 12% 8%;
  border-radius: 50%;
  border: 2px dashed rgba(31, 60, 136, 0.25);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}

/* Visual image placeholder for Sport panel */
.mentality__visual .mentality__image {
  display: block;
  width: min(100%, 520px);
  height: clamp(220px, 36vw, 420px);
  object-fit: cover;
  border-radius: 18px;
  box-shadow: var(--shadow-elev-2);
}

/* Ensure card visuals are small thumbnails, visible beside the teaser */
.mentality-card__visual {
  justify-self: end;
}

.mentality-card__visual .mentality__image {
  display: block;
  width: 100%;
  max-width: 260px;
  /* small thumbnail */
  height: auto;
  border-radius: 12px;
  box-shadow: var(--shadow-elev-2);
}

.mentality__footer {
  display: grid;
  justify-items: center;
  gap: clamp(0.8rem, 2.4vw, 1.2rem);
  margin-top: clamp(1.6rem, 4vw, 2.4rem);
}

.mentality__closing {
  margin: 0;
  color: #0a2342;
  font-size: clamp(1.1rem, 0.8vw + 1rem, 1.35rem);
  text-align: center;
}

@media (min-width: 541px) {

  /* Desktop/Tablet: Toggle nicht anzeigen */
  .cases__grid>.card .card__toggle {
    display: none !important;
  }
}

/* Desktop/Tablet: Toggle für die ersten zwei Cards sichtbar halten */
@media (min-width: 541px) {
  .cases__grid>.card:nth-child(-n+2) .card__toggle {
    display: inline-flex;
  }
}

/* Desktop & Mobile: Für die ersten zwei Cards (links) initial Text/Link verstecken */
.cases__grid>.card:nth-child(-n+2)>p {
  display: none;
}

.cases__grid>.card:nth-child(-n+2) .card__actions .card__link[href^="mailto:"] {
  display: none;
}

.cases__grid>.card:nth-child(-n+2).is-open .card__actions .card__link[href^="mailto:"] {
  display: inline-flex;
}

/* Toggle für die ersten zwei Cards immer anzeigen */
.cases__grid>.card:nth-child(-n+2) .card__toggle {
  display: inline-flex;
}

/* Ensure desktop shows the 'Mehr anzeigen' toggle on the first two case cards */
.cases__grid>.card:nth-child(-n+2) .card__toggle {
  display: inline-flex !important;
}

/* Make the mentality toggle look like other 'Mehr anzeigen' links and clickable */
.mentality-card__toggle.card__link {
  cursor: pointer;
  align-items: center;
}