/* ============================================================================
   Webdesign-Page Sections — Welle 5.27 v1 (2026-05-21)
   ----------------------------------------------------------------------------
   Sections (alle Mobile-First):
     2. Why Website > FB (wd-why)
     3. Pakete (wd-pricing)
     4. Booking-Add-on (wd-related)
     5. Prozess (wd-process — wrapper, recycelt process-section-v2.css)
     6. Referenzen (wd-ref)
     7. FAQ (wd-faq)
     8. Final CTA (wd-cta)
   Common: wd-section-header, wd-section-title, wd-section-sub
   ============================================================================ */

/* ─── Common Section-Header ──────────────────────────────────────────────── */
/* Welle 5.27 v24: alle wd-* Section-Header linksbündig (statt zentriert) —
   Brand-Konsistenz zur Startseite (Editorial-Pattern: Header links, Content
   zentriert/full-width). */
.wd-section-header {
  margin: 0 auto clamp(2rem, 5vw, 3.5rem) 0;
  max-width: 760px;
  text-align: left;
}

/* Welle 5.27 v14/v24/v29: --at-* Token-Aliases für ALLE wd-* Sections */
.wd-vs,
.wd-pricing,
.wd-related,
.wd-process,
.wd-ref,
.wd-for-good,
.wd-powerups,
.wd-faq,
.wd-cta {
  --at-mocha:     #1498D5;
  --at-ink:       #0A1B33;
  --at-ink-soft:  rgba(10, 27, 51, 0.65);
  --at-font-body: var(--font-main, 'Inter', system-ui, sans-serif);
}
body.is-dark-bg .wd-vs,
body.is-dark-bg .wd-pricing,
body.is-dark-bg .wd-related,
body.is-dark-bg .wd-process,
body.is-dark-bg .wd-ref,
body.is-dark-bg .wd-for-good,
body.is-dark-bg .wd-powerups,
body.is-dark-bg .wd-faq,
body.is-dark-bg .wd-cta {
  --at-mocha:     #3EB6F0;
  --at-ink:       #F0F4FA;
  --at-ink-soft:  rgba(240, 244, 250, 0.65);
}

