/* =========================================================================
   Reachforge landing — base styles
   Single-file, drop-in. No build step. No framework dependency.
   ========================================================================= */

:root {
  --rf-navy:      #0A1F44;
  --rf-navy-2:    #112B59;
  --rf-amber:     #F59E0B;
  --rf-amber-2:   #D97706;
  --rf-ink:       #111827;
  --rf-ink-2:     #374151;
  --rf-mute:      #6B7280;
  --rf-line:      #E5E7EB;
  --rf-bg:        #FFFFFF;
  --rf-bg-alt:    #F8FAFC;
  --rf-bg-dark:   #0A1F44;
  --rf-success:   #10B981;
  --rf-radius:    14px;
  --rf-radius-sm: 8px;
  --rf-shadow:    0 1px 2px rgba(10, 31, 68, .04), 0 8px 24px rgba(10, 31, 68, .06);
  --rf-shadow-lg: 0 4px 12px rgba(10, 31, 68, .08), 0 24px 48px rgba(10, 31, 68, .12);
  --rf-font:      -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--rf-font);
  font-size: 16px;
  line-height: 1.55;
  color: var(--rf-ink);
  background: var(--rf-bg);
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: var(--rf-navy); text-decoration: underline; text-decoration-color: rgba(10, 31, 68, .3); text-underline-offset: 2px; }
a:hover { text-decoration-color: var(--rf-navy); }
hr { border: 0; border-top: 1px solid var(--rf-line); margin: 32px 0; }

.rf-container { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 20px; }

/* Visually hide content for active currency */
[hidden] { display: none !important; }

/* =========================================================================
   HEADER
   ========================================================================= */
.rf-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--rf-line);
}
.rf-header-inner {
  display: flex; align-items: center; gap: 20px;
  padding: 12px 20px;
}
.rf-brand {
  display: flex; align-items: center; gap: 8px;
  text-decoration: none;
  font-weight: 700;
  color: var(--rf-navy);
  font-size: 18px;
}
.rf-brand-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  background: var(--rf-navy);
  color: var(--rf-amber);
  font-weight: 800;
  border-radius: 6px;
  font-size: 18px;
}
.rf-brand-name { font-weight: 700; }
.rf-brand-by { color: var(--rf-mute); font-weight: 400; font-size: 13px; }

.rf-nav { margin-left: auto; display: flex; gap: 18px; }
.rf-nav a {
  text-decoration: none;
  color: var(--rf-ink-2);
  font-weight: 500;
  font-size: 14px;
  padding: 6px 4px;
  border-bottom: 2px solid transparent;
}
.rf-nav a:hover { color: var(--rf-navy); border-bottom-color: var(--rf-amber); }

