/* ==========================================================================
   FiftyPlus — Redefine campaign landing page
   Page-specific components. Loads ON TOP of home.css, reusing the same
   striped band system (.band-*), buttons (.fp-btn), eyebrow, .fp-h2,
   .fp-chip, .fp-container, etc. Everything scoped under .fp-home.
   ========================================================================== */

/* ── Minimal nav (focused funnel — logo + single CTA) ──────────────────── */
.fp-home { --rd-nav-h: 76px; }
.fp-home .rd-nav__inner { justify-content: space-between; }

/* Merged top bar: transparent over the dark hero, solidifies on scroll ── */
.fp-home .rd-nav.fp-nav { background: transparent; backdrop-filter: none; -webkit-backdrop-filter: none; box-shadow: none; }
.fp-home .rd-nav.fp-nav .fp-nav__logo img { filter: brightness(0) invert(1); transition: filter var(--fp-dur-normal) var(--fp-ease); }
.fp-home .rd-nav.fp-nav[data-scrolled="true"] {
  background: rgba(251,249,248,0.85); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 2px 18px rgba(27,28,28,0.08);
}
.fp-home .rd-nav.fp-nav[data-scrolled="true"] .fp-nav__logo img { filter: none !important; }

/* Solid top bar variant (Tweak: Top bar = solid) ── */
.fp-home[data-header="solid"] .rd-nav.fp-nav {
  background: rgba(251,249,248,0.85); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
}
.fp-home[data-header="solid"] .rd-nav.fp-nav .fp-nav__logo img { filter: none !important; }
.fp-home[data-header="solid"] .rd-hero { margin-top: 0; padding-top: clamp(56px, 7vw, 92px); }

/* ── Hero (dark, two-column) — pulled up under the merged top bar ───────── */
.rd-hero {
  margin-top: calc(-1 * var(--rd-nav-h));
  padding-top: calc(var(--rd-nav-h) + clamp(40px, 6vw, 78px));
  padding-bottom: clamp(56px, 7vw, 88px);
  text-align: left;
}
.rd-hero__grid {
  display: grid; grid-template-columns: 1.04fr 0.96fr; gap: 56px; align-items: center;
}
.rd-hero__eyebrow {
  font-family: var(--fp-font-heading); font-size: 0.9rem; font-weight: 700;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--fp-lime); margin: 0 0 20px;
}
.rd-hero__title {
  margin: 0; font-family: var(--fp-font-heading);
  font-size: clamp(40px, 5.2vw, 66px); font-weight: 700; line-height: 1.05;
  letter-spacing: -0.025em; color: #fff; max-width: 13ch; text-wrap: balance;
}
.rd-hero__title .mark {
  background: linear-gradient(180deg, transparent 56%, var(--fp-lime) 56%);
  color: #fff; padding: 0 0.06em; border-radius: 2px;
}
.rd-hero__sub { margin: 24px 0 34px; max-width: 480px; font-size: clamp(18px, 2vw, 21px); line-height: 1.6; color: rgba(255,255,255,0.86); }
.rd-hero__cta { display: flex; flex-direction: column; align-items: flex-start; gap: 14px; }
.rd-hero__media {
  position: relative; aspect-ratio: 4 / 5; border-radius: var(--fp-radius-xl);
  background:
    radial-gradient(120% 90% at 50% 12%, rgba(185,251,159,0.16) 0%, transparent 55%),
    linear-gradient(160deg, #356455 0%, #244639 100%);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 30px 70px rgba(20,44,36,0.4);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px;
  color: rgba(255,255,255,0.5);
}
.rd-hero__media svg { width: 52px; height: 52px; }
.rd-hero__media span { font-family: var(--fp-font-heading); font-size: 15px; font-weight: 600; letter-spacing: 0.04em; }

.rd-reassure { margin: 0; font-size: 15.5px; color: rgba(255,255,255,0.62); }
.band-light .rd-reassure, .band-alt .rd-reassure { color: var(--fp-fg-3); }

/* Trust stats row across foot of hero — even rhythm, hairline dividers ── */
.rd-stats {
  margin-top: clamp(52px, 7vw, 84px);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  padding-top: clamp(30px, 4vw, 44px);
  border-top: 1px solid rgba(255,255,255,0.16);
}
.rd-stat { position: relative; text-align: center; padding: 4px clamp(12px, 2vw, 28px); }
.rd-stat + .rd-stat::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 1px; height: 46px; background: rgba(255,255,255,0.16);
}
.rd-stat__value {
  font-family: var(--fp-font-heading); font-size: clamp(22px, 2.6vw, 30px); font-weight: 700;
  color: var(--fp-lime); line-height: 1.1; display: inline-flex; align-items: center; gap: 7px; justify-content: center;
}
.rd-stat__value svg { width: 22px; height: 22px; }
.rd-stat__label { margin: 10px 0 0; font-size: 15px; color: rgba(255,255,255,0.78); line-height: 1.3; }

