/* ============================================
   4better.team — Design System & Styles
   Based on Design-Spec by Daniel (Phase 4)
   Built by Max (Phase 6)
   ============================================ */

/* --- Self-hosted Google Fonts (DSGVO-konform) --- */

/* Montserrat — latin-ext (ä, ö, ü, ß) */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url('../fonts/montserrat-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Montserrat — latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500 700;
  font-display: swap;
  src: url('../fonts/montserrat-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Roboto — latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('../fonts/roboto-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Roboto — latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 400 500;
  font-display: swap;
  src: url('../fonts/roboto-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* Roboto Italic — latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/roboto-italic-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* Roboto Italic — latin */
@font-face {
  font-family: 'Roboto';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/roboto-italic-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* --- Design Tokens (Custom Properties) --- */

:root {
  /* Colors - Primary (Teal) */
  --color-primary-50: hsl(186, 60%, 95%);
  --color-primary-100: hsl(187, 55%, 88%);
  --color-primary-200: hsl(188, 50%, 75%);
  --color-primary-300: hsl(188, 60%, 55%);
  --color-primary-400: hsl(189, 75%, 38%);
  --color-primary-500: hsl(189, 91%, 23%);
  --color-primary-600: hsl(189, 91%, 19%);
  --color-primary-700: hsl(190, 88%, 15%);
  --color-primary-800: hsl(190, 85%, 11%);

  /* Colors - Secondary (Gold) */
  --color-secondary-50: hsl(42, 100%, 96%);
  --color-secondary-300: hsl(41, 100%, 65%);
  --color-secondary-400: hsl(40, 100%, 56%);
  --color-secondary-500: hsl(40, 100%, 51%);
  --color-secondary-600: hsl(38, 100%, 45%);
  --color-secondary-700: hsl(36, 100%, 38%);

  /* Colors - Neutral (Warm Grey) */
  --color-neutral-white: #ffffff;
  --color-neutral-50: hsl(40, 20%, 97%);
  --color-neutral-100: hsl(40, 15%, 93%);
  --color-neutral-200: hsl(38, 12%, 85%);
  --color-neutral-300: hsl(38, 10%, 72%);
  --color-neutral-400: hsl(37, 8%, 55%);
  --color-neutral-500: hsl(36, 6%, 42%);
  --color-neutral-600: hsl(35, 6%, 32%);
  --color-neutral-700: hsl(34, 8%, 22%);
  --color-neutral-800: hsl(33, 10%, 15%);
  --color-neutral-900: hsl(32, 12%, 10%);

  /* Semantic */
  --color-error: hsl(0, 65%, 50%);

  /* Typography */
  --font-heading: 'Montserrat', system-ui, sans-serif;
  --font-body: 'Roboto', system-ui, sans-serif;

  --text-hero: clamp(2.25rem, 1.5rem + 3vw, 3.75rem);
  --text-h1: clamp(1.875rem, 1.25rem + 2.5vw, 3rem);
  --text-h2: clamp(1.5rem, 1rem + 2vw, 2.25rem);
  --text-h3: clamp(1.25rem, 1rem + 1.25vw, 1.875rem);
  --text-h4: clamp(1.125rem, 1rem + 0.75vw, 1.5rem);
  --text-h5: 1.25rem;
  --text-body-lg: 1.125rem;
  --text-body: 1rem;
  --text-body-sm: 0.875rem;
  --text-caption: 0.75rem;

  /* Spacing */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;
  --space-11: 192px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
  --shadow-md: 0 4px 6px rgba(0,0,0,0.1), 0 2px 4px rgba(0,0,0,0.06);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.1), 0 4px 6px rgba(0,0,0,0.05);
  --shadow-xl: 0 20px 25px rgba(0,0,0,0.1), 0 10px 10px rgba(0,0,0,0.04);

  /* Borders */
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* Transitions */
  --transition-fast: 100ms ease;
  --transition-normal: 200ms ease;
  --transition-slow: 300ms ease;

  /* Layout */
  --container-max: 1200px;
  --container-wide: 1440px;
}


/* --- Reset & Base --- */

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

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-body);
  font-size: var(--text-body);
  line-height: 1.6;
  color: var(--color-neutral-600);
  background-color: var(--color-neutral-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

a {
  color: var(--color-primary-400);
  text-decoration: none;
  transition: color var(--transition-normal);
}

a:hover {
  color: var(--color-primary-500);
}

ul, ol {
  list-style: none;
}

/* Skip Link */
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--space-4);
  background: var(--color-primary-500);
  color: var(--color-neutral-white);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  z-index: 200;
  font-family: var(--font-heading);
  font-size: var(--text-body-sm);
}

.skip-link:focus {
  top: var(--space-4);
  color: var(--color-neutral-white);
}


/* --- Typography --- */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--color-neutral-800);
  line-height: 1.2;
}

h1 { font-size: var(--text-h1); font-weight: 700; letter-spacing: -0.015em; line-height: 1.15; }
h2 { font-size: var(--text-h2); font-weight: 600; letter-spacing: -0.01em; }
h3 { font-size: var(--text-h3); font-weight: 600; letter-spacing: -0.005em; line-height: 1.25; }
h4 { font-size: var(--text-h4); font-weight: 600; line-height: 1.3; }
h5 { font-size: var(--text-h5); font-weight: 600; line-height: 1.35; }

/*
 * Utility: lässt ein semantisch korrektes <h3> optisch exakt wie ein <h4> aussehen.
 * Wird verwendet, wo Unterüberschriften aus SEO-Gründen von h4 auf h3 angehoben
 * werden, das bisherige h4-Erscheinungsbild aber 1:1 erhalten bleiben soll.
 * Die Schriftgröße steuert weiterhin die jeweilige Komponentenklasse
 * (z. B. .feature-card__title); hier werden nur die beiden Eigenschaften gespiegelt,
 * in denen sich die Basisregeln von h3 und h4 unterscheiden:
 *   line-height (h4 = 1.3, h3 = 1.25) und letter-spacing (h4 = normal, h3 = -0.005em).
 */
.heading-as-h4 { line-height: 1.3; letter-spacing: normal; }


.text-body-lg {
  font-size: var(--text-body-lg);
  line-height: 1.6;
}

.text-body-sm {
  font-size: var(--text-body-sm);
  line-height: 1.5;
}


p + p {
  margin-top: 1.5em;
}


/* --- Layout --- */

.container {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--space-4);
}


.container--narrow {
  max-width: 720px;
}

.section {
  padding: var(--space-8) 0;
}

.section--alt {
  background-color: var(--color-neutral-50);
}


.text-center {
  text-align: center;
}

@media (min-width: 768px) {
  .container {
    padding: 0 var(--space-5);
  }
  .section {
    padding: var(--space-9) 0;
  }
}

@media (min-width: 1024px) {
  .container {
    padding: 0 var(--space-7);
  }
  .section {
    padding: var(--space-10) 0;
  }
}


