/* === RF CONNECTS MOBILE NAV OVERLAY === */

/* Outer overlay: white background, no glass, right-aligned links */
.wp-block-navigation__responsive-container.is-menu-open {
  position: fixed !important;
  inset: 0 !important;
  height: 100dvh !important;
  z-index: 99999 !important;
  overflow-y: auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  background: #ffffff !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  animation: none !important;
  opacity: 1 !important;
}

/* Ensure header/nav doesn't create a stacking context that clips the overlay */
html.has-modal-open .wp-block-navigation,
html.has-modal-open .wp-block-site-header,
html.has-modal-open header.wp-block-template-part {
  z-index: 100000 !important;
}

/* Fix: theme sets max-width on these wrappers */
html.has-modal-open .wp-block-navigation__responsive-close {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  flex: 1 1 auto !important;
  margin: 0 !important;
}

/* dialog: position:static so close button containing block becomes the overlay */
html.has-modal-open .wp-block-navigation__responsive-dialog {
  position: static !important;
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  flex: 1 1 auto !important;
  margin: 0 !important;
}

/* Content wrapper right-aligned */
.wp-block-navigation__responsive-container-content {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: flex-start !important;
  flex: 1 1 auto !important;
  padding: 100px 40px 40px !important;
  box-sizing: border-box !important;
}

/* Nav link column container right-aligned */
.wp-block-navigation__responsive-container-content .wp-block-navigation__container {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  gap: 4px !important;
  width: 100% !important;
}

/* Nav link items right-aligned */
.wp-block-navigation__responsive-container-content .wp-block-navigation-item {
  width: 100% !important;
  display: flex !important;
  justify-content: flex-end !important;
}

/* Higher specificity (0,5,1) to beat theme min-width:768px rule at 0,3,1 */
html.has-modal-open .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content,
html.has-modal-open .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content .wp-block-navigation-item a {
  font-size: clamp(2rem, 7vw, 3rem) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  color: #330C6E !important;
  text-align: right !important;
  padding: 10px 0 !important;
  display: block !important;
}

/* Close button: clean on white background */
.wp-block-navigation__responsive-container-close {
  position: absolute !important;
  top: max(16px, env(safe-area-inset-top, 0px) + 16px) !important;
  right: max(16px, env(safe-area-inset-right, 0px) + 16px) !important;
  z-index: 100001 !important;
  background: rgba(0,0,0,0.06) !important;
  border-radius: 50% !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  min-height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
  color: #1a1a1a !important;
}

/* ============================================================
   RF HERO — PREMIUM UPGRADE v3 (Photo + Brand Overlay Edition)
   ============================================================ */

/* 1. Photo background visible — transparent so rfh-bg shows */
#rf-hero {
  background: transparent !important;
  min-height: 90vh !important;
  padding: clamp(80px,10vw,140px) clamp(20px,6vw,100px) clamp(80px,8vw,120px) !important;
  display: flex !important;
  align-items: center !important;
}

/* 2. Show the photo background */
#rf-hero .rfh-bg {
  display: block !important;
}

/* 3. Enhanced premium overlay — brand purple tint + stronger vignette */
#rf-hero .rfh-bg::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    radial-gradient(72% 72% at 16% 26%, rgba(26,10,61,0.62) 0%, transparent 65%),
    radial-gradient(55% 55% at 85% 18%, rgba(108,100,255,0.18) 0%, transparent 60%),
    linear-gradient(to bottom,
      rgba(10,8,18,0.80) 0%,
      rgba(10,8,18,0.38) 45%,
      rgba(10,8,18,0.55) 100%
    ) !important;
  pointer-events: none !important;
}

/* 4. Content layer above overlay */
#rf-hero .rfh-wrap {
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
}

/* 5. Strip dark glass card — open layout over photo */
#rf-hero .rfh-card {
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  max-width: 860px !important;
  overflow: visible !important;
}

/* 6. Eyebrow badge — white-tinted for dark bg */
#rf-hero .rfh-eyebrow {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  background: rgba(255,255,255,0.10) !important;
  color: rgba(255,255,255,0.92) !important;
  border: 1px solid rgba(255,255,255,0.22) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.13em !important;
  text-transform: uppercase !important;
  padding: 6px 14px 6px 10px !important;
  border-radius: 100px !important;
  margin-bottom: 28px !important;
}
#rf-hero .rfh-eyebrow::before {
  background: #84DCD1 !important;
}

/* 7. Power headline — white → lavender → purple → pink (reads on dark bg) */
#rf-hero h1 {
  font-size: clamp(52px,8.5vw,112px) !important;
  font-weight: 800 !important;
  line-height: 0.88 !important;
  letter-spacing: -0.055em !important;
  margin: 0 0 28px !important;
  background: linear-gradient(135deg,
    #FFFFFF 0%,
    #FFFFFF 22%,
    #EAE0FF 38%,
    #C4B8FF 56%,
    #9B5CFF 75%,
    #FF4FD8 100%
  ) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
  filter: drop-shadow(0 0 48px rgba(155,92,255,0.28)) !important;
  -webkit-box-decoration-break: clone !important;
  box-decoration-break: clone !important;
}

/* 8. Subtext — soft white for dark bg */
#rf-hero .rfh-sub {
  color: rgba(248,246,255,0.76) !important;
  -webkit-text-fill-color: rgba(248,246,255,0.76) !important;
  font-size: clamp(15px,1.7vw,18px) !important;
  line-height: 1.65 !important;
  max-width: 500px !important;
  font-weight: 400 !important;
  margin-bottom: 44px !important;
}

/* 9. Actions — CENTERED on both desktop and mobile */
#rf-hero .rfh-actions {
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: center !important;
}

/* 10. Button base */
#rf-hero .rfh-btn {
  font-family: Inter,system-ui,sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
  padding: 14px 28px !important;
  border-radius: 8px !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  transition: transform 0.18s ease,box-shadow 0.18s ease,border-color 0.18s ease !important;
  line-height: 1 !important;
}

/* 11. Secondary — white ghost (matches dark bg) */
#rf-hero .rfh-btn.rfh-secondary {
  background: rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.90) !important;
  -webkit-text-fill-color: rgba(255,255,255,0.90) !important;
  border: 1.5px solid rgba(255,255,255,0.26) !important;
  box-shadow: none !important;
}
#rf-hero .rfh-btn.rfh-secondary:hover {
  background: rgba(255,255,255,0.14) !important;
  border-color: rgba(255,255,255,0.42) !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  transform: translateY(-1px) !important;
}