.rf-currency-toggle { display: inline-flex; border: 1px solid var(--rf-line); border-radius: 999px; overflow: hidden; }
.rf-currency-toggle button {
  appearance: none; border: 0; background: transparent;
  padding: 6px 14px;
  font-family: inherit; font-size: 13px; font-weight: 600;
  color: var(--rf-ink-2);
  cursor: pointer;
}
.rf-currency-toggle button.active { background: var(--rf-navy); color: #fff; }
.rf-currency-toggle button:focus-visible { outline: 2px solid var(--rf-amber); outline-offset: 2px; }

@media (max-width: 720px) {
  .rf-nav { display: none; }
}

/* =========================================================================
   HERO
   ========================================================================= */
.rf-hero {
  padding: 64px 0 48px;
  background:
    radial-gradient(ellipse at top, rgba(245, 158, 11, .08), transparent 60%),
    linear-gradient(180deg, #fff 0%, var(--rf-bg-alt) 100%);
}
.rf-eyebrow {
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: 12px;
  font-weight: 700;
  color: var(--rf-amber-2);
  margin: 0 0 12px;
}
.rf-hero h1 {
  font-size: clamp(34px, 5.5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin: 0 0 18px;
  color: var(--rf-navy);
  font-weight: 800;
}
.rf-lede {
  font-size: clamp(17px, 2vw, 20px);
  color: var(--rf-ink-2);
  max-width: 720px;
  margin: 0 0 28px;
}
.rf-hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 16px; }
.rf-hero-meta { color: var(--rf-mute); font-size: 14px; margin: 0 0 32px; }

.rf-trust-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  box-shadow: var(--rf-shadow);
}
.rf-trust-strip > div { font-size: 13px; color: var(--rf-ink-2); }
.rf-trust-strip strong { color: var(--rf-navy); }

/* =========================================================================
   BUTTONS
   ========================================================================= */
.rf-btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: var(--rf-radius-sm);
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform 80ms ease, box-shadow 120ms ease, background 120ms ease;
  font-family: inherit;
}
.rf-btn-primary { background: var(--rf-navy); color: #fff; }
.rf-btn-primary:hover { background: var(--rf-navy-2); transform: translateY(-1px); box-shadow: var(--rf-shadow); }
.rf-btn-secondary { background: #fff; color: var(--rf-navy); border-color: var(--rf-navy); }
.rf-btn-secondary:hover { background: var(--rf-bg-alt); transform: translateY(-1px); }
.rf-btn-ghost { background: transparent; color: var(--rf-ink-2); }
.rf-btn-ghost:hover { color: var(--rf-navy); }
.rf-btn-block { width: 100%; }
.rf-btn-pending { opacity: .92; }

/* =========================================================================
   SECTIONS
   ========================================================================= */
.rf-section { padding: 72px 0; }
.rf-section-alt { background: var(--rf-bg-alt); }
.rf-section h2 {
  font-size: clamp(28px, 3.5vw, 40px);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--rf-navy);
  margin: 0 0 16px;
  font-weight: 800;
}
.rf-section-lede {
  font-size: 17px;
  color: var(--rf-ink-2);
  max-width: 720px;
  margin: 0 0 36px;
}
.rf-section-fineprint {
  margin-top: 24px;
  font-size: 14px;
  color: var(--rf-mute);
  max-width: 720px;
}
.rf-tier-footnote {
  margin-top: 24px;
  font-size: 13px;
  color: var(--rf-mute);
  max-width: 800px;
}

/* =========================================================================
   TIER GRID
   ========================================================================= */
.rf-tier-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
}
.rf-tier {
  position: relative;
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  padding: 28px 24px;
  box-shadow: var(--rf-shadow);
  display: flex; flex-direction: column;
}
.rf-tier-featured {
  border-color: var(--rf-amber);
  box-shadow: 0 0 0 1px var(--rf-amber), var(--rf-shadow-lg);
  transform: translateY(-4px);
}
.rf-tier-flag {
  position: absolute;
  top: -12px; left: 24px;
  background: var(--rf-amber);
  color: var(--rf-ink);
  font-size: 11px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 4px 10px;
  border-radius: 999px;
}
.rf-tier-head h3 {
  font-size: 22px;
  margin: 0 0 4px;
  color: var(--rf-navy);
}
.rf-tier-tagline { color: var(--rf-mute); font-size: 14px; margin: 0 0 18px; }