/* --- Buttons --- */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: 48px;
  padding: 0 var(--space-5);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-body);
  cursor: pointer;
  transition: background-color var(--transition-normal), transform var(--transition-fast), box-shadow var(--transition-normal);
  text-decoration: none;
  white-space: nowrap;
}

.btn:active {
  transform: scale(0.98);
}

.btn:focus-visible {
  outline: 2px solid var(--color-primary-400);
  outline-offset: 2px;
}


.btn--cta {
  background-color: var(--color-secondary-500);
  color: var(--color-neutral-white);
}

.btn--cta:hover {
  background-color: var(--color-secondary-600);
  color: var(--color-neutral-white);
}

.btn--cta-lg {
  background-color: var(--color-secondary-500);
  color: var(--color-neutral-white);
  height: 56px;
  padding: 0 var(--space-6);
  font-size: var(--text-body-lg);
}

.btn--cta-lg:hover {
  background-color: var(--color-secondary-600);
  color: var(--color-neutral-white);
}

/* Mobile: langer CTA-Text (z. B. "Beratung buchen — 250 € zzgl. MwSt.") darf
   umbrechen statt die Seite horizontal zu sprengen (UX-Audit, /beratung @390px). */
@media (max-width: 560px) {
  .btn--cta-lg {
    height: auto;
    min-height: 56px;
    max-width: 100%;
    padding-top: var(--space-2);
    padding-bottom: var(--space-2);
    white-space: normal;
    line-height: 1.3;
  }
}

.btn--outline {
  background-color: transparent;
  color: var(--color-primary-500);
  border: 2px solid var(--color-primary-500);
}

.btn--outline:hover {
  background-color: var(--color-primary-50);
  color: var(--color-primary-500);
}

.btn--ghost {
  background-color: transparent;
  color: var(--color-primary-500);
}

.btn--ghost:hover {
  background-color: var(--color-primary-50);
  color: var(--color-primary-500);
}

.btn[disabled] {
  background-color: var(--color-neutral-200);
  color: var(--color-neutral-400);
  cursor: not-allowed;
  transform: none;
}


/* --- Header --- */

.header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: 64px;
  background-color: transparent;
  transition: background-color var(--transition-normal), box-shadow var(--transition-normal);
}

.header--scrolled {
  background-color: var(--color-neutral-50);
  box-shadow: var(--shadow-sm);
}

.header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  max-width: var(--container-wide);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

.header__logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.header__logo img {
  height: 32px;
  width: auto;
}

.header__logo:hover {
  opacity: 0.8;
}

.header__nav {
  display: none;
  align-items: center;
  gap: var(--space-6);
  flex: 1;
  justify-content: center;
}

.header__nav-link {
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  text-decoration: none;
  transition: color var(--transition-normal);
  padding: var(--space-2) 0;
}

.header__nav-link:hover,
.header__nav-link--active {
  color: var(--color-primary-500);
}

.header__auth {
  display: none;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-body-sm);
}

.header__auth-link {
  color: var(--color-neutral-600);
  text-decoration: none;
  transition: color var(--transition-normal);
}

.header__auth-link:hover {
  color: var(--color-primary-500);
}

.header__auth-icon {
  display: flex;
  align-items: center;
  color: var(--color-neutral-400);
  text-decoration: none;
  transition: color var(--transition-normal);
  margin-right: 10px;
}

.header__auth-icon:hover {
  color: var(--color-primary-500);
}

.header__auth-sep {
  color: var(--color-neutral-400);
}

.header__auth-logout {
  background: none;
  border: none;
  color: var(--color-neutral-400);
  font-size: var(--text-body-sm);
  cursor: pointer;
  padding: 0;
  transition: color var(--transition-normal);
}

.header__auth-logout:hover {
  color: var(--color-neutral-600);
}

.mobile-menu__auth {
  padding: var(--space-3) 0;
  border-top: 1px solid var(--color-neutral-200);
  margin-top: var(--space-3);
}

.mobile-menu__link--muted {
  color: var(--color-neutral-400);
}

.header__cta {
  display: none;
}

.header__hamburger {
  display: flex;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  z-index: 110;
}

.header__hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background-color: var(--color-neutral-700);
  transition: transform var(--transition-normal), opacity var(--transition-normal);
}

.header__hamburger--open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.header__hamburger--open span:nth-child(2) {
  opacity: 0;
}

.header__hamburger--open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Menu */
.mobile-menu {
  position: fixed;
  top: 0;
  right: -100%;
  width: 80%;
  max-width: 320px;
  height: 100vh;
  background-color: var(--color-neutral-white);
  box-shadow: var(--shadow-lg);
  padding: var(--space-11) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: right var(--transition-slow);
  z-index: 105;
}

.mobile-menu--open {
  right: 0;
}

.mobile-menu__link {
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: var(--text-body-lg);
  color: var(--color-neutral-700);
  text-decoration: none;
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--color-neutral-100);
}

.mobile-menu__link:hover {
  color: var(--color-primary-500);
}

.mobile-menu__overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 104;
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-slow), visibility var(--transition-slow);
}

.mobile-menu__overlay--visible {
  opacity: 1;
  visibility: visible;
}

@media (min-width: 768px) {
  .header {
    height: 72px;
  }

  .header__inner {
    padding: 0 var(--space-5);
  }

  .header__nav {
    display: flex;
  }

  .header__auth {
    display: flex;
  }

  .header__cta {
    display: inline-flex;
  }

  .header__hamburger {
    display: none;
  }

  .mobile-menu,
  .mobile-menu__overlay {
    display: none;
  }
}

@media (min-width: 1024px) {
  .header__inner {
    padding: 0 var(--space-7);
  }

  .header__nav {
    gap: var(--space-7);
  }
}


/* --- Stakes Section --- */

.stakes {
  background: var(--color-neutral-white);
}

.stakes__content {
  max-width: 720px;
  margin: 0 auto;
}

.stakes__headline {
  margin-bottom: var(--space-6);
}

.stakes__text {
  color: var(--color-neutral-600);
}

.stakes__text p + p {
  margin-top: 1.5em;
}

.stakes__failure {
  font-weight: 500;
  color: var(--color-neutral-800);
  font-style: italic;
  margin-top: 1.5em;
}


/* --- Card Grid --- */

.card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
  }
}