/* Headline einzeilig (Desktop). Mobile darf umbrechen. */
@media (min-width: 768px) {
  .wd-vs .wd-section-title {
    white-space: nowrap;
    max-width: none;
  }
}
.wd-section-title {
  font-size: clamp(1.85rem, 5vw, 2.8rem);
  font-weight: 800;
  line-height: 1.12;
  letter-spacing: -0.025em;
  color: #0A1B33;
  margin: 0.5rem 0 0.75rem;
  text-wrap: balance;
}
.wd-section-sub {
  font-size: 1.02rem;
  line-height: 1.55;
  color: rgba(10, 27, 51, 0.65);
  margin: 0;
  max-width: 56ch;
}
body.is-dark-bg .wd-section-title { color: #F0F4FA; }
body.is-dark-bg .wd-section-sub { color: rgba(240, 244, 250, 0.72); }

/* Section-spacing global */
.wd-vs,
.wd-why,
.wd-pricing,
.wd-related,
.wd-process,
.wd-ref,
.wd-powerups,
.wd-faq,
.wd-cta {
  padding: clamp(3.5rem, 8vw, 6rem) 0;
  position: relative;
}

/* ═══════════════════════════════════════════════════════════════════════════
   7a. POWER-UPS — Welle 5.27 v29: Cross-Sell-Tiles am Page-Ende
   Kompakt, skalierbar (1/2/3/4 Tiles), Pattern: Stripe Related Products.
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-powerups-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2vw, 1.5rem);
  max-width: 980px;
  margin: 0 auto;
}
@media (min-width: 640px) {
  .wd-powerups-grid { grid-template-columns: 1fr 1fr; }
}

.wd-powerup {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: clamp(1rem, 2vw, 1.25rem);
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(20, 152, 213, 0.15);
  border-radius: 18px;
  text-decoration: none;
  color: inherit;
  align-items: center;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.wd-powerup:hover {
  transform: translateY(-3px);
  border-color: rgba(20, 152, 213, 0.4);
  box-shadow: 0 18px 36px -12px rgba(20, 152, 213, 0.22);
}
body.is-dark-bg .wd-powerup {
  background: rgba(26, 41, 64, 0.5);
  border-color: rgba(62, 182, 240, 0.18);
}
body.is-dark-bg .wd-powerup:hover {
  border-color: rgba(62, 182, 240, 0.45);
  box-shadow: 0 18px 36px -12px rgba(62, 182, 240, 0.28);
}

/* Tile-Icon — Service-Logo (booking, qr, etc.) */
.wd-powerup-icon {
  width: 56px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.wd-powerup-icon img {
  width: auto;
  height: 100%;
  max-width: 56px;
  max-height: 56px;
  object-fit: contain;
}

.wd-powerup-body {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.wd-powerup-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #0A1B33;
  margin: 0;
  letter-spacing: -0.015em;
}
body.is-dark-bg .wd-powerup-title { color: #F0F4FA; }

.wd-powerup-pitch {
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(10, 27, 51, 0.65);
  margin: 0 0 0.4rem;
}
body.is-dark-bg .wd-powerup-pitch { color: rgba(240, 244, 250, 0.7); }

.wd-powerup-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: #1498D5;
  transition: color 0.2s, gap 0.2s;
}
.wd-powerup:hover .wd-powerup-cta {
  gap: 0.6rem;
}
body.is-dark-bg .wd-powerup-cta { color: #3EB6F0; }

/* Coming-soon Variante (z.B. QR — Subpage noch nicht live) */
.wd-powerup--soon {
  opacity: 0.78;
  cursor: default;
}
.wd-powerup--soon:hover {
  transform: none;
  border-color: rgba(20, 152, 213, 0.15);
  box-shadow: none;
}
body.is-dark-bg .wd-powerup--soon:hover {
  border-color: rgba(62, 182, 240, 0.18);
}
.wd-powerup-cta--soon {
  color: rgba(10, 27, 51, 0.55);
  font-style: italic;
  font-weight: 500;
}
body.is-dark-bg .wd-powerup-cta--soon {
  color: rgba(240, 244, 250, 0.55);
}

/* ═══════════════════════════════════════════════════════════════════════════
   2. FACEBOOK vs WEBSITE — Welle 5.27 v7 Side-by-Side Vergleich
   Pattern: Apple/Stripe Compare-Page. Wenig Text, klarer Kontrast.
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-vs-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.5vw, 1.75rem);
  max-width: 1100px;
  margin: 0 auto;
  position: relative;
}

/* Welle 5.27 v19: Alternatives-Grid (2×2) für 4 Platform-Cards.
   Mobile: 1 Spalte stacked.
   Tablet+: 2 Spalten.
   Container ist EIN Grid-Cell innerhalb wd-vs-grid. */
.wd-vs-alts {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(0.75rem, 1.5vw, 1rem);
}
@media (min-width: 540px) {
  .wd-vs-alts {
    grid-template-columns: 1fr 1fr;
  }
}

/* Kompakte Alternative-Card (gegen 4er-Grid) */
.wd-vs-alt {
  padding: clamp(1rem, 2vw, 1.25rem) clamp(1rem, 2vw, 1.25rem) clamp(1rem, 2vw, 1.25rem);
  gap: 0.75rem;
}
.wd-vs-alt .wd-vs-card-title {
  font-size: 0.95rem;
}
.wd-vs-alt .wd-vs-card-head {
  padding-bottom: 0.65rem;
  gap: 0.6rem;
}
.wd-vs-alt .wd-vs-card-icon {
  width: 32px;
  height: 32px;
}
.wd-vs-alt .wd-vs-list li {
  font-size: 0.86rem;
  padding-left: 1.6rem;
  line-height: 1.4;
}
.wd-vs-alt .wd-vs-list li::before {
  width: 18px;
  height: 18px;
  font-size: 0.72rem;
}

/* Winner-Card (Website) — prominent, vergrößert */
.wd-vs-winner {
  padding: clamp(1.75rem, 3.5vw, 2.5rem);
}
.wd-vs-winner .wd-vs-card-title {
  font-size: clamp(1.25rem, 2.6vw, 1.5rem);
}
.wd-vs-winner .wd-vs-list li {
  font-size: 1rem;
  font-weight: 500;
}

/* Icon-Farben für die 4 Plattformen */
.wd-vs-card-icon--line { background: #06C755; color: #fff; }
.wd-vs-card-icon--ig {
  background: linear-gradient(135deg, #833AB4 0%, #FD1D1D 50%, #F77737 100%);
  color: #fff;
}
.wd-vs-card-icon--tt {
  background: #000;
  color: #fff;
  /* Subtle TikTok cyan+magenta glow */
  box-shadow:
    -1px -1px 0 rgba(37, 244, 238, 0.55),
    1px 1px 0 rgba(254, 44, 85, 0.55);
}

/* ─── Mobile-VS-Section: Sub-Headers + Divider (Welle 5.27 v47, 2026-05-24) ──
   Auf Desktop macht das Layout (2 Spalten) den 4-vs-1-Bezug klar. Auf Mobile
   stehen alle 5 Cards untereinander — ohne visuelle Hierarchie. Diese
   Sub-Headers + Mobile-Divider erklären die Story: ❌ 4 Alts (alle haben
   Limits) → VS → ✓ Winner (only website does it all).
   Hidden auf Tablet+ (display:none in @media min-width:768px Block unten). */
.wd-vs-mobile-label {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-transform: uppercase;
  margin: 0 0 0.85rem;
  padding: 0;
}
.wd-vs-mobile-label--neg {
  color: rgba(10, 27, 51, 0.55);
}
.wd-vs-mobile-label--pos {
  color: #0F7BB2;
  margin-top: 0.5rem;
}
body.is-dark-bg .wd-vs-mobile-label--neg { color: rgba(240, 244, 250, 0.55); }
body.is-dark-bg .wd-vs-mobile-label--pos { color: #5DC4F4; }

.wd-vs-mobile-label-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 0.7rem;
  font-weight: 800;
  flex-shrink: 0;
}
.wd-vs-mobile-label--neg .wd-vs-mobile-label-mark {
  background: rgba(220, 38, 38, 0.15);
  color: #b91c1c;
}
.wd-vs-mobile-label--pos .wd-vs-mobile-label-mark {
  background: rgba(20, 152, 213, 0.18);
  color: #0F7BB2;
}
body.is-dark-bg .wd-vs-mobile-label--neg .wd-vs-mobile-label-mark {
  background: rgba(248, 113, 113, 0.18);
  color: #f87171;
}
body.is-dark-bg .wd-vs-mobile-label--pos .wd-vs-mobile-label-mark {
  background: rgba(62, 182, 240, 0.22);
  color: #7FD0F8;
}

.wd-vs-mobile-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 1.5rem 0 1.25rem;
  position: relative;
}
.wd-vs-mobile-divider::before,
.wd-vs-mobile-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(20, 152, 213, 0.25), transparent);
}
.wd-vs-mobile-divider::before { margin-right: 1rem; }
.wd-vs-mobile-divider::after  { margin-left:  1rem; }
.wd-vs-mobile-divider-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #3EB6F0 0%, #1498D5 50%, #0F7BB2 100%);
  color: #fff;
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  box-shadow:
    0 0 0 3px #FAFBFD,
    0 8px 20px -4px rgba(20, 152, 213, 0.4);
}
body.is-dark-bg .wd-vs-mobile-divider-badge {
  box-shadow:
    0 0 0 3px #0A1B33,
    0 8px 20px -4px rgba(62, 182, 240, 0.45);
}

@media (min-width: 768px) {
  /* Auf Tablet+ die Mobile-Sub-Headers + Divider verstecken
     (Desktop-Layout erklärt den 4-vs-1-Bezug visuell). */
  .wd-vs-mobile-label,
  .wd-vs-mobile-divider {
    display: none;
  }

  .wd-vs-grid {
    /* 2-spaltig: links 4 small alternatives (2×2), rechts 1 winner */
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
  }
  /* VS-Badge — Welle 5.27 v16: dezenter aber geiler
     - 58px (zwischen 52 und 72, premium-mittig)
     - Solid Brand-Blue mit subtle inner gradient (Linear/Stripe-Style)
     - Clean white outer ring (3px) + single soft drop-shadow
     - Subtle continuous glow-pulse (kaum sichtbar, gibt Lebensgefühl)
     - JetBrains Mono Text, clean, no heavy text-shadow */
  .wd-vs-grid::before {
    content: 'VS';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%) scale(0) rotate(-45deg);
    opacity: 0;
    width: 58px;
    height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
      radial-gradient(circle at 35% 30%, #3EB6F0 0%, #1498D5 50%, #0F7BB2 100%);
    color: #fff;
    border-radius: 50%;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    font-family: 'JetBrains Mono', ui-monospace, monospace;
    box-shadow:
      0 0 0 3px #FAFBFD,
      0 10px 24px -6px rgba(20, 152, 213, 0.40),
      0 4px 10px -2px rgba(10, 27, 51, 0.20);
    z-index: 3;
    transition: transform 0.7s cubic-bezier(0.34, 1.6, 0.5, 1), opacity 0.4s ease-out;
  }
  .wd-vs-grid::before {
    transform: translate(-50%, -50%) scale(1) rotate(0deg);
    opacity: 1;
    animation: wd-vs-badge-pulse 3.5s ease-in-out 1s infinite;
  }
  @keyframes wd-vs-badge-pulse {
    0%, 100% {
      box-shadow:
        0 0 0 3px #FAFBFD,
        0 10px 24px -6px rgba(20, 152, 213, 0.40),
        0 4px 10px -2px rgba(10, 27, 51, 0.20);
    }
    50% {
      box-shadow:
        0 0 0 3px #FAFBFD,
        0 12px 32px -4px rgba(20, 152, 213, 0.55),
        0 4px 10px -2px rgba(10, 27, 51, 0.20);
    }
  }
  body.is-dark-bg .wd-vs-grid::before {
    background: radial-gradient(circle at 35% 30%, #5DC4F4 0%, #3EB6F0 50%, #1498D5 100%);
    box-shadow:
      0 0 0 3px #0A1B33,
      0 10px 24px -6px rgba(62, 182, 240, 0.45),
      0 4px 10px -2px rgba(0, 0, 0, 0.35);
  }
  body.is-dark-bg .wd-vs-grid::before {
    animation-name: wd-vs-badge-pulse-dark;
  }
  @keyframes wd-vs-badge-pulse-dark {
    0%, 100% {
      box-shadow:
        0 0 0 3px #0A1B33,
        0 10px 24px -6px rgba(62, 182, 240, 0.45),
        0 4px 10px -2px rgba(0, 0, 0, 0.35);
    }
    50% {
      box-shadow:
        0 0 0 3px #0A1B33,
        0 12px 32px -4px rgba(62, 182, 240, 0.65),
        0 4px 10px -2px rgba(0, 0, 0, 0.35);
    }
  }
  /* Reduced-Motion: badge sofort visible, kein pulse */
  @media (prefers-reduced-motion: reduce) {
    .wd-vs-grid::before {
      transform: translate(-50%, -50%) scale(1) rotate(0deg);
      opacity: 1;
      transition: none;
      animation: none !important;
    }
  }
}

.wd-vs-card {
  position: relative;
  padding: clamp(1.5rem, 3vw, 2rem) clamp(1.5rem, 3vw, 2rem) clamp(1.75rem, 3vw, 2.25rem);
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  transition: transform 0.3s, box-shadow 0.3s;
}

/* Facebook-Card (negative) — gedämpft, slightly muted */
.wd-vs-card--neg {
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(10, 27, 51, 0.10);
  color: rgba(10, 27, 51, 0.65);
}
body.is-dark-bg .wd-vs-card--neg {
  background: rgba(26, 41, 64, 0.45);
  border-color: rgba(240, 244, 250, 0.10);
  color: rgba(240, 244, 250, 0.55);
}

/* Website-Card (positive) — Brand-Blue dominant */
.wd-vs-card--pos {
  background: linear-gradient(135deg, rgba(20, 152, 213, 0.10) 0%, rgba(20, 152, 213, 0.04) 100%);
  border: 1.5px solid rgba(20, 152, 213, 0.35);
  color: #0A1B33;
  box-shadow: 0 12px 32px -10px rgba(20, 152, 213, 0.22);
}
body.is-dark-bg .wd-vs-card--pos {
  background: linear-gradient(135deg, rgba(62, 182, 240, 0.16) 0%, rgba(62, 182, 240, 0.06) 100%);
  border-color: rgba(62, 182, 240, 0.45);
  color: #F0F4FA;
  box-shadow: 0 12px 32px -10px rgba(62, 182, 240, 0.25);
}

.wd-vs-card-head {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid currentColor;
  border-bottom-color: rgba(10, 27, 51, 0.08);
}
body.is-dark-bg .wd-vs-card-head {
  border-bottom-color: rgba(240, 244, 250, 0.10);
}
.wd-vs-card--pos .wd-vs-card-head {
  border-bottom-color: rgba(20, 152, 213, 0.22);
}
body.is-dark-bg .wd-vs-card--pos .wd-vs-card-head {
  border-bottom-color: rgba(62, 182, 240, 0.28);
}

.wd-vs-card-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
}
.wd-vs-card-icon--fb {
  background: #1877F2;
  color: #fff;
}
.wd-vs-card-icon--www {
  background: #1498D5;
  color: #fff;
}
body.is-dark-bg .wd-vs-card-icon--www {
  background: #3EB6F0;
}

.wd-vs-card-title {
  font-size: clamp(1.1rem, 2.4vw, 1.3rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  margin: 0;
  color: #0A1B33;
}
.wd-vs-card--neg .wd-vs-card-title {
  color: rgba(10, 27, 51, 0.7);
}
body.is-dark-bg .wd-vs-card-title {
  color: #F0F4FA;
}
body.is-dark-bg .wd-vs-card--neg .wd-vs-card-title {
  color: rgba(240, 244, 250, 0.7);
}

.wd-vs-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.wd-vs-list li {
  position: relative;
  padding-left: 2rem;
  font-size: 0.98rem;
  line-height: 1.5;
}
.wd-vs-list li::before {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 22px;
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-size: 0.85rem;
  font-weight: 700;
  line-height: 1;
}
/* Negative: red ✕ */
.wd-vs-list--neg li::before {
  content: '✕';
  background: rgba(220, 53, 53, 0.12);
  color: #DC3535;
}
body.is-dark-bg .wd-vs-list--neg li::before {
  background: rgba(255, 120, 120, 0.16);
  color: #FF8888;
}
/* Positive: brand-blue ✓ */
.wd-vs-list--pos li::before {
  content: '✓';
  background: rgba(20, 152, 213, 0.18);
  color: #0F7BB2;
}
body.is-dark-bg .wd-vs-list--pos li::before {
  background: rgba(62, 182, 240, 0.22);
  color: #5DC4F4;
}

/* ═══════════════════════════════════════════════════════════════════════════
   2b. DRAMA-PACK Welle 5.27 v9 — Flash, Particles, Shine, Static, Rays
   ═══════════════════════════════════════════════════════════════════════════ */

/* Pre-Flash Overlay — füllt die ganze Section, kurz weißer Puls */
.wd-vs { overflow: hidden; }
.wd-vs-flash {
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(255,255,255,0.85), rgba(255,255,255,0) 70%);
  opacity: 0;
  pointer-events: none;
  z-index: 5;
  mix-blend-mode: overlay;
}
body.is-dark-bg .wd-vs-flash {
  background: radial-gradient(ellipse at center, rgba(62,182,240,0.6), rgba(62,182,240,0) 70%);
}

/* Section ist Container für absolute children */
.wd-vs { position: relative; }

/* Particle-Container (innerhalb Website-Card) */
.wd-vs-particles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: visible;
  z-index: 3;
}
.wd-vs-particle {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  pointer-events: none;
  box-shadow: 0 0 10px currentColor;
  will-change: transform, opacity;
}