/* 12. Primary — gradient fill + glow */
#rf-hero .rfh-primary {
  background: linear-gradient(135deg,#6C64FF 0%,#9B5CFF 55%,#FF4FD8 100%) !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 22px rgba(108,100,255,0.38) !important;
}
#rf-hero .rfh-primary:hover {
  box-shadow: 0 8px 36px rgba(108,100,255,0.55) !important;
  transform: translateY(-1px) !important;
}

/* 13. Arrow micro-animation */
#rf-hero .rfh-btn .arr {
  display: inline-block !important;
  transition: transform 0.18s ease !important;
}
#rf-hero .rfh-btn:hover .arr {
  transform: translateX(4px) !important;
}

/* 14. Desktop polish */
@media (min-width: 900px) {
  #rf-hero .rfh-inner {
    max-width: 700px !important;
  }
}

/* 15. Mobile */
@media (max-width: 768px) {
  #rf-hero {
    min-height: 88vh !important;
    padding: 80px 24px 64px !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
  }
  #rf-hero h1 {
    font-size: clamp(46px,13.5vw,72px) !important;
    line-height: 0.86 !important;
    letter-spacing: -0.045em !important;
    margin-bottom: 22px !important;
  }
  #rf-hero .rfh-sub {
    max-width: 100% !important;
    margin-bottom: 36px !important;
  }
  #rf-hero .rfh-actions {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
    width: 100% !important;
    justify-content: center !important;
  }
  #rf-hero .rfh-btn {
    justify-content: center !important;
    padding: 16px 24px !important;
  }
}


/* =======================================================
   RF CONNECTS — BELOW-HERO PREMIUM UPGRADE v1
   Services glassmorphism · Summary hover · CTA glow
   Footer links · Scroll reveal system
   ======================================================= */

/* ── SCROLL REVEAL SYSTEM ──────────────────────────────── */
.rf-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.rf-reveal.rf-visible {
  opacity: 1 !important;
  transform: none !important;
}
.rf-delay-1 { transition-delay: 0.08s !important; }
.rf-delay-2 { transition-delay: 0.16s !important; }
.rf-delay-3 { transition-delay: 0.24s !important; }
.rf-delay-4 { transition-delay: 0.32s !important; }

/* ── SERVICES — GLASSMORPHISM CARDS ────────────────────── */
.rf-services .rf-card {
  background: rgba(255,255,255,0.82) !important;
  backdrop-filter: blur(20px) saturate(160%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(160%) !important;
  border: 1px solid rgba(108,100,255,0.13) !important;
  border-radius: 18px !important;
  box-shadow: 0 2px 8px rgba(51,12,110,0.06), 0 8px 32px rgba(108,100,255,0.08) !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform 0.30s cubic-bezier(0.16,1,0.3,1), box-shadow 0.30s ease !important;
}
.rf-services .rf-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg,#6C64FF 0%,#9B5CFF 55%,#FF4FD8 100%) !important;
  opacity: 0 !important;
  transition: opacity 0.30s ease !important;
  z-index: 1 !important;
}
.rf-services .rf-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 12px 40px rgba(108,100,255,0.20), 0 4px 14px rgba(51,12,110,0.12) !important;
}
.rf-services .rf-card:hover::before { opacity: 1 !important; }