/* ── VSL (light) ───────────────────────────────────────────────────────── */
.rd-vsl-card {
  max-width: 880px; margin: 44px auto 0; background: var(--fp-surface-lowest);
  border-radius: var(--fp-radius-xl); padding: 14px; box-shadow: var(--fp-shadow-elevated);
}
.rd-vsl-poster {
  position: relative; aspect-ratio: 16 / 9; border-radius: var(--fp-radius-lg); overflow: hidden;
  background: radial-gradient(120% 120% at 50% 32%, rgba(74,138,119,0.6) 0%, rgba(42,82,70,0.95) 70%);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 18px; text-align: center; padding: 2rem;
}
.rd-vsl-play {
  width: 92px; height: 92px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--fp-lime); color: var(--fp-green-dark);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 14px rgba(185,251,159,0.16);
  transition: transform var(--fp-dur-normal) var(--fp-ease);
}
.rd-vsl-play:hover { transform: scale(1.05); }
.rd-vsl-play svg { width: 34px; height: 34px; margin-left: 4px; }
.rd-vsl-label { margin: 0; color: #fff; font-family: var(--fp-font-heading); font-weight: 600; font-size: 19px; }
.rd-vsl-hint { margin: 0; color: rgba(255,255,255,0.62); font-size: 14.5px; max-width: 24rem; }

/* ── Pain cards (dark) ─────────────────────────────────────────────────── */
.rd-pain-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 52px; }
.rd-pain-card {
  display: flex; align-items: center; gap: 20px;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--fp-radius-lg); padding: 24px 28px;
  transition: background var(--fp-dur-normal) var(--fp-ease), transform var(--fp-dur-normal) var(--fp-ease);
}
.rd-pain-card:hover { background: rgba(255,255,255,0.11); transform: translateY(-3px); }
.rd-pain-card__icon {
  flex-shrink: 0; width: 56px; height: 56px; border-radius: 16px;
  background: rgba(185,251,159,0.16); color: var(--fp-lime);
  display: inline-flex; align-items: center; justify-content: center;
}
.rd-pain-card__icon svg { width: 28px; height: 28px; }
.rd-pain-card__text { margin: 0; font-family: var(--fp-font-heading); font-size: 18px; font-weight: 600; color: #fff; line-height: 1.35; }
.rd-pain-statement {
  margin: 48px auto 0; max-width: 760px; text-align: center;
  font-family: var(--fp-font-heading); font-size: clamp(22px, 3vw, 32px); font-weight: 700;
  color: #fff; line-height: 1.35;
}
.rd-pain-statement .mark { color: var(--fp-lime); }

/* ── What's possible (light) ───────────────────────────────────────────── */
.rd-poss-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; margin-top: 48px; }
.rd-poss-item { display: flex; align-items: flex-start; gap: 18px; background: var(--fp-surface-lowest); border-radius: var(--fp-radius-lg); padding: 26px 28px; box-shadow: var(--fp-shadow-subtle); }
.rd-poss-item__icon {
  flex-shrink: 0; width: 48px; height: 48px; border-radius: 14px;
  background: rgba(58,108,93,0.10); color: var(--fp-primary);
  display: inline-flex; align-items: center; justify-content: center;
}
.rd-poss-item__icon svg { width: 24px; height: 24px; }
.rd-poss-item__label { font-family: var(--fp-font-heading); font-size: 14px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fp-primary); margin: 4px 0 8px; }
.rd-poss-item__result { font-size: 17.5px; line-height: 1.5; color: var(--fp-fg-1); margin: 0; }
.rd-poss-close { margin: 52px auto 0; max-width: 760px; text-align: center; }
.rd-poss-specialist {
  margin: 0; font-family: var(--fp-font-heading); font-size: clamp(22px, 2.8vw, 30px); font-weight: 700;
  color: var(--fp-fg-1); line-height: 1.35;
}
.rd-poss-specialist .mark { background: var(--fp-lime); color: var(--fp-green-dark); padding: 0 0.22em; border-radius: 6px; }
.rd-poss-secret { margin: 14px auto 0; max-width: 560px; font-size: 18px; font-weight: 600; color: var(--fp-primary); }