@media (min-width: 768px) {
  .card-grid--2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
    .card-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* --- Feature Card --- */

.feature-card {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.section:not(.section--alt) .feature-card {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  box-shadow: none;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.feature-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.feature-card__icon {
  font-size: 48px;
  width: 48px;
  height: 48px;
  color: var(--color-primary-400);
  margin-bottom: var(--space-2);
}

.feature-card__icon img {
  width: 48px;
  height: 48px;
  object-fit: contain;
}

.feature-card__title {
  font-size: var(--text-h4);
  color: var(--color-neutral-800);
}

.feature-card__text {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  flex: 1;
}


/* --- Plan Section --- */

.plan-steps {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  margin-top: var(--space-7);
}

.plan-step {
  display: flex;
  gap: var(--space-5);
  align-items: flex-start;
}

.plan-step__number {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-full);
  background: var(--color-primary-500);
  color: var(--color-neutral-white);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-body-lg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.plan-step__title {
  font-size: var(--text-h4);
  color: var(--color-neutral-800);
  margin-bottom: var(--space-2);
}

.plan-step__text {
  color: var(--color-neutral-600);
}

.agreement {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  justify-content: center;
  margin-top: var(--space-7);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
}

.agreement__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.agreement__check {
  color: var(--color-primary-500);
  font-weight: 700;
}

@media (min-width: 1024px) {
  .plan-steps {
    flex-direction: row;
  }
  .plan-step {
    flex-direction: column;
    align-items: stretch;
    text-align: center;
    flex: 1;
    position: relative;
  }
  .plan-step > div {
    display: flex;
    flex-direction: column;
  }
  .plan-step__number {
    align-self: center;
  }
  .plan-step__title {
    text-align: center;
    min-height: 2.6em;
  }
  .plan-step__text {
    flex: 1;
  }
  .plan-step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 24px;
    right: -16%;
    width: 32%;
    height: 2px;
    border-top: 2px dashed var(--color-neutral-200);
  }
}


/* --- Testimonial Section --- */

.testimonials {
  margin-top: var(--space-7);
}

.testimonial-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .testimonial-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .testimonial-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .testimonial-grid--2 {
    grid-template-columns: repeat(2, 1fr);
    max-width: 900px;
    margin: 0 auto;
  }
}

.testimonial-card {
  background: var(--color-neutral-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  position: relative;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

.testimonial-card__quote-mark {
  font-size: 48px;
  color: var(--color-primary-200);
  font-family: serif;
  line-height: 1;
  position: absolute;
  top: var(--space-4);
  left: var(--space-5);
}

.testimonial-card__text {
  font-size: var(--text-body-lg);
  color: var(--color-neutral-700);
  font-style: italic;
  padding-top: var(--space-5);
  flex: 1;
}

.testimonial-card__avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
}

.testimonial-card__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.testimonial-card__author {
  margin-top: var(--space-4);
  font-size: var(--text-body);
  color: var(--color-neutral-800);
  font-family: var(--font-heading);
  font-weight: 600;
  text-align: right;
}

.testimonial-card__role {
  font-size: var(--text-caption);
  color: var(--color-neutral-500);
  font-family: var(--font-heading);
  font-weight: 600;
  font-style: italic;
  text-align: right;
  margin-top: var(--space-1);
}


/* --- CTA Banner --- */

.cta-banner {
  background: var(--color-primary-700);
  padding: var(--space-8) 0;
  text-align: center;
}

.cta-banner__inner {
  max-width: 600px;
  margin: 0 auto;
}

.cta-banner h2 {
  color: var(--color-neutral-white);
  font-weight: 700;
}

.cta-banner__subline {
  color: rgba(255,255,255,0.7);
  font-size: var(--text-body-lg);
  margin-top: var(--space-4);
}

.cta-banner__actions {
  margin-top: var(--space-6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-4);
}

.cta-banner__alt {
  color: var(--color-neutral-white);
  font-size: var(--text-body-sm);
  text-decoration: underline;
}

.cta-banner__alt:hover {
  color: var(--color-secondary-400);
}

.cta-banner__guarantee {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-white);
  opacity: 0.85;
  margin-top: var(--space-3);
  font-style: italic;
}

@media (min-width: 1024px) {
  .cta-banner {
    padding: var(--space-10) 0;
  }
}


/* --- Lead Magnet Box --- */

.lead-magnet {
  background: hsl(40, 20%, 97%);
  border: 1px solid hsl(38, 14%, 86%);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  margin-top: var(--space-7);
  box-shadow: var(--shadow-sm);
  max-width: 75%;
  margin-inline: auto;
}

.lead-magnet__title {
  font-size: var(--text-h4);
  color: var(--color-neutral-800);
  margin-bottom: var(--space-3);
}

.lead-magnet__text {
  color: var(--color-neutral-600);
  margin-bottom: var(--space-5);
}

.lead-magnet__form {
  display: grid;
  gap: var(--space-3);
}

@media (min-width: 768px) {
  .lead-magnet__form {
    grid-template-columns: 1fr auto auto;
    align-items: center;
    column-gap: var(--space-3);
  }
  .lead-magnet__form .form-input {
    grid-column: 1 / -1;
  }
  .lead-magnet__form .form-checkbox {
    grid-column: 2;
    justify-self: end;
  }
}


/* --- Forms --- */

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.form-label {
  font-size: var(--text-body-sm);
  font-family: var(--font-heading);
  font-weight: 500;
  color: var(--color-neutral-700);
}

.form-input,
.form-select,
.form-textarea {
  height: 48px;
  padding: var(--space-3) var(--space-4);
  background: var(--color-neutral-100);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-body);
  color: var(--color-neutral-900);
  transition: border-color var(--transition-normal), background-color var(--transition-normal);
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  background: var(--color-neutral-white);
  border-color: var(--color-primary-400);
  box-shadow: 0 0 0 2px var(--color-primary-100);
}

.form-input::placeholder {
  color: var(--color-neutral-300);
}

.form-textarea {
  height: auto;
  min-height: 150px;
  resize: vertical;
}

.form-error {
  font-size: var(--text-caption);
  color: var(--color-error);
}

.form-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  max-width: 600px;
  margin: 0 auto;
}

.form-checkbox {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  cursor: pointer;
  line-height: 1.5;
}

.form-checkbox input[type="checkbox"] {
  margin-top: 3px;
  flex-shrink: 0;
  accent-color: var(--color-primary-500);
}

.form-checkbox a {
  color: var(--color-primary-500);
  text-decoration: underline;
}

.form-checkbox--sm {
  margin-top: var(--space-3);
  font-size: var(--text-caption);
}


/* --- Badge --- */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-caption);
  font-family: var(--font-heading);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}


.badge--empfohlen {
  background: var(--color-secondary-500);
  color: var(--color-neutral-900);
}


/* --- Pricing Cards --- */


.pricing-card {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.pricing-card--featured {
  border: 2px solid var(--color-primary-500);
  box-shadow: var(--shadow-md);
  position: relative;
  margin-top: calc(-1 * var(--space-5));
  padding-top: calc(var(--space-6) + var(--space-5));
}

.pricing-card--featured .badge {
  position: absolute;
  top: calc(-1 * 0.75em);
  left: var(--space-6);
}

.pricing-card__title {
  font-size: var(--text-h4);
  color: var(--color-neutral-800);
}

.pricing-card__price {
  font-family: var(--font-heading);
  font-size: var(--text-h3);
  font-weight: 700;
  color: var(--color-primary-500);
}

.pricing-card__price-note {
  display: block;
  font-family: var(--font-body);
  font-size: var(--text-body-sm);
  font-weight: 400;
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

.pricing-card__description {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
}

.pricing-card__timeline {
  font-size: var(--text-body-sm);
  font-weight: 600;
  color: var(--color-primary-700);
}

.pricing-card__features {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.pricing-card__features li {
  position: relative;
  padding-left: var(--space-5);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
}

.pricing-card__features li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--color-primary-500);
  font-weight: 700;
}


/* --- Comparison Table --- */

.comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-body-sm);
  margin-top: var(--space-7);
  overflow-x: auto;
  display: block;
}