/* Services heading: tighter + gradient rf word */
.rf-services-heading {
  font-size: clamp(36px,4.5vw,56px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.045em !important;
}
.rf-services-heading span {
  background: linear-gradient(135deg,#6C64FF 0%,#9B5CFF 55%,#FF4FD8 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}
.rf-services-heading::after {
  background: linear-gradient(90deg,#6C64FF,#9B5CFF,#FF4FD8) !important;
}

/* ── SUMMARY — GLASSMORPHISM CARDS ─────────────────────── */
.rf-sum-card {
  background: rgba(255,255,255,0.80) !important;
  backdrop-filter: blur(16px) saturate(150%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(150%) !important;
  border: 1px solid rgba(108,100,255,0.11) !important;
  border-radius: 18px !important;
  box-shadow: 0 4px 20px rgba(108,100,255,0.07) !important;
  transition: transform 0.30s cubic-bezier(0.16,1,0.3,1), box-shadow 0.30s ease !important;
  position: relative !important;
  overflow: hidden !important;
}
.rf-sum-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg,#6C64FF,#9B5CFF,#FF4FD8) !important;
  opacity: 0 !important;
  transition: opacity 0.30s ease !important;
}
.rf-sum-card:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 16px 44px rgba(108,100,255,0.18) !important;
}
.rf-sum-card:hover::before { opacity: 1 !important; }
.rf-summary-grid > *:nth-child(1).rf-sum-card { transition-delay: 0s; }
.rf-summary-grid > *:nth-child(2).rf-sum-card { transition-delay: 0.08s; }
.rf-summary-grid > *:nth-child(3).rf-sum-card { transition-delay: 0.16s; }

/* ── FINAL CTA — PRIMARY BUTTON GLOW ───────────────────── */
.rf-final-btn.rf-final-primary {
  box-shadow: 0 6px 28px rgba(108,100,255,0.42) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}
.rf-final-btn.rf-final-primary:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 44px rgba(108,100,255,0.60) !important;
}
.rf-final-btn.rf-final-secondary {
  transition: transform 0.22s ease, background 0.22s ease !important;
}
.rf-final-btn.rf-final-secondary:hover {
  transform: translateY(-2px) !important;
  background: rgba(255,255,255,0.12) !important;
}

/* ── FOOTER — SOCIAL ICON + NAV HOVER ──────────────────── */
footer.wp-block-template-part .wp-block-social-links .wp-social-link {
  transition: transform 0.2s ease, opacity 0.2s ease !important;
}
footer.wp-block-template-part .wp-block-social-links .wp-social-link:hover {
  transform: translateY(-3px) scale(1.08) !important;
  opacity: 0.80 !important;
}
footer.wp-block-template-part .wp-block-navigation-item__content,
footer.wp-block-template-part .wp-block-navigation a {
  padding-bottom: 2px !important;
  border-bottom: 1.5px solid transparent !important;
  transition: color 0.2s ease, border-color 0.2s ease !important;
}
footer.wp-block-template-part .wp-block-navigation a:hover {
  color: #6C64FF !important;
  border-bottom-color: #6C64FF !important;
}

/* ── SECTION BADGE PILLS ────────────────────────────────── */
.rf-services-pill, .rf-summary-pill, .rf-section-pill {
  background: linear-gradient(135deg,rgba(108,100,255,0.10),rgba(255,79,216,0.07)) !important;
  border: 1px solid rgba(108,100,255,0.22) !important;
  color: #6C64FF !important;
  font-weight: 700 !important;
  letter-spacing: 0.10em !important;
}

/* ── LEADS SECTION — SUBTLE BG UPGRADE ─────────────────── */
#rf-lead-alert {
  background: linear-gradient(160deg,rgba(108,100,255,0.04) 0%,transparent 40%), #f8f6ff !important;
}

/* ── HVAC LP — HEADING UNDERLINE GRADIENT ───────────────── */
#rf-hvac-lp .rfhvac-rule,
#rf-hvac-lp h2 + hr,
#rf-hvac-lp .rfhvac-wrap h2::after {
  background: linear-gradient(90deg,#6C64FF,#84DCD1) !important;
  border: none !important;
  height: 3px !important;
}

/* animations removed — nav opens/closes instantly */



/* ============================================================
   RF CONNECTS — PREMIUM VISUAL REDESIGN v2
   Deep-rebuild for every section below the hero
   ============================================================ */

/* ─────────────────────────────────────────
   SERVICES SECTION  —  dark bg + premium cards
   ───────────────────────────────────────── */

section.rf-services {
  background:
    radial-gradient(ellipse 80% 55% at 50% 0%, rgba(108,100,255,.18) 0%, transparent 62%),
    radial-gradient(ellipse 50% 45% at 88% 90%, rgba(240,0,117,.10) 0%, transparent 60%),
    #0D0818 !important;
  padding-top: 120px !important;
  padding-bottom: 120px !important;
  max-width: 100% !important;
  overflow: hidden !important;
}

/* Heading — massive + gradient first word */
section.rf-services .rf-services-heading {
  font-size: clamp(48px, 6vw, 80px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.05em !important;
  color: #ffffff !important;
  line-height: 1.05 !important;
  margin-bottom: 20px !important;
}

section.rf-services .rf-services-heading span {
  background: linear-gradient(135deg, #6C64FF 0%, #9B5CFF 50%, #FF4FD8 100%);
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  color: transparent !important;
}

/* Intro paragraph */
section.rf-services .rf-intro {
  color: rgba(255,255,255,.58) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1.72 !important;
  margin-bottom: 60px !important;
}

/* Card base */
section.rf-services .rf-card {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 20px !important;
  padding: 40px 32px !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform .32s ease, box-shadow .32s ease !important;
  text-decoration: none !important;
}

/* Top gradient accent line */
section.rf-services .rf-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, #6C64FF, #9B5CFF, #FF4FD8) !important;
  border-radius: 20px 20px 0 0 !important;
}

section.rf-services .rf-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 28px 70px rgba(108,100,255,.26), inset 0 0 40px rgba(108,100,255,.06) !important;
  border-color: rgba(108,100,255,.28) !important;
}

/* Icon circle */
section.rf-services .rf-icon {
  background: linear-gradient(135deg, rgba(108,100,255,.30), rgba(155,92,255,.18)) !important;
  border-radius: 16px !important;
  width: 66px !important;
  height: 66px !important;
  margin: 0 auto 24px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.18) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Card title */
section.rf-services .rf-card h3 {
  color: #ffffff !important;
  font-weight: 800 !important;
  font-size: 22px !important;
  letter-spacing: -0.028em !important;
  margin-bottom: 8px !important;
}

/* Sub-label */
section.rf-services .rf-sub {
  color: #6C64FF !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: .1em !important;
  text-transform: uppercase !important;
  margin-bottom: 16px !important;
}

/* Card body text */
section.rf-services .rf-card p {
  color: rgba(255,255,255,.52) !important;
  font-size: 15px !important;
  line-height: 1.70 !important;
}


/* ─────────────────────────────────────────
   LEAD ALERT SECTION  —  instant leads hero
   ───────────────────────────────────────── */

#rf-lead-alert {
  background: linear-gradient(155deg, #F2EEFF 0%, #F9F7FF 45%, #EEF2FF 100%) !important;
  position: relative !important;
  overflow: hidden !important;
}

#rf-lead-alert::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(108,100,255,.45), transparent) !important;
  pointer-events: none !important;
}

#rf-lead-header {
  font-size: clamp(38px, 5vw, 66px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.08 !important;
  color: #1A0836 !important;
}

.rf-lead-eyebrow {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
  color: #6C64FF !important;
}

.rf-lead-underline {
  background: linear-gradient(90deg, #6C64FF, #FF4FD8) !important;
  height: 3px !important;
  border-radius: 2px !important;
  max-width: 140px !important;
  margin-top: 12px !important;
}

/* Slack card glassmorphism upgrade */
#rf-slack-card {
  background: rgba(255,255,255,.72) !important;
  backdrop-filter: blur(22px) !important;
  -webkit-backdrop-filter: blur(22px) !important;
  border: 1px solid rgba(255,255,255,.85) !important;
  box-shadow: 0 28px 70px rgba(108,100,255,.16), 0 2px 10px rgba(0,0,0,.06) !important;
  border-radius: 22px !important;
}

/* CTA link in lead section */
a#rf-lead-cta {
  background: linear-gradient(135deg, #6C64FF, #9B5CFF, #FF4FD8) !important;
  box-shadow: 0 0 36px rgba(108,100,255,.38), 0 4px 16px rgba(108,100,255,.25) !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  transition: box-shadow .3s ease, transform .2s ease !important;
}

a#rf-lead-cta:hover {
  box-shadow: 0 0 56px rgba(108,100,255,.55), 0 8px 28px rgba(108,100,255,.36) !important;
  transform: translateY(-2px) !important;
}


/* ─────────────────────────────────────────
   HVAC LP SECTION  —  conversion section
   ───────────────────────────────────────── */

#rf-hvac-lp {
  background:
    radial-gradient(ellipse 55% 55% at 85% 45%, rgba(108,100,255,.09), transparent 65%),
    radial-gradient(ellipse 45% 45% at 15% 80%, rgba(132,220,209,.08), transparent 60%),
    #f8f6ff !important;
  position: relative !important;
}

#rf-hvac-lp::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(108,100,255,.35), transparent) !important;
  pointer-events: none !important;
}

#rf-hvac-lp .eyebrow {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .13em !important;
  text-transform: uppercase !important;
  color: #6C64FF !important;
}