/* ── Pillars (dark, numbered) ──────────────────────────────────────────── */
.rd-pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 52px; }
.rd-pillar { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--fp-radius-lg); padding: 34px 30px; transition: background var(--fp-dur-normal) var(--fp-ease), transform var(--fp-dur-normal) var(--fp-ease); }
.rd-pillar:hover { background: rgba(255,255,255,0.11); transform: translateY(-4px); }
.rd-pillar__num {
  width: 52px; height: 52px; border-radius: 50%; background: var(--fp-lime); color: var(--fp-green-dark);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--fp-font-heading); font-size: 22px; font-weight: 700; margin-bottom: 22px;
}
.rd-pillar__title { font-family: var(--fp-font-heading); font-size: 24px; font-weight: 700; color: var(--fp-lime); margin: 0 0 12px; }
.rd-pillar__text { margin: 0; font-size: 17px; line-height: 1.6; color: rgba(255,255,255,0.85); }

/* ── Testimonials (light alt) ──────────────────────────────────────────── */
.rd-google {
  display: inline-flex; align-items: center; gap: 10px; padding: 10px 18px; border-radius: 9999px;
  background: var(--fp-surface-lowest); box-shadow: var(--fp-shadow-card); text-decoration: none;
  font-family: var(--fp-font-heading); margin-bottom: 22px;
}
.rd-google strong { font-size: 17px; font-weight: 700; color: var(--fp-fg-1); }
.rd-google .stars { color: #F5A623; letter-spacing: 1px; font-size: 15px; }
.rd-google span.on { font-size: 15px; color: var(--fp-fg-3); font-family: var(--fp-font-body); }
.rd-tgrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; margin-top: 14px; }
.rd-tcard { background: var(--fp-surface-lowest); border-radius: var(--fp-radius-lg); padding: 32px 34px; box-shadow: var(--fp-shadow-card); }
.rd-tcard__head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.rd-tcard__avatar { width: 44px; height: 44px; border-radius: 50%; background: var(--fp-lime-light); color: var(--fp-green-dark); display: inline-flex; align-items: center; justify-content: center; font-family: var(--fp-font-heading); font-weight: 700; font-size: 18px; }
.rd-tcard__source { display: flex; align-items: center; gap: 7px; font-size: 14px; color: var(--fp-fg-3); }
.rd-tcard__stars { color: #F5A623; letter-spacing: 1px; font-size: 15px; }
.rd-tcard__quote { margin: 0 0 18px; font-size: 17.5px; line-height: 1.6; color: var(--fp-fg-1); }
.rd-tcard__name { margin: 0; font-family: var(--fp-font-heading); font-size: 16px; font-weight: 700; color: var(--fp-fg-2); }

/* ── Programme + guarantee (dark, white card) ──────────────────────────── */
.rd-prog-card { max-width: 820px; margin: 48px auto 0; background: var(--fp-surface-lowest); border-radius: var(--fp-radius-xl); overflow: hidden; box-shadow: 0 24px 60px rgba(20,44,36,0.32); text-align: left; }
.rd-prog-body { padding: clamp(30px, 4vw, 48px); }
.rd-prog-label { font-family: var(--fp-font-heading); font-size: 14px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--fp-fg-3); margin: 0 0 22px; }
.rd-prog-features { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px 32px; }
.rd-prog-features li { display: flex; align-items: flex-start; gap: 13px; font-size: 17px; color: var(--fp-fg-1); line-height: 1.4; }
.rd-prog-features svg { width: 21px; height: 21px; color: var(--fp-primary); flex-shrink: 0; margin-top: 1px; }
.rd-prog-guarantee {
  display: flex; gap: 20px; align-items: flex-start;
  margin-top: 32px; padding: 26px 28px;
  background: rgba(185,251,159,0.14); border: 1px solid rgba(58,108,93,0.16);
  border-radius: var(--fp-radius-lg);
}
.rd-prog-guarantee__icon {
  flex-shrink: 0; width: 52px; height: 52px; border-radius: 14px;
  background: var(--fp-primary); color: var(--fp-lime);
  display: inline-flex; align-items: center; justify-content: center;
}
.rd-prog-guarantee__icon svg { width: 28px; height: 28px; }
.rd-prog-guarantee__body { flex: 1; min-width: 0; }
.rd-prog-guarantee__title { font-family: var(--fp-font-heading); font-size: 20px; font-weight: 700; color: var(--fp-primary); margin: 2px 0 10px; }
.rd-prog-guarantee__promise { margin: 0 0 8px; font-size: 17.5px; font-weight: 700; color: var(--fp-fg-1); line-height: 1.5; }
.rd-prog-guarantee__support { margin: 0; font-size: 16px; color: var(--fp-fg-2); line-height: 1.55; }
.rd-prog-cta { padding: 26px 40px 30px; background: var(--fp-surface-high); border-top: 1px solid var(--fp-ghost-border); display: flex; flex-direction: column; align-items: center; gap: 12px; text-align: center; }