.rf-price { margin-bottom: 18px; }
.rf-price-row { display: flex; align-items: baseline; gap: 8px; }
.rf-price-amount {
  font-size: 36px;
  font-weight: 800;
  color: var(--rf-navy);
  letter-spacing: -0.02em;
  line-height: 1;
}
.rf-price-cadence { color: var(--rf-mute); font-size: 14px; }
.rf-price-sub {
  margin: 8px 0 0;
  display: flex; flex-wrap: wrap; gap: 8px; align-items: center;
  font-size: 13px;
  color: var(--rf-ink-2);
}
.rf-badge {
  display: inline-flex; align-items: center;
  background: rgba(16, 185, 129, .12);
  color: #047857;
  font-size: 11px; font-weight: 700;
  padding: 3px 8px;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.rf-tier-features {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  font-size: 14px;
  color: var(--rf-ink-2);
}
.rf-tier-features li {
  padding: 6px 0 6px 24px;
  position: relative;
  border-bottom: 1px dashed var(--rf-line);
}
.rf-tier-features li:last-child { border-bottom: 0; }
.rf-tier-features li::before {
  content: "";
  position: absolute;
  left: 4px; top: 13px;
  width: 8px; height: 8px;
  background: var(--rf-amber);
  border-radius: 2px;
}
.rf-tier-features strong { color: var(--rf-navy); }

.rf-tier-cta { margin-top: auto; }
.rf-paypal-slot { min-height: 48px; }
.rf-paypal-slot-pending { display: none; } /* hidden until real ID swapped in */
.rf-pending-note {
  font-size: 11px;
  color: var(--rf-mute);
  margin: 8px 0 0;
  text-align: center;
}

/* =========================================================================
   LEAD MAGNET
   ========================================================================= */
.rf-sample-wrap {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 820px) {
  .rf-sample-wrap { grid-template-columns: 1fr; }
}
.rf-sample-bullets {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  font-size: 14px;
  color: var(--rf-ink-2);
}
.rf-sample-bullets li {
  padding: 8px 0 8px 24px;
  position: relative;
}
.rf-sample-bullets li::before {
  content: "✓";
  position: absolute;
  left: 0; top: 8px;
  color: var(--rf-success);
  font-weight: 700;
}

.rf-sample-form {
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  padding: 24px;
  box-shadow: var(--rf-shadow);
}
.rf-sample-form label {
  display: block;
  font-weight: 600;
  font-size: 14px;
  color: var(--rf-ink);
  margin-bottom: 6px;
}
.rf-sample-form input[type="email"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius-sm);
  font-family: inherit;
  font-size: 15px;
  margin-bottom: 12px;
  background: var(--rf-bg-alt);
}
.rf-sample-form input[type="email"]:focus {
  outline: 2px solid var(--rf-amber);
  outline-offset: 2px;
  background: #fff;
}
.rf-form-fineprint { font-size: 12px; color: var(--rf-mute); margin: 12px 0 0; }
.rf-form-success {
  background: rgba(16, 185, 129, .12);
  color: #047857;
  border: 1px solid rgba(16, 185, 129, .35);
  border-radius: var(--rf-radius-sm);
  padding: 12px;
  font-size: 14px;
  margin: 12px 0 0;
}

/* =========================================================================
   INFRA GRID
   ========================================================================= */
.rf-infra-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
  margin-top: 16px;
}
.rf-infra-card {
  position: relative;
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  padding: 28px 24px;
  box-shadow: var(--rf-shadow);
  display: flex; flex-direction: column;
}
.rf-infra-card-featured {
  border-color: var(--rf-navy);
  box-shadow: 0 0 0 1px var(--rf-navy), var(--rf-shadow-lg);
}

/* =========================================================================
   HOW IT WORKS
   ========================================================================= */
.rf-how-grid {
  list-style: none;
  padding: 0;
  margin: 12px 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}
.rf-how-grid li {
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  padding: 28px 24px;
  position: relative;
}
.rf-how-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 38px; height: 38px;
  border-radius: 999px;
  background: var(--rf-amber);
  color: var(--rf-ink);
  font-weight: 800;
  font-size: 16px;
  margin-bottom: 12px;
}
.rf-how-grid h3 { color: var(--rf-navy); margin: 0 0 6px; font-size: 18px; }
.rf-how-grid p { margin: 0; color: var(--rf-ink-2); font-size: 14px; }

/* =========================================================================
   PROOF / TRUST
   ========================================================================= */