.rf-hvac-lp-underline {
  background: linear-gradient(90deg, #6C64FF, #FF4FD8) !important;
  height: 3px !important;
  border-radius: 2px !important;
}

/* Wire visual card upgrade */
.rf-wire {
  box-shadow: 0 28px 70px rgba(108,100,255,.16), 0 2px 10px rgba(0,0,0,.06) !important;
  border-radius: 22px !important;
  border: 1px solid rgba(108,100,255,.12) !important;
}


/* ─────────────────────────────────────────
   SUMMARY SECTION  —  upgraded glassmorphism
   ───────────────────────────────────────── */

section.rf-summary {
  background: linear-gradient(175deg, #F8F6FF 0%, #EDE8FF 100%) !important;
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}

section.rf-summary .rf-summary-head {
  background: rgba(255,255,255,.74) !important;
  backdrop-filter: blur(28px) !important;
  -webkit-backdrop-filter: blur(28px) !important;
  border: 1px solid rgba(255,255,255,.82) !important;
  box-shadow: 0 32px 90px rgba(108,100,255,.15), 0 4px 18px rgba(0,0,0,.05) !important;
  border-radius: 30px !important;
}

section.rf-summary .rf-summary-title {
  font-size: clamp(38px, 5vw, 62px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  color: #1A0836 !important;
  line-height: 1.1 !important;
}

section.rf-summary .rf-summary-underline {
  background: linear-gradient(90deg, #6C64FF, #FF4FD8) !important;
  height: 3px !important;
  border-radius: 2px !important;
}

section.rf-summary .rf-summary-sub {
  color: #6B7280 !important;
  font-size: 17px !important;
  font-weight: 500 !important;
  line-height: 1.72 !important;
}


/* ─────────────────────────────────────────
   FINAL CTA SECTION  —  bold deep dark
   ───────────────────────────────────────── */

section.rf-final-cta {
  background: #F8F6FF !important;
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}

section.rf-final-cta .rf-final-shell {
  background: linear-gradient(135deg, #1A0836 0%, #2D1B69 55%, #1A0836 100%) !important;
  border: 1px solid rgba(108,100,255,.28) !important;
  box-shadow:
    0 48px 110px rgba(26,8,54,.65),
    0 0 0 1px rgba(108,100,255,.14),
    inset 0 1px 0 rgba(255,255,255,.06) !important;
  border-radius: 30px !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Noise texture overlay on shell */
section.rf-final-cta .rf-final-shell::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E") !important;
  background-size: 180px 180px !important;
  opacity: .028 !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

/* Radial glow center-top */
section.rf-final-cta .rf-final-shell::after {
  content: '' !important;
  position: absolute !important;
  top: -80px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 700px !important;
  height: 320px !important;
  background: radial-gradient(ellipse, rgba(108,100,255,.22) 0%, transparent 68%) !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

section.rf-final-cta .rf-final-grid,
section.rf-final-cta .rf-final-wrap,
section.rf-final-cta .rf-final-image {
  position: relative !important;
  z-index: 1 !important;
}

section.rf-final-cta .rf-final-eyebrow {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  color: rgba(108,100,255,.85) !important;
}

section.rf-final-cta .rf-final-wrap h2 {
  font-size: clamp(34px, 4.5vw, 56px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.1 !important;
  color: #ffffff !important;
}

section.rf-final-cta .rf-final-wrap p {
  color: rgba(255,255,255,.65) !important;
  font-size: 16px !important;
  line-height: 1.70 !important;
}

section.rf-final-cta .rf-final-btn.rf-final-primary {
  background: linear-gradient(135deg, #6C64FF 0%, #9B5CFF 50%, #FF4FD8 100%) !important;
  box-shadow: 0 0 44px rgba(108,100,255,.45), 0 6px 22px rgba(108,100,255,.30) !important;
  border: none !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  border-radius: 50px !important;
  transition: box-shadow .3s ease, transform .22s ease !important;
}

section.rf-final-cta .rf-final-btn.rf-final-primary:hover {
  box-shadow: 0 0 66px rgba(108,100,255,.62), 0 10px 34px rgba(108,100,255,.42) !important;
  transform: translateY(-2px) !important;
}

section.rf-final-cta .rf-final-btn.rf-final-secondary {
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  color: rgba(255,255,255,.85) !important;
  border-radius: 50px !important;
  transition: background .3s ease, border-color .3s ease !important;
}

section.rf-final-cta .rf-final-btn.rf-final-secondary:hover {
  background: rgba(255,255,255,.14) !important;
  border-color: rgba(255,255,255,.38) !important;
}

section.rf-final-cta .rf-final-image-card {
  border-radius: 22px !important;
  overflow: hidden !important;
  box-shadow: 0 28px 70px rgba(0,0,0,.45) !important;
}


/* ─────────────────────────────────────────
   FOOTER  —  gradient separator + hover effects
   ───────────────────────────────────────── */

footer.wp-block-template-part {
  border-top: 1px solid transparent !important;
  border-image: linear-gradient(90deg, transparent 0%, #6C64FF 25%, #9B5CFF 50%, #FF4FD8 75%, transparent 100%) 1 !important;
  position: relative !important;
}

footer a,
footer .wp-block-navigation-item__content {
  transition: color .22s ease !important;
}

footer a:hover,
footer .wp-block-navigation-item__content:hover {
  color: #6C64FF !important;
  text-decoration: none !important;
}

footer .wp-block-social-links .wp-block-social-link a {
  transition: transform .22s ease, opacity .22s ease, filter .22s ease !important;
}

footer .wp-block-social-links .wp-block-social-link a:hover {
  transform: translateY(-4px) scale(1.08) !important;
  opacity: .9 !important;
  filter: drop-shadow(0 4px 10px rgba(108,100,255,.35)) !important;
}

/* Logo glow */
footer .wp-block-site-logo {
  filter: drop-shadow(0 0 14px rgba(51,12,110,.22)) !important;
  transition: filter .3s ease !important;
}

footer .wp-block-site-logo:hover {
  filter: drop-shadow(0 0 20px rgba(51,12,110,.4)) !important;
}

/* Stat grid horizontal dividers */
.rf-summary-grid {
  position: relative !important;
}

.rf-summary-grid::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(90deg, transparent 33%, rgba(108,100,255,.12) 33%, rgba(108,100,255,.12) 33.5%, transparent 33.5%, transparent 66%, rgba(108,100,255,.12) 66%, rgba(108,100,255,.12) 66.5%, transparent 66.5%) !important;
  pointer-events: none !important;
  z-index: 0 !important;
}

/* === RF CONNECTS — LIGHT CANVAS v4 === */
/* Uniform #F8F6FF base, dark ink throughout */
html {
  background: #F8F6FF !important;
  background-size: auto !important;
  min-height: auto;
}
body, .wp-site-blocks { background: #F8F6FF !important; }

/* Services: barely-there indigo tint, white cards, dark text */
section.rf-services {
  background:
    radial-gradient(ellipse 80% 55% at 50% 0%, rgba(108,100,255,0.06) 0%, transparent 62%),
    rgba(108,100,255,0.04) !important;
}
section.rf-services .rf-services-heading { color: #330C6E !important; }
section.rf-services .rf-intro { color: rgba(51,12,110,0.62) !important; }
section.rf-services .rf-card {
  background: rgba(255,255,255,0.90) !important;
  border: 1px solid rgba(108,100,255,0.14) !important;
}
section.rf-services .rf-card h3 {
  color: #1a1a2e !important;
  -webkit-text-fill-color: #1a1a2e !important;
}
section.rf-services .rf-card p { color: rgba(26,26,46,0.65) !important; }

/* HVAC LP: inherit body */
#rf-hvac-lp { background: transparent !important; }

/* Final CTA: section AND shell both light — match exact specificity of base rule */
html body section.rf-final-cta { background: #F8F6FF !important; }
section.rf-final-cta .rf-final-shell {
  background: #F8F6FF !important;
  background-image: none !important;
  box-shadow: 0 2px 24px rgba(108,100,255,0.08) !important;
  border: 1px solid rgba(108,100,255,0.10) !important;
}
/* Suppress the noise texture and glow overlays */
section.rf-final-cta .rf-final-shell::before,
section.rf-final-cta .rf-final-shell::after {
  display: none !important;
}
/* CTA text: dark ink */
section.rf-final-cta .rf-final-shell h2,
section.rf-final-cta .rf-final-shell h3,
section.rf-final-cta .rf-final-shell h4,
section.rf-final-cta .rf-final-shell p {
  color: #1a1a2e !important;
  -webkit-text-fill-color: #1a1a2e !important;
}
section.rf-final-cta .rf-final-eyebrow {
  color: #6C64FF !important;
  -webkit-text-fill-color: #6C64FF !important;
}

/* === RF POLISH FIX v1 — CTA Secondary Button === */
/* Secondary "meet the team" button: white text/border adapted for light canvas */
.rf-final-btn.rf-final-secondary {
  color: #330C6E !important;
  -webkit-text-fill-color: #330C6E !important;
  background: rgba(108, 100, 255, 0.07) !important;
  border: 1.5px solid rgba(108, 100, 255, 0.35) !important;
}

/* =====================================================
   RF GROWTH SYSTEM — Visual Upgrade v1
   Append-only. Home page CSS above is untouched.
   Brand: bg #F8F6FF | purple #330C6E | indigo #6C64FF
          pink #F00075 | teal #84DCD1 | grad #6C64FF→#FF4FD8
   ===================================================== */

/* --- SECTION BACKGROUNDS: ALTERNATING RHYTHM --- */
.rf-how {
  background: rgba(108,100,255,0.04) !important;
}
.rf-who {
  background: rgba(108,100,255,0.04) !important;
}
#rfgs-final {
  background: rgba(108,100,255,0.04) !important;
}

/* --- HOW IT WORKS: STEP CARD ENHANCEMENTS --- */
.rf-step {
  background: #fff !important;
  border: 1px solid rgba(108,100,255,0.13) !important;
  box-shadow: 0 2px 16px rgba(51,12,110,0.06), 0 0 0 1px rgba(108,100,255,0.06) inset !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.rf-step:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 12px 40px rgba(108,100,255,0.14) !important;
}

/* --- RESULTS: CASE STUDY CARD ENHANCEMENTS --- */
.rf-res .case {
  background: #fff !important;
  border: 1px solid rgba(108,100,255,0.12) !important;
  border-radius: 20px !important;
  overflow: hidden !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.rf-res .case:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 48px rgba(108,100,255,0.16) !important;
}

/* --- TIER CARDS: FLIP DARK → LIGHT --- */
.rfc-card {
  background: #fff !important;
  border: 1px solid rgba(108,100,255,0.14) !important;
  box-shadow: 0 4px 24px rgba(51,12,110,0.08) !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.rfc-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 14px 44px rgba(108,100,255,0.16) !important;
}
.rfc-card.featured {
  background: linear-gradient(155deg, rgba(108,100,255,0.05) 0%, #fff 60%) !important;
  border: 2px solid rgba(108,100,255,0.45) !important;
  box-shadow: 0 8px 40px rgba(108,100,255,0.18) !important;
}
.rfc-card.coming {
  background: rgba(248,246,255,0.7) !important;
  opacity: 0.72;
  border: 1px dashed rgba(108,100,255,0.2) !important;
}

/* Flip rfc-card text from white → dark */
.rfc-card .rfc-name {
  color: #330C6E !important;
}
.rfc-card .rfc-badge {
  background: rgba(108,100,255,0.1) !important;
  color: #6C64FF !important;
}
.rfc-card .rfc-badge.pop {
  background: linear-gradient(135deg, #6C64FF 0%, #FF4FD8 100%) !important;
  color: #fff !important;
}
.rfc-card .rfc-hr {
  background: rgba(108,100,255,0.1) !important;
}
.rfc-card .rfc-item {
  color: #444 !important;
}
.rfc-card .rfc-item::before,
.rfc-card .rfc-item .check {
  color: #6C64FF !important;
}

/* Summary table light treatment */
.rf-summary {
  background: #fff !important;
  border: 1px solid rgba(108,100,255,0.12) !important;
  box-shadow: 0 2px 16px rgba(51,12,110,0.06) !important;
  border-radius: 16px !important;
}

/* --- FINAL CTA CARD: FLIP DARK → LIGHT --- */
.rfgs-card {
  background: #fff !important;
  border: 1px solid rgba(108,100,255,0.14) !important;
  border-top: 4px solid transparent !important;
  border-image: linear-gradient(90deg, #6C64FF 0%, #FF4FD8 100%) 1 !important;
  box-shadow: 0 8px 48px rgba(51,12,110,0.10) !important;
  border-radius: 24px !important;
  /* border-image overrides border-radius on top — use outline trick instead */
}
/* Use ::before for the gradient top bar since border-image kills border-radius */
.rfgs-card {
  border-top: 1px solid rgba(108,100,255,0.14) !important;
  border-image: none !important;
  position: relative !important;
  overflow: hidden !important;
}
.rfgs-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0; left: 0; right: 0 !important;
  height: 4px !important;
  background: linear-gradient(90deg, #6C64FF 0%, #FF4FD8 100%) !important;
  border-radius: 0 !important;
  z-index: 1 !important;
}

/* Flip rfgs text from white → dark */
.rfgs-eyebrow {
  color: #6C64FF !important;
  background: rgba(108,100,255,0.1) !important;
}
.rfgs-title {
  color: #330C6E !important;
  -webkit-text-fill-color: #330C6E !important;
}
.rfgs-sub {
  color: #555 !important;
}
.rfgs-sub strong {
  color: #330C6E !important;
}
.rfgs-chip {
  background: rgba(108,100,255,0.09) !important;
  color: #330C6E !important;
}
.rfgs-chip .dot {
  background: #6C64FF !important;
}
.rfgs-note {
  color: #777 !important;
}

/* rfgs step items inside the card */
.rfgs-steps .rfgs-step,
.rfgs-step {
  color: #333 !important;
}
.rfgs-step-num,
.rfgs-num {
  background: rgba(108,100,255,0.1) !important;
  color: #6C64FF !important;
}

/* --- CTA BUTTONS: GRADIENT PRIMARY + GHOST SECONDARY --- */

/* Primary CTA: any "qualify" or "apply" style button in light sections */
.rfgs-actions a:first-of-type,
.rf-pricing-cta .rfq-open,
.rf-who-cta .rfq-open {
  background: linear-gradient(135deg, #6C64FF 0%, #FF4FD8 100%) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: 0 4px 20px rgba(108,100,255,0.35) !important;
  transition: opacity 0.2s ease, transform 0.2s ease !important;
}
.rfgs-actions a:first-of-type:hover,
.rf-pricing-cta .rfq-open:hover,
.rf-who-cta .rfq-open:hover {
  opacity: 0.92 !important;
  transform: translateY(-2px) !important;
}

/* rfgs primary link — "apply to work with us" */
.rfgs-actions a[href],
.rfgs-actions a {
  color: #330C6E !important;
}
.rfgs-actions a:first-child {
  background: linear-gradient(135deg, #6C64FF 0%, #FF4FD8 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  padding: 14px 32px !important;
  font-weight: 700 !important;
  box-shadow: 0 4px 20px rgba(108,100,255,0.30) !important;
  display: inline-block !important;
  transition: opacity 0.2s, transform 0.2s !important;
}
.rfgs-actions a:first-child:hover {
  opacity: 0.90 !important;
  transform: translateY(-2px) !important;
}
.rfgs-actions a:not(:first-child) {
  background: transparent !important;
  color: #6C64FF !important;
  border: 2px solid rgba(108,100,255,0.4) !important;
  border-radius: 100px !important;
  padding: 12px 28px !important;
  font-weight: 600 !important;
  transition: all 0.2s !important;
}
.rfgs-actions a:not(:first-child):hover {
  background: rgba(108,100,255,0.08) !important;
  border-color: #6C64FF !important;
  transform: translateY(-2px) !important;
}

/* Who section CTA button */
.rf-who-cta a {
  color: #330C6E !important;
}

/* Pricing section CTA */
.rf-pricing-cta a {
  color: #330C6E !important;
}

/* General rfq-open buttons in light sections */
.rf-how .rfq-open,
.rf-res .rfq-open,
.rf-who .rfq-open,
.rf-pricing .rfq-open,
#rfgs-final .rfq-open {
  background: linear-gradient(135deg, #6C64FF 0%, #FF4FD8 100%) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 100px !important;
  box-shadow: 0 4px 20px rgba(108,100,255,0.30) !important;
  transition: opacity 0.2s, transform 0.2s !important;
}
.rf-how .rfq-open:hover,
.rf-res .rfq-open:hover,
.rf-who .rfq-open:hover,
.rf-pricing .rfq-open:hover,
#rfgs-final .rfq-open:hover {
  opacity: 0.90 !important;
  transform: translateY(-2px) !important;
}

/* --- SCROLL REVEAL: wire .rf-fade to IntersectionObserver --- */
/* .rf-fade elements not using the existing reveal class get the transition */
.rf-fade:not(.rf-how-reveal):not(.rf-res-reveal):not(.rf-hero-reveal) {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.65s ease-out, transform 0.65s ease-out;
  will-change: opacity, transform;
}
.rf-fade.visible,
.rf-fade.active {
  opacity: 1 !important;
  transform: none !important;
}

/* --- MOBILE TIGHTENING --- */
@media (max-width: 640px) {
  .rfc-grid {
    grid-template-columns: 1fr !important;
  }
  .rfgs-card {
    padding: 32px 24px !important;
  }
}


/* ===================================================
   RF GROWTH SYSTEM — v1 HOTFIX: restore rf-fade visibility
   The rf-fade elements have their own JS observer system.
   Remove the conflicting opacity:0 override.
   =================================================== */
.rf-fade:not(.rf-how-reveal):not(.rf-res-reveal):not(.rf-hero-reveal) {
  opacity: 1 !important;
  transform: none !important;
  transition: opacity 0.65s ease-out, transform 0.65s ease-out !important;
}
/* Keep the visible/active states as smooth transitions if JS adds them */
.rf-fade.visible,
.rf-fade.active,
.rf-fade.animated {
  opacity: 1 !important;
  transform: none !important;
}


/* =====================================================
   RF GROWTH SYSTEM — v1 PATCH 2
   Fix case-body white text, fit card top borders,
   and fit head label colors (use literals not vars)
   ===================================================== */

/* --- CASE STUDY CARDS: flip white text → dark --- */
.rf-res .case {
  background: #fff !important;
}
.rf-res .case-body {
  color: #333 !important;
}
.rf-res .case-body .tag {
  background: rgba(108,100,255,0.1) !important;
  color: #6C64FF !important;
}
.rf-res .case-body h3 {
  color: #330C6E !important;
}
.rf-res .case-body .sub {
  color: #666 !important;
}
.rf-res .case-body .stats {
  color: #330C6E !important;
}
.rf-res .case-body .note {
  color: #777 !important;
}
/* Stats numbers — keep them prominent */
.rf-res .case-body .stats strong,
.rf-res .case-body .stats b,
.rf-res .case-body .stats [class*="num"],
.rf-res .case-body .stats [class*="val"] {
  color: #330C6E !important;
  font-weight: 800 !important;
}

/* --- WHO SECTION: fit card top border accents (literal hex, !important) --- */
.rf-who-grid .rf-fit:first-child {
  border-top: 4px solid #84DCD1 !important;
}
.rf-who-grid .rf-fit:last-child {
  border-top: 4px solid #F00075 !important;
}

/* Fit head label colors */
.rf-who-grid .rf-fit:first-child .rf-fit-head {
  color: #2bb8a5 !important;
}
.rf-who-grid .rf-fit:last-child .rf-fit-head {
  color: #F00075 !important;
}


/* ============================================================
   RF GROWTH SYSTEM — PREMIUM POLISH PASS  2025-03-24
   rfconnects.com/rfgrowthsystem/
   ============================================================ */

/* ── 1. NAV / HERO OVERLAP FIX ─────────────────────────────────
   Nav is position:fixed, 146px tall. Hero section starts at y=88,
   putting first content only 34px below nav bottom (was 92px padding).
   scroll-padding-top was 32px → anchor sections snapped 114px behind nav.
──────────────────────────────────────────────────────────────── */
html {
  scroll-padding-top: 160px !important;
}

.rf-hero {
  padding-top: 160px !important;
}

#how-it-works,
#results,
#who,
#tiers,
#rfgs-final {
  scroll-margin-top: 160px;
}

/* ── 2a. HERO PRE-QUALIFIER CARD — DARK → LIGHT ────────────────
   Was: linear-gradient(135deg,rgba(40,38,55,.94),rgba(20,18,30,.94))
   Now: crisp white glass card with brand border + soft shadow
──────────────────────────────────────────────────────────────── */
.rf-card {
  background-image: none !important;
  background-color: rgba(255, 255, 255, 0.96) !important;
  border: 1px solid rgba(108, 100, 255, 0.18) !important;
  box-shadow: 0 20px 56px rgba(51, 12, 110, 0.09) !important;
}

.rf-card-title {
  color: #330C6E !important;
}

.rf-card-tag {
  background: rgba(240, 0, 117, 0.07) !important;
  color: #F00075 !important;
  border: 1px solid rgba(240, 0, 117, 0.18) !important;
}

.rf-card-item {
  background: rgba(108, 100, 255, 0.05) !important;
  color: rgba(51, 12, 110, 0.85) !important;
}

.rf-ic {
  background: rgba(108, 100, 255, 0.11) !important;
  color: #330C6E !important;
}

.rf-card-foot {
  color: rgba(51, 12, 110, 0.50) !important;
}

/* ── 2b. PRICING CTA CARD — DARK → LIGHT ───────────────────────
   Was: background rgb(18,11,35) — near-black with white text
   Now: light brand gradient with proper dark-on-light contrast
──────────────────────────────────────────────────────────────── */
.rf-pricing-cta {
  background: linear-gradient(135deg, rgba(108, 100, 255, 0.08) 0%, rgba(240, 0, 117, 0.04) 100%) !important;
  border: 1px solid rgba(108, 100, 255, 0.16) !important;
  box-shadow: 0 4px 28px rgba(51, 12, 110, 0.07) !important;
}

.rf-pricing-cta-title {
  color: #330C6E !important;
  letter-spacing: -0.03em;
}

.rf-pricing-cta-sub {
  color: rgba(51, 12, 110, 0.62) !important;
}

/* ── 2c. FINAL SECTION STEP CARDS — DARK → LIGHT ───────────────
   Was: rgba(0,0,0,0.24) — rendered as flat medium gray over white card
   Was: stepTitle rgba(255,255,255,0.92) — near-invisible on gray
   Now: light brand-tinted sub-cards with readable dark type
──────────────────────────────────────────────────────────────── */
.rfgs-step {
  background: rgba(248, 246, 255, 0.88) !important;
  border: 1px solid rgba(108, 100, 255, 0.13) !important;
  box-shadow: 0 2px 14px rgba(51, 12, 110, 0.05) !important;
}

.rfgs-stepTitle {
  color: #330C6E !important;
  font-weight: 800 !important;
}

.rfgs-stepNum {
  color: #6C64FF !important;
  font-weight: 900 !important;
}

.rfgs-stepText {
  color: rgba(51, 12, 110, 0.60) !important;
}

/* ── 3. GENERAL POLISH SWEEP ────────────────────────────────────

   Secondary ghost button — was barely visible on light bg
   Bump border opacity and font-weight for definition
──────────────────────────────────────────────────────────────── */
.rf-secondary {
  background: rgba(255, 255, 255, 0.94) !important;
  border: 1.5px solid rgba(108, 100, 255, 0.24) !important;
  color: #330C6E !important;
  font-weight: 700 !important;
}

/* Consistent tight letter-spacing on all section headings */
.rf-how-title,
.rf-res-title,
.rf-who-title,
.rf-pricing-title,
.rfgs-title {
  letter-spacing: -0.04em;
}

/* Hero heading tighter tracking to match premium standard */
.rf-hero-shell h1,
.rf-hero-title {
  letter-spacing: -0.05em;
}

/* Pricing tier cards — add hover lift for premium interactivity */
.rfc-card {
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.rfc-card:hover {
  box-shadow: 0 8px 40px rgba(51, 12, 110, 0.12) !important;
  transform: translateY(-2px);
}

/* rf-step cards in how-it-works — add hover lift too */
.rf-step {
  transition: box-shadow 0.22s ease, transform 0.22s ease;
}

.rf-step:hover {
  box-shadow: 0 6px 30px rgba(51, 12, 110, 0.10) !important;
  transform: translateY(-2px);
}

/* ── 4. MOBILE TIGHTENING (390px) ───────────────────────────────
   Hero padding reduced on small screens so content isn't
   pushed too far below the nav (which collapses on mobile).
──────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .rf-hero {
    padding-top: 120px !important;
  }

  html {
    scroll-padding-top: 120px !important;
  }

  #how-it-works,
  #results,
  #who,
  #tiers,
  #rfgs-final {
    scroll-margin-top: 120px;
  }

  .rfgs-step {
    padding: 16px !important;
  }
}

/* ============================================================
   END RF GROWTH SYSTEM POLISH PASS
   ============================================================ */


/* =========================================================
   RF CONNECTS — COMPREHENSIVE NAV + HERO FIX  |  2026-03-25
   =========================================================
   Fixes applied:
   1.  Glass nav pill: backdrop-filter moved to ::before
       (backdrop-filter on element creates CSS containing
        block that traps position:fixed children — browser spec)
   2.  Mobile overlay: override display:none → visibility+
       transform for GPU-accelerated slide animation
   3.  X close button: properly positioned top-right
   4.  Desktop nav links: scoped to desktop, no bleed from overlay
   5.  Hero: photo extends behind nav, buttons row on desktop,
       content padding clears fixed nav height
   ========================================================= */

/* ── 1. GLASS NAV PILL: Move backdrop-filter to ::before ──
   backdrop-filter on the .wp-block-columns creates a new
   CSS containing block for all position:fixed descendants.
   Moving it to ::before preserves the glass effect without
   trapping the fullscreen nav overlay inside the pill.     */
.rfnav-sticky-wrapper .wp-block-columns {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.rfnav-sticky-wrapper .wp-block-columns::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 100px;
  backdrop-filter: blur(28px) saturate(2);
  -webkit-backdrop-filter: blur(28px) saturate(2);
  z-index: 0;
  pointer-events: none;
}
.rfnav-sticky-wrapper .wp-block-columns > * {
  position: relative;
  z-index: 1;
}

/* ── 2. MOBILE OVERLAY: GPU-animated full-screen slide ────
   WP sets display:none on closed container — this skips
   CSS transitions entirely. Fix: always display:flex, use
   visibility (instant) + transform (animated) instead.    */
@media (max-width: 767px) {
  .wp-block-navigation__responsive-container {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    z-index: 99999 !important;
    overflow-y: auto !important;
    /* Hidden state: off-screen left, invisible */
    visibility: hidden !important;
    transform: translateX(-100%) !important;
    will-change: transform;
    /* Slide + delay visibility until slide is done on close */
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
                visibility 0s linear 0.35s !important;
    /* Premium dark overlay */
    background: rgba(15, 4, 30, 0.97) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
  }

  /* ── OPEN: slide in + instant visibility ── */
  .wp-block-navigation__responsive-container.is-menu-open {
    visibility: visible !important;
    transform: translateX(0) !important;
    /* visibility fires immediately on open, delayed on close */
    transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
                visibility 0s linear 0s !important;
  }

  /* ── 3. X CLOSE BUTTON: top-right, not clipped ── */
  .wp-block-navigation__responsive-container-close {
    position: fixed !important;
    top: 24px !important;
    right: 20px !important;
    left: auto !important;
    bottom: auto !important;
    z-index: 100001 !important;
    color: #fff !important;
    background: rgba(255, 255, 255, 0.10) !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
    border-radius: 50% !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer;
    padding: 0 !important;
  }

  /* ── OVERLAY NAV LINK CONTENT ── */
  .wp-block-navigation__responsive-container-content {
    width: 100% !important;
    padding: 80px 24px 40px !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
  }

  .wp-block-navigation__responsive-container .wp-block-navigation-item__content {
    font-size: clamp(28px, 9vw, 46px) !important;
    font-weight: 800 !important;
    text-align: center !important;
    color: #fff !important;
    letter-spacing: -0.02em !important;
    line-height: 1.15 !important;
    padding: 8px 0 !important;
    width: 100% !important;
    display: block !important;
  }
}

/* ── 4. DESKTOP NAV LINKS: scope to ≥768px ────────────── */
@media (min-width: 768px) {
  /* Lock desktop inline nav links at correct size */
  .wp-block-navigation:not(.has-background) a.wp-block-navigation-item__content {
    font-size: 15px !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
  }
}

/* ── CLOSE BTN VISIBILITY FIX: beat WP core display:none + visibility:hidden ──
   WP core nav stylesheet hides the button by default. Need both display AND
   visibility overrides. Using .is-menu-open parent for max specificity.       */
@media (max-width: 767px) {
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-close,
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-dialog
    .wp-block-navigation__responsive-container-close {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: fixed !important;
    top: 24px !important;
    right: 20px !important;
    left: auto !important;
    bottom: auto !important;
    z-index: 100001 !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: rgba(51, 12, 110, 0.12) !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    color: #fff !important;
    cursor: pointer;
    padding: 0 !important;
    box-sizing: border-box !important;
  }

  /* Dialog wrapper must not clip or hide children */
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-dialog {
    display: flex !important;
    visibility: visible !important;
    overflow: visible !important;
  }

  /* Dialog wrapper: icon colour */
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-close svg {
    fill: currentColor !important;
    color: #330C6E !important;
  }
}

/* ── CLOSE BTN FINAL FIX: Remove backdrop-filter from container
   (backdrop-filter creates CSS containing block that traps position:fixed
   children). Container already has solid bg — no blur needed.
   Switch close button to position:absolute since container = viewport.  */
@media (max-width: 767px) {
  /* Strip the backdrop-filter I accidentally added to the container */
  .wp-block-navigation__responsive-container {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Now the container is safe — use absolute positioning for close btn
     (container is 100vw x 100dvh so absolute = same as fixed visually) */
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-close,
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-dialog
    .wp-block-navigation__responsive-container-close {
    position: absolute !important;
    top: 24px !important;
    right: 20px !important;
    left: auto !important;
    bottom: auto !important;
    display: flex !important;
    visibility: visible !important;
    z-index: 100 !important;
  }
}

/* ── CLOSE BTN FINAL FIX: inset:0 (no 100vw scrollbar overflow), absolute btn ── */
@media (max-width: 767px) {
  /* inset:0 fills viewport exactly without scrollbar-width overflow */
  .wp-block-navigation__responsive-container {
    inset: 0 !important;
    width: auto !important;
    height: auto !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  /* Close button: absolute within the viewport-filling container */
  html body .wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-close,
  html body .wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-dialog
    .wp-block-navigation__responsive-container-close {
    position: absolute !important;
    top: 24px !important;
    right: 20px !important;
    left: auto !important;
    bottom: auto !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 100 !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,0.10) !important;
    border: 1px solid rgba(255,255,255,0.20) !important;
    color: #fff !important;
    cursor: pointer;
    padding: 0 !important;
    box-sizing: border-box !important;
  }
}

/* ── BACKDROP-FILTER TRAP ROOT FIX: match .is-menu-open specificity ── */
@media (max-width: 767px) {
  /* Override the original theme rule that traps fixed children inside the pill */
  .wp-block-navigation__responsive-container.is-menu-open {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    /* Also ensure it fills the viewport via inset:0 not width:100vw */
    inset: 0 !important;
    width: auto !important;
    height: auto !important;
    /* Dark overlay background */
    background: rgba(15, 4, 30, 0.97) !important;
  }
  /* Close button: absolute within viewport-filling container, fully on-screen */
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-container-close,
  .wp-block-navigation__responsive-container.is-menu-open
    .wp-block-navigation__responsive-dialog
    .wp-block-navigation__responsive-container-close {
    position: absolute !important;
    top: 24px !important;
    right: 20px !important;
    left: auto !important;
    bottom: auto !important;
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    z-index: 100 !important;
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50% !important;
    background: rgba(255,255,255,0.10) !important;
    border: 1px solid rgba(255,255,255,0.20) !important;
    color: #fff !important;
    cursor: pointer;
    padding: 0 !important;
    box-sizing: border-box !important;
  }
}