@media (min-width: 768px) {
  .comparison-table {
    display: table;
  }
}

.comparison-table th,
.comparison-table td {
  padding: var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-neutral-100);
}

.comparison-table th {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-neutral-800);
  background: var(--color-neutral-50);
}

.comparison-table tr:nth-child(even) {
  background: var(--color-neutral-50);
}

.comparison-table td:last-child {
  color: var(--color-primary-500);
  font-weight: 500;
}


/* --- Enabler Grid --- */

.enabler-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .enabler-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .enabler-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1440px) {
  .enabler-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.enabler-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.enabler-card:hover .enabler-card__image img {
  transform: scale(1.05);
}

.enabler-card__name {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-neutral-800);
  font-size: var(--text-body);
}

.enabler-card__role {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.enabler-card__tagline {
  font-size: var(--text-caption);
  font-style: italic;
  color: var(--color-neutral-500);
  margin-top: var(--space-2);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.enabler-card__location {
  font-size: var(--text-caption);
  color: var(--color-neutral-400);
  margin-top: var(--space-2);
}


/* --- Blockquote --- */

.blockquote {
  border-left: 4px solid var(--color-primary-500);
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-h3);
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-primary-700);
  line-height: 1.3;
  max-width: 720px;
  margin: var(--space-7) auto;
}


/* --- Values Grid --- */

.values-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.value-card {
  padding: var(--space-5);
}


/* --- Footer --- */

.footer {
  background: var(--color-primary-800);
  padding: var(--space-8) 0 var(--space-6);
  color: var(--color-neutral-white);
}

.footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

.footer__heading {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--color-neutral-white);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.footer__link {
  display: block;
  color: rgba(255,255,255,0.8);
  font-size: var(--text-body-sm);
  margin-bottom: var(--space-3);
  transition: color var(--transition-normal);
}

.footer__link:hover {
  color: var(--color-secondary-400);
}

.footer__bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid rgba(255,255,255,0.1);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: center;
  text-align: center;
}

.footer__claim {
  font-size: var(--text-body-sm);
  font-style: italic;
  color: rgba(255,255,255,0.5);
}

.footer__copyright {
  font-size: var(--text-caption);
  color: rgba(255,255,255,0.4);
}

.footer__social a {
  color: rgba(255,255,255,0.7);
  transition: color var(--transition-normal);
}

.footer__social a:hover {
  color: var(--color-secondary-400);
}

@media (min-width: 768px) {
  .footer__grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
  }
}


/* --- Utility Classes --- */

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

.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mb-5 { margin-bottom: var(--space-5); }
.mb-6 { margin-bottom: var(--space-6); }
.mb-7 { margin-bottom: var(--space-7); }
.mt-3 { margin-top: var(--space-3); }
.mt-5 { margin-top: var(--space-5); }
.mt-6 { margin-top: var(--space-6); }
.mt-7 { margin-top: var(--space-7); }


/* --- Scroll Animations --- */

.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.fade-in--visible {
  opacity: 1;
  transform: translateY(0);
}


/* --- Process Note --- */

.process-note {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  font-style: italic;
  margin-top: var(--space-5);
}


/* ============================================
   4better.team — V3 Design System Extension
   Full-bleed heroes, modern cards, filters
   ============================================ */


/* Keep backward compat for workshops page */
.ws-hero {
  position: relative;
  min-height: 480px;
  display: flex;
  align-items: flex-start;
  background: url('../img/hero-workshops.webp') center/cover no-repeat;
  color: var(--color-neutral-white);
}

.ws-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(0, 50, 60, 0.82) 0%,
    rgba(0, 50, 60, 0.55) 100%
  );
}

.ws-hero__inner {
  position: relative;
  z-index: 1;
  padding-top: var(--space-9);
  padding-bottom: var(--space-9);
}

.ws-hero__kicker {
  font-family: var(--font-heading);
  font-size: var(--text-body-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-secondary-300);
  margin-bottom: var(--space-3);
}

.ws-hero__headline {
  font-size: var(--text-hero);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-neutral-white);
  margin-bottom: var(--space-4);
  max-width: 720px;
}

.ws-hero__subline {
  font-size: var(--text-body-lg);
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.6;
  max-width: 560px;
}

.ws-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
  margin-top: var(--space-6);
}

.ws-hero__alt-link {
  color: rgba(255, 255, 255, 0.8);
  font-size: var(--text-body-sm);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition-normal);
}

.ws-hero__alt-link:hover {
  color: var(--color-neutral-white);
}

.btn--on-dark {
  border-color: rgba(255, 255, 255, 0.5);
  color: var(--color-neutral-white);
}

.btn--on-dark:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.8);
  color: var(--color-neutral-white);
}

@media (min-width: 1024px) {
  .ws-hero {
    min-height: 560px;
  }
}


/* --- Filter Tabs --- */


.ws-filter__tabs {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-2);
}

.ws-filter__tab {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-full);
  padding: var(--space-2) var(--space-5);
  font-family: var(--font-heading);
  font-weight: 500;
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  cursor: pointer;
  transition: all var(--transition-normal);
}

.ws-filter__tab:hover {
  border-color: var(--color-primary-300);
  color: var(--color-primary-500);
}

.ws-filter__tab--active {
  background: var(--color-primary-500);
  border-color: var(--color-primary-500);
  color: var(--color-neutral-white);
}

.ws-filter__tab--active:hover {
  background: var(--color-primary-600);
  border-color: var(--color-primary-600);
  color: var(--color-neutral-white);
}

.ws-filter__more-wrap {
  position: relative;
  display: inline-flex;
}

.ws-filter__more-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  background: var(--color-neutral-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 16px rgba(0,0,0,.1);
  padding: var(--space-2);
  z-index: 10;
  flex-direction: column;
  gap: var(--space-1);
  min-width: 200px;
}

.ws-filter__more-dropdown--open {
  display: flex;
}

.ws-filter__more-dropdown .ws-filter__tab {
  text-align: left;
  border-radius: var(--radius-md);
  width: 100%;
}


/* --- Workshop Grid --- */

.ws-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 640px) {
  .ws-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .ws-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* --- Workshop Card --- */

.ws-card {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
  display: flex;
  flex-direction: column;
}

.ws-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.ws-card__img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  position: relative;
}

.ws-card__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.ws-card:hover .ws-card__img img {
  transform: scale(1.05);
}

