/* ============================================================
   CoLe's Heart — so-koennen-sie-helfen.css
   Seite „So können Sie helfen" (Page 104) — Version B (Editorial).
   Intro · 3 alternierende Bild|Text-Reihen (3 Wege) · „Wofür Ihre
   Spende wirkt" (5 Pills + Trust) · CTA-Band (.mag-donate-Reuse).
   Neuer Standard: 2 Schriften, flache Hintergründe, eckige Bilder.
   Icons als Inline-SVG (Theme lädt FA nur als Sprite).
   ============================================================ */

.hf-container { width: 100%; max-width: 1180px; margin-inline: auto; padding-inline: 40px; box-sizing: border-box; }
.hf-kicker { font-family: var(--ch-font-body); font-weight: 700; font-size: 13px; letter-spacing: .16em; text-transform: uppercase; color: var(--ch-gold-600); display: block; margin-bottom: 14px; }

/* ===================== Intro ===================== */
.hf-intro { background: var(--ch-cream); padding-block: 80px 8px; text-align: center; }
.hf-intro__inner { max-width: 800px; margin-inline: auto; }
.hf-h1 { font-family: var(--ch-font-display) !important; font-weight: 600 !important; font-size: clamp(40px, 5.2vw, 66px); line-height: 1.03; letter-spacing: -0.015em; color: var(--ch-ink); margin: 0; text-wrap: balance; }
.hf-h1 em { font-style: italic; color: var(--ch-gold-500); }
.hf-lead { font-size: 20px; line-height: 1.6; color: var(--ch-ink-soft); margin: 20px auto 0; max-width: 640px; }

/* ===================== 3 Wege (Editorial) ===================== */
.hf-ways { background: var(--ch-cream); }
.hb-row { background: var(--ch-cream); }
.hb-row > .row_inner { display: grid !important; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; max-width: 1180px; margin-inline: auto; padding: 60px 40px; }
.hb-row > .row_inner > .module_column { width: auto !important; float: none !important; margin: 0 !important; }
.hb-row + .hb-row > .row_inner { border-top: 1px solid var(--ch-line); }
/* gespiegelte Reihe (Punkt 02): Bild rechts, Text links — explizite Spaltenplatzierung */
.hb-row--rev .hb-row__media { grid-column: 2; order: 2; }
.hb-row--rev .hb-row__body  { grid-column: 1; order: 1; }

.hb-row__media { position: relative; }
.hb-row__media .module-image { position: relative; margin: 0; }
.hb-row__media .module-image img { display: block; width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 0 !important; position: relative; z-index: 1; }
.hb-row__media .module-image::after { content: ""; position: absolute; z-index: 0; width: 120px; height: 120px; right: -22px; bottom: -22px; background-image: radial-gradient(var(--ch-gold-400) 2.2px, transparent 2.2px); background-size: 17px 17px; opacity: .5; }
.hb-row--rev .hb-row__media .module-image::after { right: auto; left: -22px; }

.hb-row__head { display: flex; align-items: center; gap: 18px; margin-bottom: 16px; }
.hb-row__num { font-family: var(--ch-font-display); font-style: italic; font-size: 40px; line-height: 1; color: var(--ch-gold-400); }
.hb-row__head .ch-icon-bubble { width: 72px; height: 72px; display: inline-flex !important; align-items: center; justify-content: center; }
.hb-row__head .ch-icon-bubble svg { width: 34px; height: 34px; }
.hb-row__title { font-family: var(--ch-font-display) !important; font-weight: 600; font-size: clamp(30px, 3.2vw, 42px); line-height: 1.05; color: var(--ch-ink); margin: 0 0 14px; }
.hb-row__text { font-size: 17.5px; line-height: 1.72; color: var(--ch-ink-soft); margin: 0 0 24px; max-width: 540px; }
.hb-row__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.hb-row__actions .ch-btn svg { width: 17px; height: 17px; flex: none; }

/* ===================== Wofür Ihre Spende wirkt ===================== */
.hf-impact { background: var(--ch-cream-deep); padding-block: 76px; }
.hf-impact__inner { max-width: 980px; margin-inline: auto; text-align: center; }
.hf-impact__lead { font-size: 18px; line-height: 1.7; color: var(--ch-ink-soft); margin: 16px auto 36px; max-width: 660px; }
.hf-impact__grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; }
.hf-pill { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.hf-pill .ch-icon-bubble { width: 104px; height: 104px; background: var(--ch-gold-50); color: var(--ch-gold-500); display: inline-flex !important; align-items: center; justify-content: center; }
.hf-pill .ch-icon-bubble svg { width: 50px; height: 50px; }
.hf-pill__t { font-family: var(--ch-font-display); font-weight: 600; font-size: 21px; line-height: 1.18; color: var(--ch-ink); }
.hf-trust { display: flex; justify-content: center; gap: 28px; flex-wrap: wrap; margin-top: 40px; }
.hf-trust__item { display: inline-flex; align-items: center; gap: 9px; font-size: 15px; color: var(--ch-ink-soft); }
.hf-trust__item svg { width: 18px; height: 18px; color: var(--ch-gold-500); flex: none; }

/* ===================== Responsive ===================== */
@media (max-width: 920px) {
  .hb-row > .row_inner { grid-template-columns: 1fr; gap: 26px; padding: 40px 24px; }
  .hb-row--rev .hb-row__media { grid-column: auto; order: 0; }
  .hb-row--rev .hb-row__body { grid-column: auto; order: 0; }
  .hb-row__media { max-width: 520px; }
  .hb-row__media .module-image::after { display: none; }
  .hf-impact__grid { grid-template-columns: repeat(2, 1fr); }
  .hf-container { padding-inline: 24px; }
}
@media (max-width: 560px) {
  .hf-impact__grid { grid-template-columns: 1fr; }
}