/* Website-Card pulsing glow (continuous, eingeschaltet via JS) */
.wd-vs-card--pulsing {
  animation: wd-vs-pulse 2.4s ease-in-out infinite;
}
@keyframes wd-vs-pulse {
  0%, 100% { box-shadow: 0 12px 32px -10px rgba(20, 152, 213, 0.22); }
  50%      { box-shadow: 0 16px 48px -8px rgba(20, 152, 213, 0.55), 0 0 0 2px rgba(20, 152, 213, 0.35); }
}
body.is-dark-bg .wd-vs-card--pulsing {
  animation: wd-vs-pulse-dark 2.4s ease-in-out infinite;
}
@keyframes wd-vs-pulse-dark {
  0%, 100% { box-shadow: 0 12px 32px -10px rgba(62, 182, 240, 0.25); }
  50%      { box-shadow: 0 16px 48px -8px rgba(62, 182, 240, 0.55), 0 0 0 2px rgba(62, 182, 240, 0.45); }
}

/* Website-Card continuous Shine-Sweep (diagonal light reflection) */
.wd-vs-card--pos {
  position: relative;
  overflow: hidden;
}
.wd-vs-card--pos::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, transparent 30%, rgba(255, 255, 255, 0.18) 50%, transparent 70%);
  transform: translateX(-100%);
  animation: wd-vs-shine 4.5s ease-in-out infinite;
  pointer-events: none;
}
@keyframes wd-vs-shine {
  0%, 60% { transform: translateX(-100%); }
  85%     { transform: translateX(100%); }
  100%    { transform: translateX(100%); }
}