.ws-card__body {
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.ws-card__tags {
  display: flex;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}

.ws-tag {
  display: inline-block;
  padding: 2px var(--space-3);
  border-radius: var(--radius-full);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}

.ws-tag--marketing {
  background: var(--color-primary-50);
  color: var(--color-primary-500);
}

.ws-tag--ki {
  background: var(--color-secondary-50);
  color: var(--color-secondary-700);
}

.ws-tag--format {
  background: var(--color-neutral-100);
  color: var(--color-neutral-500);
}

.ws-card__title {
  font-size: var(--text-h4);
  color: var(--color-neutral-800);
  margin-bottom: var(--space-2);
  line-height: 1.3;
}

.ws-card__desc {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  line-height: 1.6;
  margin-bottom: var(--space-4);
}

.ws-card__meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2) var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-100);
  margin-top: auto;
}

.ws-card__meta-label {
  display: block;
  font-size: 11px;
  font-family: var(--font-heading);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-neutral-400);
}

.ws-card__meta-value {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-700);
  font-weight: 500;
}

.ws-card__meta-value--status {
  color: var(--color-primary-500);
}

.ws-card__cta {
  margin-top: var(--space-4);
  width: 100%;
}

.btn--sm {
  height: 40px;
  padding: 0 var(--space-4);
  font-size: var(--text-body-sm);
}


/* --- Comparison Table --- */

.ws-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ws-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-body-sm);
  min-width: 700px;
}

.ws-table th,
.ws-table td {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  border-bottom: 1px solid var(--color-neutral-100);
}

.ws-table th {
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-neutral-500);
  background: var(--color-neutral-50);
  position: sticky;
  top: 0;
}

.ws-table tbody tr:hover {
  background: var(--color-primary-50);
}

.ws-table td a {
  color: var(--color-primary-500);
  font-weight: 500;
}

.ws-table td a:hover {
  text-decoration: underline;
}

.ws-status {
  display: inline-block;
  padding: 2px var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-primary-50);
  color: var(--color-primary-700);
  font-size: var(--text-caption);
  font-weight: 600;
}

.ws-status--planned {
  background: var(--color-primary-50);
  color: var(--color-primary-500);
}

/* --- Planned Workshop Cards --- */

.ws-card--planned {
  border: 1px solid var(--color-neutral-200);
}

.ws-card__badge {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-family: var(--font-heading);
  font-weight: 700;
  font-size: var(--text-caption);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  z-index: 1;
}

.ws-card__badge--bookable {
  background: var(--color-secondary-400);
  color: var(--color-neutral-white);
}

.ws-card__meta-value--planned {
  color: var(--color-primary-500);
  font-weight: 600;
}

/* --- Teal Accent Button (Interesse bekunden) --- */

.btn--accent {
  background: var(--color-primary-500);
  color: var(--color-neutral-white);
  border: none;
}

.btn--accent:hover {
  background: var(--color-primary-600);
  color: var(--color-neutral-white);
}

/* --- Cancel Info --- */

.ws-detail__cancel-info {
  font-size: var(--text-caption);
  color: var(--color-neutral-400);
  margin-top: var(--space-3);
}

/* --- Reminder Form --- */

.ws-detail__remind-section {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-100);
}

.ws-detail__remind-label {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  margin-bottom: var(--space-2);
}

.ws-remind-form {
  display: flex;
  flex-direction: column;
  text-align: left;
}

.ws-remind-form .form-input {
  width: 100%;
  box-sizing: border-box;
}

.ws-remind-form__btn {
  width: 100%;
  margin-top: var(--space-2);
}

.ws-remind-form__consent {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  margin-top: var(--space-2);
  font-size: var(--text-caption);
  color: var(--color-neutral-500);
  cursor: pointer;
}

.ws-remind-form__consent input[type="checkbox"] {
  margin-top: 2px;
  accent-color: var(--color-primary-500);
}

.ws-remind-form__consent a {
  color: var(--color-primary-500);
  text-decoration: underline;
}

.ws-remind-success {
  color: var(--color-primary-500);
  font-weight: 600;
  margin-top: var(--space-2);
  font-size: var(--text-body-sm);
}

/* --- Interest Grid (2-column layout) --- */

.ws-interest-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
  align-items: start;
}

.ws-interest-grid__note {
  color: var(--color-neutral-500);
  font-size: var(--text-body-sm);
  margin-top: var(--space-4);
}

@media (max-width: 768px) {
  .ws-interest-grid {
    grid-template-columns: 1fr;
    gap: var(--space-6);
  }
}

/* --- Interest Form --- */

.ws-interest-form {
  max-width: 480px;
}

.ws-interest-form .form-field {
  margin-bottom: var(--space-4);
}

.ws-interest-form .form-label {
  display: block;
  font-weight: 600;
  font-size: var(--text-body-sm);
  margin-bottom: var(--space-2);
  color: var(--color-neutral-700);
}

.ws-interest-form .form-input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  font-size: var(--text-body);
  font-family: var(--font-body);
  transition: border-color 0.2s;
}

.ws-interest-form .form-input:focus {
  outline: none;
  border-color: var(--color-primary-500);
  box-shadow: 0 0 0 3px var(--color-primary-50);
}


/* --- Badge (In Planung) --- */

.ws-detail__badge-planned {
  display: inline-block;
  padding: var(--space-2) var(--space-4);
  background: var(--color-primary-50);
  color: var(--color-primary-500);
  border-radius: var(--radius-full);
  font-size: var(--text-body-sm);
  font-weight: 600;
  margin-bottom: var(--space-4);
}

/* --- Newsletter Section --- */

.ws-newsletter-section {
  background: var(--color-primary-500);
}

.ws-newsletter-section h2 {
  color: var(--color-neutral-white);
}

.ws-newsletter-section p {
  color: rgba(255,255,255,0.85);
}

.ws-newsletter__fields {
  display: flex;
  gap: var(--space-3);
  max-width: 480px;
  margin: 0 auto var(--space-4);
}

.ws-newsletter__fields .form-input {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  font-size: var(--text-body);
  font-family: var(--font-body);
  background: var(--color-neutral-white);
}

.ws-newsletter__fields .form-input:focus {
  outline: none;
  border-color: var(--color-secondary-400);
  box-shadow: 0 0 0 3px rgba(255,255,255,0.2);
}

.ws-newsletter__consent {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  max-width: 480px;
  margin: 0 auto;
  font-size: var(--text-caption);
  color: rgba(255,255,255,0.8);
  text-align: left;
  cursor: pointer;
}

.ws-newsletter__consent input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  accent-color: var(--color-neutral-white);
}

.ws-newsletter__consent a {
  color: var(--color-neutral-white);
  text-decoration: underline;
}

/* --- CTA Banner Beige Variant --- */

.cta-banner--beige {
  background: var(--color-neutral-100);
}

.cta-banner--beige h2 {
  color: var(--color-neutral-800);
}

.cta-banner--beige .cta-banner__subline {
  color: var(--color-neutral-600);
}

.cta-banner--beige .cta-banner__alt {
  color: var(--color-primary-500);
}