.rf-proof-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 20px;
  margin-top: 12px;
}
.rf-proof-card {
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius);
  padding: 24px;
}
.rf-proof-card h3 { color: var(--rf-navy); margin: 0 0 12px; font-size: 18px; }
.rf-proof-quote { color: var(--rf-ink-2); font-size: 15px; line-height: 1.6; margin: 0 0 12px; }
.rf-proof-attrib { font-weight: 600; color: var(--rf-ink); font-size: 14px; margin: 0 0 12px; }
.rf-proof-caption { color: var(--rf-mute); font-size: 12px; margin: 0; line-height: 1.5; }

/* =========================================================================
   FAQ
   ========================================================================= */
.rf-faq-wrap details {
  background: #fff;
  border: 1px solid var(--rf-line);
  border-radius: var(--rf-radius-sm);
  padding: 16px 20px;
  margin-bottom: 12px;
}
.rf-faq-wrap details[open] { box-shadow: var(--rf-shadow); }
.rf-faq-wrap summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--rf-navy);
  font-size: 15px;
  outline: none;
}
.rf-faq-wrap summary::-webkit-details-marker { display: none; }
.rf-faq-wrap summary::after {
  content: "+";
  float: right;
  color: var(--rf-amber-2);
  font-weight: 700;
  font-size: 20px;
  line-height: 1;
}
.rf-faq-wrap details[open] summary::after { content: "−"; }
.rf-faq-wrap details p {
  margin: 12px 0 0;
  color: var(--rf-ink-2);
  font-size: 14px;
  line-height: 1.6;
}

/* =========================================================================
   FINAL CTA
   ========================================================================= */
.rf-cta-final {
  background: linear-gradient(135deg, var(--rf-navy) 0%, var(--rf-navy-2) 100%);
  color: #fff;
}
.rf-cta-final h2 { color: #fff; margin: 0 0 12px; }
.rf-cta-final p { color: rgba(255, 255, 255, .85); max-width: 720px; margin: 0 0 28px; font-size: 17px; }
.rf-cta-final .rf-eyebrow { color: var(--rf-amber); }
.rf-cta-final-buttons { display: flex; flex-wrap: wrap; gap: 12px; }
.rf-cta-final .rf-btn-primary { background: var(--rf-amber); color: var(--rf-ink); }
.rf-cta-final .rf-btn-primary:hover { background: #fff; }
.rf-cta-final .rf-btn-secondary { background: transparent; color: #fff; border-color: rgba(255, 255, 255, .35); }
.rf-cta-final .rf-btn-secondary:hover { background: rgba(255, 255, 255, .1); }
.rf-cta-final .rf-btn-ghost { color: rgba(255, 255, 255, .8); }
.rf-cta-final .rf-btn-ghost:hover { color: #fff; }

/* =========================================================================
   FOOTER
   ========================================================================= */
.rf-footer {
  padding: 36px 0 24px;
  background: #fff;
  border-top: 1px solid var(--rf-line);
}
.rf-footer-inner {
  display: grid;
  grid-template-columns: 1.2fr 2fr 1fr;
  gap: 24px;
  align-items: center;
}
@media (max-width: 720px) {
  .rf-footer-inner { grid-template-columns: 1fr; text-align: center; }
}
.rf-footer-brand { display: flex; align-items: center; gap: 8px; color: var(--rf-navy); font-size: 14px; }
.rf-footer-sub { color: var(--rf-mute); font-weight: 400; }
.rf-footer-links { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; }
.rf-footer-links a { color: var(--rf-ink-2); text-decoration: none; font-size: 13px; }
.rf-footer-links a:hover { color: var(--rf-navy); text-decoration: underline; }
.rf-footer-legal {
  margin: 0;
  color: var(--rf-mute);
  font-size: 12px;
  text-align: right;
}
@media (max-width: 720px) { .rf-footer-legal { text-align: center; } }

/* =========================================================================
   PRINT
   ========================================================================= */
@media print {
  .rf-header, .rf-footer, .rf-hero-cta, .rf-tier-cta, .rf-currency-toggle { display: none !important; }
  body { background: #fff; }
}