/* FB-Card Static-Noise Overlay (continuous, leichte Interferenz-Streifen) */
.wd-vs-card--neg {
  position: relative;
  overflow: hidden;
}
.wd-vs-card--static::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    rgba(255,255,255,0) 0px,
    rgba(255,255,255,0) 2px,
    rgba(220, 53, 53, 0.04) 2px,
    rgba(220, 53, 53, 0.04) 3px
  );
  pointer-events: none;
  animation: wd-vs-static 0.18s steps(3) infinite;
  mix-blend-mode: overlay;
  opacity: 0.6;
}
@keyframes wd-vs-static {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-3px); }
}

/* Welle 5.27 v16: Sun-Rays raus — zu viel. Dezenter Pulse-Halo reicht. */

/* Letter-Drop helpers (gesetzt von JS, keine extra Styles nötig — gsap handles transform) */
.wd-vs-word { display: inline-block; }
.wd-vs-letter { display: inline-block; will-change: transform, opacity; }

/* Reduced-Motion: alle dramatischen Effekte aus */
@media (prefers-reduced-motion: reduce) {
  .wd-vs-card--pulsing,
  .wd-vs-card--pos::after,
  .wd-vs-card--static::after,
  .wd-vs-grid::after {
    animation: none !important;
  }
  .wd-vs-flash,
  .wd-vs-particles {
    display: none;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   2. WHY WEBSITE > FACEBOOK — Q&A Editorial Pattern
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-why { background: transparent; }

.wd-qa-list {
  display: flex;
  flex-direction: column;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  margin: 0;
  padding: 0;
  list-style: none;
  max-width: 840px;
  margin-left: auto;
  margin-right: auto;
}
.wd-qa {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: clamp(1rem, 2.5vw, 1.6rem);
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid rgba(20, 152, 213, 0.12);
  border-radius: 18px;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  box-shadow: 0 8px 24px -8px rgba(10, 27, 51, 0.06);
}
body.is-dark-bg .wd-qa {
  background: rgba(26, 41, 64, 0.55);
  border-color: rgba(62, 182, 240, 0.18);
}
.wd-qa-num {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #1498D5;
  padding-top: 0.25rem;
}
body.is-dark-bg .wd-qa-num { color: #3EB6F0; }
.wd-qa-q {
  font-size: clamp(1.05rem, 2.2vw, 1.25rem);
  font-weight: 700;
  line-height: 1.35;
  color: #0A1B33;
  margin: 0 0 0.65rem;
  font-style: italic;
}
body.is-dark-bg .wd-qa-q { color: #F0F4FA; }
.wd-qa-a {
  font-size: 0.96rem;
  line-height: 1.65;
  color: rgba(10, 27, 51, 0.72);
  margin: 0;
}
body.is-dark-bg .wd-qa-a { color: rgba(240, 244, 250, 0.75); }

/* ═══════════════════════════════════════════════════════════════════════════
   3. PAKETE — Business / Professional / Premium
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-pricing {
  background: linear-gradient(180deg, transparent 0%, rgba(20, 152, 213, 0.03) 50%, transparent 100%);
}
body.is-dark-bg .wd-pricing {
  background: linear-gradient(180deg, transparent 0%, rgba(62, 182, 240, 0.05) 50%, transparent 100%);
}

/* Base-Inclusion-Bar — "Always included in all plans" */
.wd-base-bar {
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid rgba(20, 152, 213, 0.15);
  border-radius: 16px;
  padding: clamp(1.1rem, 2.2vw, 1.5rem) clamp(1.25rem, 2.5vw, 1.75rem);
  margin-bottom: 2rem;
}
body.is-dark-bg .wd-base-bar {
  background: rgba(26, 41, 64, 0.5);
  border-color: rgba(62, 182, 240, 0.2);
}
.wd-base-bar-label {
  display: block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1498D5;
  margin-bottom: 0.85rem;
}
body.is-dark-bg .wd-base-bar-label { color: #3EB6F0; }
.wd-base-bar-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem 1.5rem;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.9rem;
  color: rgba(10, 27, 51, 0.78);
}
.wd-base-bar-list li {
  position: relative;
  padding-left: 1.4rem;
  line-height: 1.5;
}
.wd-base-bar-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #1498D5;
  font-weight: 700;
}
body.is-dark-bg .wd-base-bar-list { color: rgba(240, 244, 250, 0.78); }
body.is-dark-bg .wd-base-bar-list li::before { color: #3EB6F0; }
@media (min-width: 768px) {
  .wd-base-bar-list { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
  .wd-base-bar-list { grid-template-columns: repeat(3, 1fr); }
}

/* Tier-Grid */
.wd-tier-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
@media (min-width: 768px) {
  .wd-tier-grid { grid-template-columns: repeat(3, 1fr); align-items: stretch; }
}

.wd-tier {
  position: relative;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(20, 152, 213, 0.15);
  border-radius: 20px;
  padding: clamp(1.5rem, 3vw, 2rem);
  display: flex;
  flex-direction: column;
  /* Welle 5.27 v25: height:100% erzwingt stretch in grid → alle 3 Cards
     gleich hoch (Stripe/Linear/Notion-Standard). flex:1 auf .wd-tier-features
     füllt den verbleibenden Platz, CTA bleibt am bottom gepinnt. */
  height: 100%;
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  box-shadow: 0 12px 32px -12px rgba(10, 27, 51, 0.1);
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.wd-tier:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 44px -12px rgba(10, 27, 51, 0.18);
  border-color: rgba(20, 152, 213, 0.3);
}
body.is-dark-bg .wd-tier {
  background: rgba(26, 41, 64, 0.6);
  border-color: rgba(62, 182, 240, 0.18);
}
body.is-dark-bg .wd-tier:hover { border-color: rgba(62, 182, 240, 0.4); }

.wd-tier--featured {
  border-color: rgba(20, 152, 213, 0.45);
  box-shadow: 0 16px 38px -10px rgba(20, 152, 213, 0.25);
  /* Welle 5.27 v28: translateY(-6px) ENTFERNT damit Pro + Premium auf
     gleicher Y-Achse sitzen (Hairlines + Banner aligned). Featured bleibt
     dominant durch Border + Glow + Badge — Elevation nicht mehr nötig. */
}
body.is-dark-bg .wd-tier--featured {
  border-color: rgba(62, 182, 240, 0.55);
  box-shadow: 0 16px 38px -10px rgba(62, 182, 240, 0.3);
}

.wd-tier-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  padding: 0.35rem 0.9rem;
  background: linear-gradient(135deg, #1498D5 0%, #0F7BB2 100%);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 999px;
  box-shadow: 0 6px 16px -4px rgba(20, 152, 213, 0.42);
}

.wd-tier-head {
  margin-bottom: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid rgba(20, 152, 213, 0.12);
  /* Welle 5.27 v26: min-height damit Hairline + Build-up-Banner auf gleicher
     Y-Achse über alle 3 Cards sitzen — Linear/Apple-Standard. Premium hat
     kürzeren Header (kein Period + kein Annual-Note), kriegt jetzt
     Pseudo-Whitespace-Buffer durch min-height.
     v27: 8.5rem → 10.5rem (gemessen: Business/Pro = 162px, Premium = 136px). */
  min-height: 10.5rem;
}
@media (max-width: 767px) {
  /* Mobile: Cards stacken, min-height nicht nötig */
  .wd-tier-head { min-height: 0; }
}
body.is-dark-bg .wd-tier-head { border-bottom-color: rgba(62, 182, 240, 0.15); }

.wd-tier-name {
  font-size: 1.4rem;
  font-weight: 700;
  color: #0A1B33;
  margin: 0 0 0.85rem;
  letter-spacing: -0.015em;
}
body.is-dark-bg .wd-tier-name { color: #F0F4FA; }

.wd-tier-price {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.wd-tier-amount {
  font-size: clamp(1.85rem, 4.5vw, 2.4rem);
  font-weight: 800;
  color: #1498D5;
  letter-spacing: -0.025em;
  line-height: 1;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
}
body.is-dark-bg .wd-tier-amount { color: #3EB6F0; }
.wd-tier--featured .wd-tier-amount { color: #0F7BB2; }
body.is-dark-bg .wd-tier--featured .wd-tier-amount { color: #5DC4F4; }

.wd-tier-period,
.wd-tier-tagline,
.wd-tier-annual {
  font-size: 0.85rem;
  color: rgba(10, 27, 51, 0.6);
  margin: 0.35rem 0 0;
  line-height: 1.4;
}
.wd-tier-annual {
  font-weight: 600;
  color: #FF7A4D;
}
body.is-dark-bg .wd-tier-period,
body.is-dark-bg .wd-tier-tagline { color: rgba(240, 244, 250, 0.6); }
body.is-dark-bg .wd-tier-annual { color: #FF9466; }

/* Welle 5.27 v24: Tier-Buildup-Label ("Everything in X, plus:") — Stripe-Pattern */
.wd-tier-buildup {
  margin: 0 0 0.9rem;
  padding: 0.55rem 0.85rem;
  background: rgba(20, 152, 213, 0.08);
  border-left: 3px solid #1498D5;
  border-radius: 6px;
  font-size: 0.82rem;
  font-weight: 600;
  color: #0F7BB2;
  line-height: 1.3;
}
body.is-dark-bg .wd-tier-buildup {
  background: rgba(62, 182, 240, 0.12);
  border-left-color: #3EB6F0;
  color: #5DC4F4;
}

.wd-tier-features {
  list-style: none;
  margin: 0 0 1.25rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  flex: 1;
}
.wd-tier-features li {
  position: relative;
  padding-left: 1.4rem;
  font-size: 0.92rem;
  color: rgba(10, 27, 51, 0.78);
  line-height: 1.5;
}
.wd-tier-features li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: #1498D5;
  font-weight: 700;
}
.wd-tier-features li strong {
  color: #0A1B33;
  font-weight: 700;
}
body.is-dark-bg .wd-tier-features li { color: rgba(240, 244, 250, 0.78); }
body.is-dark-bg .wd-tier-features li strong { color: #F0F4FA; }
body.is-dark-bg .wd-tier-features li::before { color: #3EB6F0; }

.wd-tier-note {
  font-size: 0.78rem;
  color: rgba(10, 27, 51, 0.55);
  line-height: 1.55;
  margin: 0 0 1rem;
}
body.is-dark-bg .wd-tier-note { color: rgba(240, 244, 250, 0.6); }
.wd-tier-note strong { color: #0A1B33; font-weight: 700; }
body.is-dark-bg .wd-tier-note strong { color: #F0F4FA; }

.wd-tier-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.4rem;
  font-size: 0.92rem;
  font-weight: 600;
  background: transparent;
  border: 1.5px solid rgba(20, 152, 213, 0.4);
  border-radius: 999px;
  color: #1498D5;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.wd-tier-cta:hover {
  background: rgba(20, 152, 213, 0.08);
  border-color: rgba(20, 152, 213, 0.7);
}
.wd-tier-cta--primary {
  background: linear-gradient(135deg, #1498D5 0%, #0F7BB2 100%);
  color: #fff;
  border-color: transparent;
  box-shadow: 0 8px 22px -6px rgba(20, 152, 213, 0.4);
}
.wd-tier-cta--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -6px rgba(20, 152, 213, 0.5);
  background: linear-gradient(135deg, #3EB6F0 0%, #1498D5 100%);
}
body.is-dark-bg .wd-tier-cta { color: #3EB6F0; border-color: rgba(62, 182, 240, 0.45); }
body.is-dark-bg .wd-tier-cta:hover { background: rgba(62, 182, 240, 0.12); }

.wd-pricing-foot {
  margin: 2rem auto 0;
  max-width: 720px;
  text-align: center;
  font-size: 0.82rem;
  color: rgba(10, 27, 51, 0.55);
  line-height: 1.55;
}
body.is-dark-bg .wd-pricing-foot { color: rgba(240, 244, 250, 0.6); }

/* ═══════════════════════════════════════════════════════════════════════════
   4. RELATED SERVICE (Booking-System) — Side-by-Side Editorial Card
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-related-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  padding: clamp(1.75rem, 4vw, 3rem);
  background: linear-gradient(135deg, rgba(255, 122, 77, 0.06) 0%, rgba(20, 152, 213, 0.04) 100%);
  border: 1px solid rgba(255, 122, 77, 0.18);
  border-radius: 24px;
  overflow: hidden;
}
body.is-dark-bg .wd-related-card {
  background: linear-gradient(135deg, rgba(255, 148, 102, 0.08) 0%, rgba(62, 182, 240, 0.06) 100%);
  border-color: rgba(255, 148, 102, 0.22);
}
@media (min-width: 768px) {
  .wd-related-card { grid-template-columns: 1.1fr 0.9fr; }
}

.wd-related-eyebrow {
  display: inline-block;
  padding: 0.3rem 0.7rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #FF7A4D;
  background: rgba(255, 122, 77, 0.12);
  border-radius: 999px;
  margin-bottom: 1rem;
}
body.is-dark-bg .wd-related-eyebrow {
  color: #FF9466;
  background: rgba(255, 148, 102, 0.16);
}

.wd-related-title {
  font-size: clamp(1.45rem, 3.5vw, 2rem);
  font-weight: 800;
  color: #0A1B33;
  line-height: 1.2;
  margin: 0 0 0.75rem;
  letter-spacing: -0.02em;
}
body.is-dark-bg .wd-related-title { color: #F0F4FA; }

.wd-related-sub {
  font-size: 0.98rem;
  color: rgba(10, 27, 51, 0.7);
  line-height: 1.6;
  margin: 0 0 1.25rem;
}
body.is-dark-bg .wd-related-sub { color: rgba(240, 244, 250, 0.72); }

.wd-related-bullets {
  list-style: none;
  margin: 0 0 1.5rem;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.wd-related-bullets li {
  position: relative;
  padding-left: 1.5rem;
  font-size: 0.92rem;
  color: rgba(10, 27, 51, 0.78);
  line-height: 1.5;
}
.wd-related-bullets li::before {
  content: '→';
  position: absolute;
  left: 0;
  color: #FF7A4D;
  font-weight: 700;
}
body.is-dark-bg .wd-related-bullets li { color: rgba(240, 244, 250, 0.78); }
body.is-dark-bg .wd-related-bullets li::before { color: #FF9466; }

.wd-related-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.4rem;
  font-size: 0.95rem;
  font-weight: 600;
  background: linear-gradient(135deg, #FF7A4D 0%, #E55F32 100%);
  color: #fff;
  border-radius: 999px;
  text-decoration: none;
  box-shadow: 0 8px 22px -6px rgba(255, 122, 77, 0.4);
  transition: transform 0.2s, box-shadow 0.2s;
}
.wd-related-cta:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 32px -6px rgba(255, 122, 77, 0.5);
}

.wd-related-hint {
  font-size: 0.78rem;
  color: rgba(10, 27, 51, 0.55);
  margin: 1rem 0 0;
}
body.is-dark-bg .wd-related-hint { color: rgba(240, 244, 250, 0.55); }

/* Mini Booking-Mock Visual */
.wd-related-visual {
  display: flex;
  align-items: center;
  justify-content: center;
}
.wd-related-mock {
  width: 100%;
  max-width: 360px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 20px 44px -12px rgba(10, 27, 51, 0.18);
  overflow: hidden;
  font-size: 0.85rem;
}
body.is-dark-bg .wd-related-mock {
  background: #1A2940;
  box-shadow: 0 20px 44px -12px rgba(0, 0, 0, 0.5);
}

.wd-related-mock-head {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 0.85rem;
  background: rgba(20, 152, 213, 0.04);
  border-bottom: 1px solid rgba(20, 152, 213, 0.1);
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(10, 27, 51, 0.7);
}
body.is-dark-bg .wd-related-mock-head {
  background: rgba(62, 182, 240, 0.08);
  border-bottom-color: rgba(62, 182, 240, 0.15);
  color: rgba(240, 244, 250, 0.78);
}
.wd-related-mock-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
}
.wd-related-mock-dot--r { background: #ff6b6b; }
.wd-related-mock-dot--y { background: #ffd93d; }
.wd-related-mock-dot--g { background: #6bcf7f; }
.wd-related-mock-title { margin-left: auto; }

.wd-related-mock-list {
  list-style: none;
  margin: 0;
  padding: 0.5rem 0;
}
.wd-related-mock-list li {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.65rem 0.85rem;
  border-bottom: 1px solid rgba(20, 152, 213, 0.06);
  color: rgba(10, 27, 51, 0.8);
}
.wd-related-mock-list li:last-child { border-bottom: none; }
body.is-dark-bg .wd-related-mock-list li {
  border-bottom-color: rgba(62, 182, 240, 0.08);
  color: rgba(240, 244, 250, 0.82);
}
.wd-related-mock-time {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 0.78rem;
  font-weight: 700;
  color: #1498D5;
  flex: 0 0 48px;
}
body.is-dark-bg .wd-related-mock-time { color: #3EB6F0; }
.wd-related-mock-list li > span:nth-child(2) {
  flex: 1;
  font-size: 0.85rem;
}
.wd-related-mock-check {
  color: #06C755;
  font-weight: 700;
  font-size: 0.95rem;
}
.wd-related-mock-new {
  background: rgba(255, 122, 77, 0.08);
  font-weight: 600;
}
.wd-related-mock-new .wd-related-mock-time { color: #FF7A4D; }
.wd-related-mock-pulse {
  width: 8px; height: 8px;
  background: #FF7A4D;
  border-radius: 50%;
  box-shadow: 0 0 0 0 rgba(255, 122, 77, 0.6);
  animation: wd-mock-pulse 1.5s ease-in-out infinite;
}
@keyframes wd-mock-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255, 122, 77, 0.6); }
  50%      { box-shadow: 0 0 0 8px rgba(255, 122, 77, 0); }
}

/* ═══════════════════════════════════════════════════════════════════════════
   5. PROZESS — recycelt process-section-v2.css, hier nur Wrapper-Spacing
   ═══════════════════════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════════════════════
   5. PROZESS — Welle 5.27 v33: Polish ÜBERTRAGEN zu process-section-v2.css
   (unscoped, greift jetzt page-wide auf Startseite + Webdesign-Page).
   Brand-Konsistenz, 1 Komponente statt 2 Varianten.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════
   6. REFERENZEN — 2-Card Grid mit Live-Badge
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-ref-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(1rem, 2.5vw, 2rem);
}
@media (min-width: 768px) {
  .wd-ref-grid { grid-template-columns: repeat(2, 1fr); }
}

.wd-ref-card {
  display: block;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(20, 152, 213, 0.15);
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s, box-shadow 0.3s, border-color 0.3s;
}
.wd-ref-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 44px -12px rgba(10, 27, 51, 0.18);
  border-color: rgba(20, 152, 213, 0.35);
}
body.is-dark-bg .wd-ref-card {
  background: rgba(26, 41, 64, 0.55);
  border-color: rgba(62, 182, 240, 0.18);
}

.wd-ref-card-frame {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(20, 152, 213, 0.08), rgba(255, 122, 77, 0.06));
}
.wd-ref-card-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform 0.6s;
}
.wd-ref-card:hover .wd-ref-card-frame img {
  transform: scale(1.04);
}

.wd-ref-card-meta {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  padding: 1.25rem 1.5rem 1.5rem;
  position: relative;
}
.wd-ref-card-branch {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #1498D5;
}
body.is-dark-bg .wd-ref-card-branch { color: #3EB6F0; }
.wd-ref-card-name {
  font-size: 1.15rem;
  font-weight: 700;
  color: #0A1B33;
  margin: 0;
  letter-spacing: -0.015em;
}
body.is-dark-bg .wd-ref-card-name { color: #F0F4FA; }
.wd-ref-card-badge {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  padding: 0.3rem 0.7rem;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  border-radius: 999px;
  white-space: nowrap;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  /* Default fallback (für alte Cards ohne Variant-Klasse) */
  background: rgba(6, 199, 85, 0.12);
  color: #06A346;
}
/* Live Customer — Green (LINE-Brand-Hint) */
.wd-ref-card-badge--live {
  background: rgba(6, 199, 85, 0.15);
  color: #06A346;
  box-shadow: inset 0 0 0 1px rgba(6, 199, 85, 0.25);
}
body.is-dark-bg .wd-ref-card-badge--live {
  background: rgba(6, 199, 85, 0.18);
  color: #4DDB8A;
  box-shadow: inset 0 0 0 1px rgba(6, 199, 85, 0.35);
}
/* Design Showcase — Brand-Blue */
.wd-ref-card-badge--showcase {
  background: rgba(20, 152, 213, 0.14);
  color: #0F7BB2;
  box-shadow: inset 0 0 0 1px rgba(20, 152, 213, 0.30);
}
body.is-dark-bg .wd-ref-card-badge--showcase {
  background: rgba(20, 152, 213, 0.20);
  color: #5DC4F4;
  box-shadow: inset 0 0 0 1px rgba(62, 182, 240, 0.40);
}

.wd-ref-cta-row {
  margin-top: clamp(2rem, 4vw, 3rem);
  text-align: center;
}
/* CTA-Button selbst nutzt globale .btn .btn-primary (Startseite-Konsistenz):
   Cyan-Gradient + Glow + Shimmer-Animation. Siehe _shared/css/style.css. */

/* ═══════════════════════════════════════════════════════════════════════════
   7. FAQ — Native <details>/<summary>, custom-styled
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-faq {
  background: linear-gradient(180deg, transparent 0%, rgba(20, 152, 213, 0.02) 100%);
}

.wd-faq-list {
  max-width: 840px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.wd-faq-item {
  background: rgba(255, 255, 255, 0.65);
  border: 1px solid rgba(20, 152, 213, 0.12);
  border-radius: 14px;
  padding: 0;
  transition: border-color 0.25s, background 0.25s;
}
.wd-faq-item:hover { border-color: rgba(20, 152, 213, 0.28); }
.wd-faq-item[open] {
  background: rgba(255, 255, 255, 0.85);
  border-color: rgba(20, 152, 213, 0.35);
}
body.is-dark-bg .wd-faq-item {
  background: rgba(26, 41, 64, 0.5);
  border-color: rgba(62, 182, 240, 0.15);
}
body.is-dark-bg .wd-faq-item[open] {
  background: rgba(26, 41, 64, 0.75);
  border-color: rgba(62, 182, 240, 0.4);
}

.wd-faq-item--highlight {
  border-color: rgba(255, 122, 77, 0.32);
  background: linear-gradient(135deg, rgba(255, 122, 77, 0.05), rgba(255, 255, 255, 0.65));
}
.wd-faq-item--highlight[open] {
  border-color: rgba(255, 122, 77, 0.55);
}
body.is-dark-bg .wd-faq-item--highlight {
  border-color: rgba(255, 148, 102, 0.38);
  background: linear-gradient(135deg, rgba(255, 148, 102, 0.08), rgba(26, 41, 64, 0.5));
}

.wd-faq-item summary {
  cursor: pointer;
  padding: 1.1rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  color: #0A1B33;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  transition: color 0.2s;
}
.wd-faq-item summary::-webkit-details-marker { display: none; }
.wd-faq-item summary::after {
  content: '+';
  font-size: 1.4rem;
  font-weight: 400;
  color: #1498D5;
  flex-shrink: 0;
  transition: transform 0.3s;
}
.wd-faq-item[open] summary::after {
  transform: rotate(45deg);
}
body.is-dark-bg .wd-faq-item summary { color: #F0F4FA; }
body.is-dark-bg .wd-faq-item summary::after { color: #3EB6F0; }

.wd-faq-item p {
  padding: 0 1.5rem 1.25rem;
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.65;
  color: rgba(10, 27, 51, 0.72);
}
body.is-dark-bg .wd-faq-item p { color: rgba(240, 244, 250, 0.75); }

/* ═══════════════════════════════════════════════════════════════════════════
   8. FINAL CTA — LINE-First Band
   ═══════════════════════════════════════════════════════════════════════════ */
.wd-cta { padding-bottom: clamp(5rem, 10vw, 8rem); }

.wd-cta-band {
  padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem);
  background: linear-gradient(135deg, #1498D5 0%, #0F7BB2 50%, #0A1B33 100%);
  border-radius: 28px;
  color: #fff;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.wd-cta-band::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 40% at 80% 20%, rgba(255, 122, 77, 0.25), transparent 60%),
    radial-gradient(ellipse 40% 60% at 10% 80%, rgba(62, 182, 240, 0.2), transparent 65%);
  pointer-events: none;
}

.wd-cta-eyebrow {
  position: relative;
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.75);
  margin-bottom: 0.85rem;
}

.wd-cta-title {
  position: relative;
  font-size: clamp(1.8rem, 4.5vw, 2.6rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: #fff;
  margin: 0 0 0.85rem;
  text-wrap: balance;
}
.wd-cta-sub {
  position: relative;
  font-size: 1.02rem;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.82);
  margin: 0 auto 2rem;
  max-width: 56ch;
}

.wd-cta-buttons {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  justify-content: center;
}

.wd-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  padding: 1rem 1.6rem;
  font-size: 1rem;
  font-weight: 600;
  border-radius: 999px;
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}
.wd-cta-btn--line {
  background: #06C755;
  color: #fff;
  box-shadow: 0 10px 28px -6px rgba(6, 199, 85, 0.5);
}
.wd-cta-btn--line:hover {
  transform: translateY(-2px);
  background: #05B14A;
  box-shadow: 0 16px 38px -6px rgba(6, 199, 85, 0.6);
}
.wd-cta-btn--secondary {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
  border: 1.5px solid rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(20px);
}
.wd-cta-btn--secondary:hover {
  background: rgba(255, 255, 255, 0.18);
  border-color: rgba(255, 255, 255, 0.5);
  transform: translateY(-2px);
}

/* ─── Reduced-Motion ────────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .wd-tier, .wd-ref-card, .wd-faq-item, .wd-cta-btn, .wd-tier-cta, .wd-hero-cta, .wd-related-cta {
    transition: none;
  }
  .wd-related-mock-pulse { animation: none; }
}

/* ============================================================================
   WdForGood — "For-Good" Section (Pro-bono Webdesign für gemeinnützige Projekte)
   ----------------------------------------------------------------------------
   2-col Desktop (Text-Block links, DonationForChildren-Case-Tile rechts),
   1-col Mobile-Stack. Bewusst klein + faktisch, kein "Impact"-Pathos.
   ============================================================================ */
.wd-for-good {
  padding: clamp(3.5rem, 8vw, 6rem) 0;
  /* Transparent damit Section den Page-bg übernimmt (light + dark) — vermeidet
     den sichtbaren Color-Cut zu den anderen .wd-* Sections die alle transparent sind. */
  background: transparent;
  position: relative;
}

.wd-for-good-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: start;
}
@media (min-width: 880px) {
  .wd-for-good-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 3.5rem;
    align-items: center;
  }
}

.wd-for-good-text {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.wd-for-good-header {
  margin: 0;
  max-width: none;
}
.wd-for-good-title {
  font-size: clamp(1.7rem, 5vw, 2.4rem);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.025em;
  color: var(--wd-ink, #0A1B33);
  margin: 0.4rem 0 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.1em;
}
body.is-dark-bg .wd-for-good-title {
  color: #F0F4FA;
}
.wd-for-good-title-line {
  display: block;
}
.wd-for-good-title-line--accent {
  color: #1498D5;
}
body.is-dark-bg .wd-for-good-title-line--accent {
  color: #3EB6F0;
}

.wd-for-good-sub {
  font-size: 1.05rem;
  font-weight: 600;
  color: #0A1B33;
  letter-spacing: -0.005em;
  margin: 0;
}
body.is-dark-bg .wd-for-good-sub {
  color: rgba(240, 244, 250, 0.92);
}

.wd-for-good-body {
  font-size: 0.96rem;
  line-height: 1.65;
  color: rgba(10, 27, 51, 0.70);
  max-width: 48ch;
  margin: 0;
}
body.is-dark-bg .wd-for-good-body {
  color: rgba(240, 244, 250, 0.70);
}

.wd-for-good-cta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 0.5rem;
}
.wd-for-good-cta-hint {
  font-size: 0.82rem;
  color: rgba(10, 27, 51, 0.55);
  font-weight: 500;
}
body.is-dark-bg .wd-for-good-cta-hint {
  color: rgba(240, 244, 250, 0.55);
}

.wd-for-good-case {
  width: 100%;
}
.wd-for-good-case-link {
  display: flex;
  flex-direction: column;
  background: #ffffff;
  border: 1px solid rgba(10, 27, 51, 0.08);
  border-radius: 16px;
  overflow: hidden;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
body.is-dark-bg .wd-for-good-case-link {
  background: #15233a;
  border-color: rgba(240, 244, 250, 0.10);
}
.wd-for-good-case-link:hover {
  transform: translateY(-3px);
  border-color: rgba(20, 152, 213, 0.35);
  box-shadow:
    0 12px 28px -8px rgba(10, 27, 51, 0.14),
    0 24px 56px -16px rgba(20, 152, 213, 0.18);
}
body.is-dark-bg .wd-for-good-case-link:hover {
  box-shadow: 0 12px 28px -8px rgba(0, 0, 0, 0.45);
}

.wd-for-good-case-photo {
  position: relative;
  width: 100%;
  /* Aspect ~1.62 — passt zum gecroppten Donation-Hero-Screenshot (800×494) */
  aspect-ratio: 800 / 494;
  overflow: hidden;
  background: linear-gradient(135deg, #f5e6d3 0%, #d4a574 100%);
}
.wd-for-good-case-photo img {
  /* contain statt cover damit nichts wegcropped wird, falls Container-Aspect minimal abweicht */
  object-fit: contain;
}
.wd-for-good-case-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.wd-for-good-case-body {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 1.3rem 1.4rem 1.4rem;
}
.wd-for-good-case-label {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: #1498D5;
}
body.is-dark-bg .wd-for-good-case-label {
  color: #3EB6F0;
}
.wd-for-good-case-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: -0.015em;
  color: #0A1B33;
  margin: 0;
}
body.is-dark-bg .wd-for-good-case-title {
  color: #F0F4FA;
}
.wd-for-good-case-logo {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.wd-for-good-case-desc {
  font-size: 0.88rem;
  line-height: 1.55;
  color: rgba(10, 27, 51, 0.65);
  margin: 0;
}
body.is-dark-bg .wd-for-good-case-desc {
  color: rgba(240, 244, 250, 0.65);
}
.wd-for-good-case-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.4rem;
  font-size: 0.85rem;
  font-weight: 700;
  color: #1498D5;
  transition: color 0.15s ease;
}
.wd-for-good-case-link:hover .wd-for-good-case-cta {
  color: #0F7BB2;
}
body.is-dark-bg .wd-for-good-case-cta {
  color: #3EB6F0;
}