.cta-banner--beige .cta-banner__alt:hover {
  color: var(--color-primary-700);
}

.cta-banner--beige .text-body-sm {
  color: var(--color-neutral-400) !important;
}

.cta-banner--beige .text-body-sm a {
  color: var(--color-neutral-500) !important;
}

@media (max-width: 480px) {
  .ws-newsletter__fields {
    flex-direction: column;
  }
}


/* --- Enterprise CTA --- */

.ws-enterprise {
  background: var(--color-neutral-50);
  padding: var(--space-8) 0;
  border-top: 1px solid var(--color-neutral-100);
}

.ws-enterprise__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
}

@media (min-width: 768px) {
  .ws-enterprise__inner {
    grid-template-columns: 1.2fr 0.8fr;
    gap: var(--space-8);
  }
}

.ws-enterprise__text h2 {
  font-size: var(--text-h3);
  margin-bottom: var(--space-3);
}

.ws-enterprise__text p {
  color: var(--color-neutral-600);
}

.ws-enterprise__action {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  border-left: 4px solid var(--color-secondary-500);
}

.ws-enterprise__action p {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  margin-bottom: var(--space-4);
}


/* --- Accordion --- */

.ws-accordion {
  text-align: center;
  margin-top: var(--space-6);
}


.ws-accordion__toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  background: none;
  border: 2px solid var(--color-neutral-200);
  border-radius: var(--radius-full);
  padding: var(--space-3) var(--space-6);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  cursor: pointer;
  transition: all var(--transition-normal);
}

.ws-accordion__toggle:hover {
  border-color: var(--color-primary-400);
  color: var(--color-primary-500);
}

.ws-accordion__icon {
  transition: transform var(--transition-normal);
  font-size: 12px;
}


/* --- Guide / Founders (reworked) --- */

.ws-guide__photo {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
}

.ws-guide__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ws-founders {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  align-items: center;
  max-width: 800px;
  margin: 0 auto;
}

.ws-founders__photos {
  width: 100%;
}

.ws-founders__story {
  text-align: center;
}

.ws-founders__story p {
  color: var(--color-neutral-600);
  line-height: 1.7;
}

.ws-founders__names {
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-200);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
}

@media (min-width: 768px) {
  .ws-founders {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    align-items: start;
    gap: var(--space-8);
    text-align: left;
    max-width: none;
  }

  .ws-founders__photos {
    flex-direction: column;
    gap: var(--space-4);
  }

  .ws-founders__story {
    text-align: left;
  }

  .ws-guide__photo {
    width: 120px;
    height: 120px;
  }
}


/* --- Enterprise White Variant --- */

.ws-enterprise--white {
  background: var(--color-neutral-white);
  border-top: 1px solid var(--color-neutral-100);
  border-bottom: 1px solid var(--color-neutral-100);
}

.ws-enterprise--white .ws-enterprise__action {
  background: var(--color-neutral-50);
}


/* --- Filter alignment (left-aligned in grid section) --- */

#workshop-grid .ws-filter__tabs,
.ws-filter__tabs--table {
  justify-content: flex-start;
}


/* --- Clickable card link --- */

.ws-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.ws-card__link:hover {
  color: inherit;
}

/* Clickable table row */

.ws-table tbody tr[data-href] {
  cursor: pointer;
}



/* --- Founders: joint photo variant --- */

.ws-guide__photo--wide {
  width: 100%;
  max-width: 480px;
  height: auto;
  border-radius: var(--radius-lg);
}


/* --- Workshop Detail Page --- */

.ws-detail {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}

@media (min-width: 768px) {
  .ws-detail {
    grid-template-columns: 1fr 320px;
    gap: var(--space-8);
  }
}

.ws-detail__main h2 {
  font-size: var(--text-h3);
  margin-bottom: var(--space-4);
  margin-top: var(--space-8);
}

.ws-detail__main h2:first-child {
  margin-top: 0;
}

.ws-detail__main p {
  color: var(--color-neutral-600);
  line-height: 1.7;
  margin-bottom: var(--space-4);
}

.ws-detail__sidebar {
  position: sticky;
  top: var(--space-7);
  align-self: start;
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  padding: var(--space-6);
  border-top: 4px solid var(--color-primary-500);
}

.ws-detail__sidebar-img {
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-5);
}

.ws-detail__sidebar-img img {
  width: 100%;
  height: auto;
  display: block;
}

.ws-detail__price {
  font-family: var(--font-heading);
  font-size: var(--text-h2);
  font-weight: 700;
  color: var(--color-primary-500);
}

.ws-detail__price-note {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  margin-bottom: var(--space-5);
}


/* Detail Accordion */

.ws-detail__accordion-item {
  border-bottom: 1px solid var(--color-neutral-100);
}

.ws-detail__accordion-btn {
  width: calc(100% + 2 * var(--space-5));
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) var(--space-5);
  margin: 0 calc(-1 * var(--space-5));
  background: none;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-body);
  color: var(--color-neutral-800);
  cursor: pointer;
  text-align: left;
  transition: color var(--transition-normal), background var(--transition-normal);
}

.ws-detail__accordion-btn:hover {
  color: var(--color-primary-500);
  background: var(--color-primary-50);
}

.ws-detail__accordion-btn span:last-child {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--color-neutral-100);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
  flex-shrink: 0;
  transition: background var(--transition-normal), color var(--transition-normal);
}

.ws-detail__accordion-btn:hover span:last-child {
  background: var(--color-primary-100);
  color: var(--color-primary-600);
}

.ws-detail__accordion-content {
  display: none;
  padding: 0 var(--space-5) var(--space-4);
  color: var(--color-neutral-600);
  font-size: var(--text-body-sm);
  line-height: 1.7;
}

.ws-detail__accordion-content.is-open {
  display: block;
}


/* Detail target audience */

.ws-detail__audience {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  margin: var(--space-6) 0;
}

@media (min-width: 640px) {
  .ws-detail__audience {
    grid-template-columns: repeat(3, 1fr);
  }
}


/* --- Detail Page: Hero (two-column, no background image) --- */

/* Rounded card wrapper (shared pattern) */

.ws-detail__card {
  background: var(--color-neutral-white);
  border-radius: 16px;
  border: 1px solid var(--color-neutral-100);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.03);
  padding: var(--space-7);
}

/* Summary box (highlighted paragraph) */

.ws-detail__summary-box {
  background: var(--color-neutral-50);
  border-radius: 12px;
  border: 1px solid var(--color-neutral-100);
  padding: var(--space-5) var(--space-6);
}

.ws-detail__summary-box p {
  color: var(--color-neutral-700);
  margin: 0;
  line-height: 1.7;
}

/* Detail page: light gray body background */

body:has(.ws-detail-hero) {
  background: var(--color-neutral-50);
}

body:has(.ws-detail-hero) .section,
body:has(.ws-detail-hero) .section--alt {
  background: transparent;
}