/* ── How it works (light, 4 steps) ─────────────────────────────────────── */
.rd-steps { list-style: none; margin: 52px 0 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.rd-step { background: var(--fp-surface-lowest); border-radius: var(--fp-radius-lg); padding: 32px 28px; box-shadow: var(--fp-shadow-subtle); }
.rd-step__num { width: 44px; height: 44px; border-radius: 50%; background: var(--fp-primary); color: #fff; display: inline-flex; align-items: center; justify-content: center; font-family: var(--fp-font-heading); font-weight: 700; font-size: 18px; margin-bottom: 22px; }
.rd-step__title { font-family: var(--fp-font-heading); font-size: 21px; font-weight: 700; color: var(--fp-primary); margin: 0 0 12px; line-height: 1.25; }
.rd-step__text { margin: 0; font-size: 16.5px; line-height: 1.55; color: var(--fp-fg-2); }

/* ── Founder note (dark, two-column) ───────────────────────────────────── */
.rd-founder__grid { display: grid; grid-template-columns: 0.82fr 1.18fr; gap: 56px; align-items: center; }
.rd-founder__photo {
  position: relative; aspect-ratio: 4 / 5; border-radius: var(--fp-radius-xl);
  background: linear-gradient(160deg, #2f5a4c 0%, #214136 100%); border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 24px 60px rgba(20,44,36,0.38);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; color: rgba(255,255,255,0.5);
}
.rd-founder__photo svg { width: 46px; height: 46px; }
.rd-founder__photo span { font-family: var(--fp-font-heading); font-size: 14.5px; font-weight: 600; }
.rd-founder__p { margin: 0 0 18px; font-size: 18px; line-height: 1.7; color: rgba(255,255,255,0.88); max-width: 60ch; }
.rd-founder__sign { margin: 26px 0 2px; font-family: Georgia, "Times New Roman", serif; font-style: italic; font-size: 30px; color: var(--fp-lime); }
.rd-founder__role { margin: 0 0 26px; font-size: 15px; color: rgba(255,255,255,0.62); }

/* ── FAQ (light accordion) ─────────────────────────────────────────────── */
.rd-faq { max-width: 800px; margin: 48px auto 0; }
.rd-faq details {
  background: var(--fp-surface-lowest); border-radius: var(--fp-radius-lg);
  margin-bottom: 14px; overflow: hidden; box-shadow: var(--fp-shadow-subtle);
}
.rd-faq summary {
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
  padding: 26px 30px; cursor: pointer; list-style: none;
  font-family: var(--fp-font-heading); font-size: 20px; font-weight: 600; color: var(--fp-primary);
}
.rd-faq summary::-webkit-details-marker { display: none; }
.rd-faq summary .ico { flex-shrink: 0; width: 26px; height: 26px; transition: transform var(--fp-dur-normal) var(--fp-ease); color: var(--fp-primary); }
.rd-faq details[open] summary .ico { transform: rotate(45deg); }
.rd-faq__body { padding: 0 30px 28px; font-size: 17.5px; line-height: 1.65; color: var(--fp-fg-2); max-width: 64ch; }

/* ── Final CTA (dark) ──────────────────────────────────────────────────── */
.rd-final { text-align: center; }
.rd-final__stack { display: inline-block; max-width: min(520px, 100%); margin: 0 auto; text-align: left; }
.rd-final .fp-h2 { max-width: none; margin: 0; }
.rd-final__benefits-wrap { margin-top: 48px; }
.rd-final__benefits { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 28px; text-align: left; }
.rd-final__benefits li { display: flex; align-items: flex-start; gap: 16px; font-size: 18px; line-height: 1.55; color: rgba(255,255,255,0.92); }
.rd-final__benefit--note { font-style: italic; color: rgba(255,255,255,0.85); }
.rd-final__benefits svg { width: 22px; height: 22px; color: var(--fp-lime); flex-shrink: 0; margin-top: 1px; }
.rd-final__scarcity { margin: 40px 0 32px; font-style: italic; font-size: 16.5px; color: rgba(255,255,255,0.72); }
.rd-final__close { margin: 26px 0 0; font-family: var(--fp-font-heading); font-size: 16px; font-weight: 600; color: rgba(255,255,255,0.78); }

/* ── Compact footer ────────────────────────────────────────────────────── */
.rd-foot { background: var(--band-green-dark); color: rgba(255,255,255,0.7); padding: 36px 0; }
.rd-foot__inner { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 18px; }
.rd-foot__logo img { height: 26px; width: auto; filter: brightness(0) invert(1); display: block; }
.rd-foot__contact { display: flex; flex-wrap: wrap; gap: 22px; font-size: 15.5px; }
.rd-foot__contact a { color: var(--fp-lime); text-decoration: none; }
.rd-foot__legal { font-size: 14px; color: rgba(255,255,255,0.5); }

/* ── Mobile sticky CTA ─────────────────────────────────────────────────── */
.rd-sticky {
  display: none; position: fixed; left: 0; right: 0; bottom: 0; z-index: 80;
  padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  background: rgba(251,249,248,0.92); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 -4px 24px rgba(27,28,28,0.1);
}
.rd-sticky .fp-btn { width: 100%; }

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 920px) {
  .rd-hero__grid, .rd-founder__grid { grid-template-columns: 1fr; gap: 40px; }
  .rd-hero__media { aspect-ratio: 16 / 10; max-height: 360px; }
  .rd-founder__photo { aspect-ratio: 16 / 11; max-height: 320px; order: -1; }
  .rd-pillars, .rd-steps { grid-template-columns: 1fr; }
  .rd-poss-grid, .rd-tgrid, .rd-pain-grid { grid-template-columns: 1fr; }
  .rd-prog-features { grid-template-columns: 1fr; }
  .rd-stats { grid-template-columns: repeat(2, 1fr); row-gap: 30px; }
  .rd-stat:nth-child(odd)::before { display: none; }
}
@media (max-width: 760px) {
  .rd-sticky { display: none; }
  .rd-prog-features li { padding: 16px 24px; }
  .rd-prog-guarantee, .rd-prog-cta { padding-left: 24px; padding-right: 24px; }
  .rd-faq summary { font-size: 18px; padding: 22px 22px; min-height: 56px; }
  .rd-faq__body { padding: 0 22px 24px; }
}

@media (max-width: 480px) {
  .rd-hero__media { aspect-ratio: 16 / 9; max-height: 240px; }
  .rd-hero__title { font-size: clamp(32px, 8vw, 40px); }
  .rd-hero__sub { margin: 18px 0 24px; }
  .rd-hero__cta { align-items: center; width: 100%; }
  .rd-hero .btn-redefine-cta { width: 100%; }
  .rd-founder__photo { max-height: 280px; aspect-ratio: 16 / 11; }
  .rd-pain-card__text { font-size: 17px; }
}