body:has(.ws-detail-hero) .section {
  padding: var(--space-4) 0;
}

body:has(.ws-detail-hero) .ws-detail-hero {
  padding-top: var(--space-8);
  padding-bottom: var(--space-4);
}

.ws-detail-hero {
  padding-top: var(--space-9);
}

.ws-detail__main .ws-detail__kicker {
  font-family: var(--font-heading);
  font-size: var(--text-body-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary-500);
  margin-bottom: var(--space-4);
}

.ws-detail__kicker::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-secondary-500);
  margin-right: var(--space-2);
  vertical-align: middle;
}

.ws-detail__title {
  font-size: var(--text-h1);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-4);
  max-width: 600px;
}

.ws-detail__desc {
  font-size: var(--text-body-lg);
  color: var(--color-neutral-600);
  line-height: 1.7;
  margin-bottom: var(--space-5);
}

/* Section headings — clean, no accent lines */

.ws-detail__meta-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-3);
  margin-bottom: var(--space-6);
}

.ws-detail__meta-grid > div {
  background: var(--color-neutral-50);
  border-radius: 12px;
  border: 1px solid var(--color-neutral-100);
  padding: var(--space-4) var(--space-5);
}

.ws-detail__meta-grid span {
  display: block;
  font-size: 11px;
  font-family: var(--font-heading);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-primary-500);
}

.ws-detail__meta-grid strong {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-800);
}

.ws-detail__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--space-4);
}

.ws-detail__remind {
  font-size: var(--text-caption);
  color: var(--color-neutral-500);
  margin-top: var(--space-1);
}

/* Sidebar: inclusion list */

.ws-detail__sidebar-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-5) 0;
}

.ws-detail__sidebar-list li {
  position: relative;
  padding-left: var(--space-5);
  padding-bottom: var(--space-2);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.5;
}

.ws-detail__sidebar-list li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 7px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-secondary-500);
}

/* Audience cards (with H3) */

.ws-detail__audience-card {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--color-neutral-100);
}

.ws-detail__audience-card h3 {
  font-size: var(--text-body);
  font-weight: 600;
  color: var(--color-primary-500);
  margin-bottom: var(--space-2);
}

.ws-detail__audience-card p {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.6;
  margin: 0;
}

/* Focus items (three-column, simple) */

.ws-detail__focus-items {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin: var(--space-6) 0;
}

@media (min-width: 640px) {
  .ws-detail__focus-items {
    grid-template-columns: repeat(3, 1fr);
  }
}

.ws-detail__focus-item {
  background: var(--color-neutral-50);
  border-radius: 12px;
  border: 1px solid var(--color-neutral-100);
  padding: var(--space-5);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.7;
}

.ws-detail__focus-item strong {
  color: var(--color-primary-500);
  font-family: var(--font-heading);
  font-size: var(--text-body-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  display: block;
  margin-bottom: var(--space-2);
}

/* Trainer profiles */

.ws-detail__trainers {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  margin-top: var(--space-6);
}

@media (min-width: 640px) {
  .ws-detail__trainers {
    grid-template-columns: repeat(2, 1fr);
  }
}

.ws-detail__trainer {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  background: var(--color-neutral-50);
  border-radius: 12px;
  border: 1px solid var(--color-neutral-100);
  padding: var(--space-5);
}

.ws-detail__trainer-photo {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: var(--shadow-md);
}

.ws-detail__trainer-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.ws-detail__trainer-name {
  font-family: var(--font-heading);
  font-size: var(--text-body);
  font-weight: 600;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-1);
  display: block;
}

a.ws-detail__trainer-name {
  text-decoration: none;
  transition: color var(--transition-normal);
}

a.ws-detail__trainer-name:hover {
  color: var(--color-primary-500);
}

.ws-detail__trainer-role {
  font-size: var(--text-caption);
  color: var(--color-primary-500);
  font-family: var(--font-heading);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-bottom: var(--space-2);
}

.ws-detail__trainer-text {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.6;
  margin: 0;
}

/* Bottom CTA */

.ws-detail__cta-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: start;
}

@media (min-width: 768px) {
  .ws-detail__cta-grid {
    grid-template-columns: 1fr 300px;
  }
}

.ws-detail__cta-list {
  list-style: none;
  padding: 0;
  margin: var(--space-4) 0 0 0;
}

.ws-detail__cta-list li {
  position: relative;
  padding-left: var(--space-5);
  padding-bottom: var(--space-3);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-700);
}

.ws-detail__cta-list li::before {
  content: '';
  position: absolute;
  left: 2px;
  top: 7px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-secondary-500);
}

.ws-detail__cta-info {
  font-size: var(--text-caption);
  color: var(--color-neutral-500);
  margin: var(--space-2) 0 var(--space-3);
}

.ws-detail__cta-box {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  padding: var(--space-7);
  text-align: center;
  border-top: 4px solid var(--color-primary-500);
}


/* ============================================
   About Page
   ============================================ */

.ws-hero--about {
  background-image: url('../img/hero-ueber-uns.webp');
}

/* About: Angebote (Card-Style) */

.about__offerings {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 640px) {
  .about__offerings {
    grid-template-columns: repeat(3, 1fr);
  }
}

.about__offering {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}

.about__offering:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.about__offering-img {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.about__offering-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.about__offering:hover .about__offering-img img {
  transform: scale(1.05);
}

.about__offering-img__label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: var(--space-5);
  background: linear-gradient(135deg, rgba(0, 50, 60, 0.55) 0%, rgba(0, 50, 60, 0.35) 100%);
  font-family: var(--font-heading);
  font-size: var(--text-h3);
  font-weight: 700;
  color: var(--color-neutral-white);
  letter-spacing: -0.01em;
}

.about__offering-body {
  padding: var(--space-5);
}

.about__offering-body p {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.6;
  margin: 0;
}


/* About: Blockquote single line (nowrap nur auf Desktop —
   auf Mobile erzeugt es horizontales Scrollen) */

.ws-hero--about ~ .section .blockquote {
  max-width: none;
}

@media (min-width: 768px) {
  .ws-hero--about ~ .section .blockquote {
    white-space: nowrap;
  }
}

/* About: Value cards with gray background */

.value-card.feature-card {
  background: var(--color-neutral-white);
  border: 1px solid var(--color-neutral-100);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* About: Team grid layout */

.about__team {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: start;
}

.about__team-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.about__team-img img {
  width: 100%;
  height: auto;
  display: block;
}

.about__team-text p {
  color: var(--color-neutral-600);
  line-height: 1.7;
}

.about__team-names {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-neutral-200);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-500);
}

@media (min-width: 768px) {
  .about__team {
    grid-template-columns: 0.9fr 1.1fr;
    gap: var(--space-8);
  }
}


/* ============================================
   Contact Page
   ============================================ */

.ws-hero--beratung {
  background-image: url('../img/hero-beratung.webp');
}

.ws-hero--enabler {
  background-image: url('../img/atmosphere-enabler.webp');
}

.ws-hero--home {
  background-image: url('../img/hero-home.webp');
  /* Bei sehr breitem Viewport nicht den Kopf abschneiden: Fokus etwas oberhalb der Mitte */
  background-position: center 30%;
}

/* --- Enabler Card Redesign --- */

.enabler-card {
  background: var(--color-neutral-white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-normal), transform var(--transition-normal);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-5) var(--space-4);
}

.enabler-card__image {
  width: 280px;
  height: 280px;
  max-width: 100%;
  aspect-ratio: 1;
  border-radius: 50%;
  margin: 0 auto var(--space-4);
  background: var(--color-neutral-200);
  overflow: hidden;
  flex-shrink: 0;
}

.enabler-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
  border-radius: 50%;
}

.ws-hero--webseiten {
  background-image: url('../img/hero-webseiten.webp?v=3');
}

.ws-hero--kontakt {
  background-image: url('../img/hero-kontakt.webp');
}

.ws-hero--kiteam {
  background-image: url('../img/hero-kiteam.webp');
  /* Gesicht sitzt im oberen Bilddrittel: Fokus nach oben, damit der Kopf nicht abgeschnitten wird */
  background-position: center 22%;
}

/* Mehrfach-Auswahl Checkboxen (z. B. Wunschzeiten Warteliste) */
.form-checkgroup {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2) var(--space-4);
  margin-top: var(--space-2);
}

@media (max-width: 600px) {
  .form-checkgroup {
    grid-template-columns: 1fr;
  }
}

/* Startseiten-Highlight: Flaggschiff „Dein KI-Team" */
.kiteam-feature {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  align-items: center;
  background: var(--color-primary-50);
  border: 1px solid var(--color-primary-100);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
}

.kiteam-feature__image img {
  width: 100%;
  border-radius: var(--radius-md);
  object-fit: cover;
  display: block;
}

@media (min-width: 768px) {
  .kiteam-feature {
    grid-template-columns: 1.1fr 1fr;
    gap: var(--space-8);
    padding: var(--space-8);
  }
}

/* FAQ-Accordion (crawlbar, GEO-freundlich) */
.faq-item { border: 1px solid var(--color-neutral-200); border-radius: var(--radius-md); margin-bottom: var(--space-3); background: #fff; }
.faq-item__q { cursor: pointer; padding: var(--space-4) var(--space-6) var(--space-4) var(--space-5); font-weight: 600; color: var(--color-neutral-800); list-style: none; position: relative; }
.faq-item__q::-webkit-details-marker { display: none; }
.faq-item__q::after { content: '+'; position: absolute; right: var(--space-5); top: var(--space-4); color: var(--color-primary-500); font-weight: 700; font-size: 1.2em; line-height: 1; }
.faq-item[open] .faq-item__q::after { content: '–'; }
.faq-item__a { padding: 0 var(--space-5) var(--space-4); color: var(--color-neutral-600); }
.faq-item__a p { margin: 0; }

.contact__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}

@media (min-width: 768px) {
  .contact__layout {
    grid-template-columns: 1.4fr 0.6fr;
    gap: var(--space-9);
    align-items: start;
  }
}

.contact__form-title {
  font-size: var(--text-h3);
  margin-bottom: var(--space-6);
}

.contact__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact__submit {
  align-self: flex-start;
}

/* Sidebar */

.contact__sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.contact__info-card {
  background: var(--color-neutral-50);
  border: 1px solid var(--color-neutral-100);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.contact__info-card h3 {
  font-size: var(--text-body);
  font-weight: 600;
  color: var(--color-neutral-800);
  margin-bottom: var(--space-5);
}

.contact__info-item {
  padding: var(--space-4) 0;
  border-top: 1px solid var(--color-neutral-200);
}

.contact__info-label {
  display: block;
  font-family: var(--font-heading);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-neutral-400);
  margin-bottom: var(--space-1);
}

.contact__info-link {
  color: var(--color-primary-500);
  font-weight: 500;
  text-decoration: none;
}

.contact__info-link:hover {
  text-decoration: underline;
}

.contact__response-note {
  background: var(--color-primary-50);
  border-left: 3px solid var(--color-primary-500);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
}

.contact__response-note p {
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
  line-height: 1.6;
  margin: 0;
}


/* ============================================
   Beratung Page
   ============================================ */

/* --- Portfolio Cards --- */

.portfolio-card {
  display: block;
  background: var(--color-neutral-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: box-shadow 0.2s, transform 0.2s;
}

.portfolio-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.portfolio-card img {
  border-radius: 0 !important;
}

.portfolio-card__description {
  text-align: center;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-body-sm);
  color: var(--color-neutral-600);
}


.stakes__split {
  display: flex;
  flex-direction: column;
  gap: var(--space-7);
}

.stakes__split .stakes__content {
  text-align: center;
}

.stakes__image img {
  width: 100%;
  border-radius: var(--radius-lg);
  object-fit: cover;
}

@media (min-width: 768px) {
  .stakes__split {
    flex-direction: row;
    align-items: center;
    gap: var(--space-8);
  }

  .stakes__split .stakes__content {
    flex: 1.1;
    text-align: left;
  }

  .stakes__image {
    flex: 0.9;
  }
}

.beratung__price {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--color-primary-500);
}

/* --- FAQ --- */

.faq-list {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq-item {
  background: var(--color-neutral-white);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: box-shadow var(--transition-normal);
}

.faq-item[open] {
  box-shadow: var(--shadow-sm);
}

.faq-item__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-5) var(--space-6);
  font-family: var(--font-heading);
  font-weight: 600;
  font-size: var(--text-body);
  color: var(--color-neutral-800);
  cursor: pointer;
  list-style: none;
}

.faq-item__question::-webkit-details-marker {
  display: none;
}

.faq-item__question::after {
  content: '+';
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--color-primary-500);
  transition: transform var(--transition-normal);
  flex-shrink: 0;
  margin-left: var(--space-4);
}

.faq-item[open] .faq-item__question::after {
  content: '−';
}

.faq-item__answer {
  padding: 0 var(--space-6) var(--space-5);
}

.faq-item__answer p {
  color: var(--color-neutral-600);
  line-height: 1.7;
  margin: 0;
}

.faq-item__answer p + p {
  margin-top: 1em;
}


/* --- Reduced Motion (WCAG 2.3.3) ---
   Nutzer mit Betriebssystem-Einstellung "Bewegung reduzieren" bekommen
   keine dekorativen Bewegungen. Scroll-Fade-Ins erscheinen sofort am Ziel,
   sonstige Transitions/Animationen werden auf nicht wahrnehmbar gesetzt.
   Betrifft AUSSCHLIESSLICH prefers-reduced-motion: reduce – keine Auswirkung
   auf normale Besucher. */
@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;
  }

  /* Scroll-Fade-Ins direkt im Endzustand zeigen (auch ohne IntersectionObserver-Trigger) */
  .fade-in {
    opacity: 1 !important;
    transform: none !important;
  }
}
