/* =============================================================
   Vooyfarma Doctores 2026 — Main stylesheet
   Clinical editorial + 21st.dev-style motion
   2026-04-30: Unified type set to Montserrat (all elements).
   ============================================================= */

/* Belt-and-suspenders: Montserrat applied to every element under .vfd-body.
   Overrides any inherited Elementor / parent-theme font declarations. */
.vfd-body,
.vfd-body *,
.vfd-body *::before,
.vfd-body *::after {
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif !important;
}
.vfd-body input,
.vfd-body select,
.vfd-body textarea,
.vfd-body button {
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif !important;
}

/* Safety net: ensure Solicitar cotización primary buttons always render white text. */
.vfd-body .vfd-btn--primary,
.vfd-body .vfd-btn--primary:link,
.vfd-body .vfd-btn--primary:visited,
.vfd-body .vfd-btn--primary:hover,
.vfd-body .vfd-btn--primary:focus,
.vfd-body .vfd-btn--primary:active {
  color: #ffffff !important;
}

/* ---------- 1. Design Tokens -------------------------------- */
:root {
  /* Brand */
  --vf-primary-900: #062949;
  --vf-primary-800: #0A3D62;
  --vf-primary-700: #0F5487;
  --vf-primary-600: #1B6FB3;
  --vf-primary-500: #2B8AD1;
  --vf-primary-400: #55A7E0;
  --vf-primary-300: #8DC6EC;
  --vf-primary-100: #E6F2FB;
  --vf-primary-50:  #F4F9FD;

  --vf-teal-700:  #0D8C7F;
  --vf-teal-500:  #14B8A6;
  --vf-teal-400:  #2DD4BF;
  --vf-teal-300:  #5EEAD4;
  --vf-cyan:      #67E8F9;

  --vf-coral:     #FF6B6B;
  --vf-coral-50:  #FFF1F1;

  /* Neutrals */
  --vf-ink-950: #060B17;
  --vf-ink-900: #0F172A;
  --vf-ink-800: #1E293B;
  --vf-ink-700: #334155;
  --vf-ink-600: #475569;
  --vf-ink-500: #64748B;
  --vf-ink-400: #94A3B8;
  --vf-ink-300: #CBD5E1;
  --vf-ink-200: #E2E8F0;
  --vf-ink-100: #F1F5F9;
  --vf-bone:    #FAFBFC;
  --vf-white:   #FFFFFF;

  --vf-success: #10B981;
  --vf-warn:    #F59E0B;

  /* Type — Montserrat everywhere (April 2026 unified type pivot). */
  --vf-font-display: "Montserrat", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --vf-font-body:    "Montserrat", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --vf-font-mono:    "Montserrat", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Shadows */
  --vf-shadow-xs: 0 1px 2px rgba(10, 61, 98, .06);
  --vf-shadow-sm: 0 2px 8px rgba(10, 61, 98, .06), 0 1px 2px rgba(10,61,98,.04);
  --vf-shadow-md: 0 8px 24px rgba(10, 61, 98, .08), 0 2px 6px rgba(10,61,98,.04);
  --vf-shadow-lg: 0 20px 50px rgba(10, 61, 98, .12), 0 6px 12px rgba(10,61,98,.05);
  --vf-shadow-glow: 0 0 0 1px rgba(27, 111, 179, .14), 0 12px 40px -8px rgba(27, 111, 179, .35);
  --vf-shadow-glow-teal: 0 0 0 1px rgba(20, 184, 166, .18), 0 12px 40px -6px rgba(20, 184, 166, .45);

  /* Radius */
  --vf-r-xs: 8px;
  --vf-r-sm: 12px;
  --vf-r-md: 16px;
  --vf-r-lg: 24px;
  --vf-r-xl: 32px;
  --vf-r-2xl: 44px;
  --vf-r-full: 9999px;

  /* Spacing */
  --vf-container: 1240px;
  --vf-gutter: clamp(18px, 4vw, 36px);

  /* Easing */
  --vf-ease: cubic-bezier(.22,.61,.36,1);
  --vf-ease-out: cubic-bezier(.16,1,.3,1);
  --vf-ease-bounce: cubic-bezier(.68,-0.55,.27,1.55);
}

/* ---------- 2. Reset + globals ------------------------------ */
.vfd-body,
.vfd-body * { box-sizing: border-box; }

.vfd-body {
  margin: 0;
  padding: 0;
  font-family: var(--vf-font-body);
  font-size: 16px;
  line-height: 1.6;
  color: var(--vf-ink-800);
  background: var(--vf-bone);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* kill hello-elementor defaults that might leak */
.vfd-body.elementor-default .site-header,
.vfd-body.elementor-default .site-footer { display: none !important; }
.vfd-body .page-content > .entry-content { margin: 0; padding: 0; }
.vfd-body .entry-content > * { margin: 0; }

.vfd-body img { max-width: 100%; height: auto; display: block; }
.vfd-body a { color: var(--vf-primary-600); text-decoration: none; transition: color .2s var(--vf-ease); }
.vfd-body a:hover { color: var(--vf-primary-800); }

.vfd-body h1,.vfd-body h2,.vfd-body h3,.vfd-body h4 {
  font-family: var(--vf-font-display);
  color: var(--vf-ink-900);
  letter-spacing: -0.02em;
  line-height: 1.08;
  margin: 0 0 .5em;
  font-weight: 700;
}
.vfd-body h1 { font-size: clamp(38px, 6vw, 76px); letter-spacing: -0.035em; font-weight: 700; }
.vfd-body h2 { font-size: clamp(30px, 4.2vw, 52px); letter-spacing: -0.028em; }
.vfd-body h3 { font-size: clamp(22px, 2.6vw, 30px); }
.vfd-body h4 { font-size: clamp(18px, 1.8vw, 22px); }
.vfd-body p { margin: 0 0 1em; color: var(--vf-ink-700); }

.vfd-container { width: 100%; max-width: var(--vf-container); margin: 0 auto; padding: 0 var(--vf-gutter); }

.vfd-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--vf-font-mono);
  font-size: 12px; letter-spacing: .18em; text-transform: uppercase;
  color: var(--vf-primary-700); font-weight: 500;
  padding: 6px 12px; border-radius: var(--vf-r-full);
  background: var(--vf-primary-50);
  border: 1px solid var(--vf-primary-100);
}
.vfd-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--vf-teal-500); box-shadow: 0 0 0 3px rgba(20,184,166,.22); animation: vfd-pulse 2s infinite; }
@keyframes vfd-pulse { 0%,100% { transform: scale(1); opacity: 1;} 50% { transform: scale(1.4); opacity: .6;} }

.vfd-section { padding: clamp(72px, 10vw, 140px) 0; position: relative; }
.vfd-section-tight { padding: clamp(48px, 7vw, 96px) 0; }
.vfd-section-head { text-align: center; max-width: 760px; margin: 0 auto clamp(48px, 6vw, 80px); }
.vfd-section-head p { font-size: 19px; color: var(--vf-ink-600); margin-top: 18px; }

/* gradient text */
.vfd-grad {
  background: linear-gradient(135deg, var(--vf-primary-700) 0%, var(--vf-primary-500) 30%, var(--vf-teal-500) 65%, var(--vf-cyan) 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}

/* ---------- 3. Buttons -------------------------------------- */
.vfd-btn {
  --btn-fg: #fff;
  --btn-bg: var(--vf-primary-700);
  position: relative;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 16px 26px;
  border-radius: var(--vf-r-full);
  background: var(--btn-bg);
  color: var(--btn-fg);
  font-family: var(--vf-font-body);
  font-weight: 600;
  font-size: 15.5px;
  letter-spacing: -0.005em;
  border: 0; cursor: pointer;
  transition: transform .3s var(--vf-ease), box-shadow .3s var(--vf-ease), background .3s var(--vf-ease);
  box-shadow: 0 10px 30px -10px rgba(10,61,98,.55), inset 0 1px 0 rgba(255,255,255,.2);
  text-decoration: none;
  overflow: hidden;
  isolation: isolate;
  white-space: nowrap;
}
.vfd-btn:hover { transform: translateY(-2px); box-shadow: 0 18px 40px -12px rgba(10,61,98,.55), 0 0 0 1px rgba(255,255,255,.18) inset; color: #fff; }
.vfd-btn:active { transform: translateY(0); }

.vfd-btn--primary { --btn-bg: linear-gradient(135deg, var(--vf-primary-800) 0%, var(--vf-primary-600) 55%, var(--vf-teal-500) 130%); }
.vfd-btn--teal    { --btn-bg: linear-gradient(135deg, var(--vf-teal-700) 0%, var(--vf-teal-500) 100%); box-shadow: 0 10px 30px -10px rgba(20,184,166,.55); }
.vfd-btn--ghost {
  --btn-fg: var(--vf-primary-800);
  background: #fff; border: 1px solid var(--vf-ink-200);
  box-shadow: var(--vf-shadow-sm);
}
.vfd-btn--ghost:hover { color: var(--vf-primary-900); border-color: var(--vf-primary-300); }
.vfd-btn--sm { padding: 11px 18px; font-size: 14px; }
.vfd-btn--lg { padding: 20px 32px; font-size: 17px; }

/* Sheen effect */
.vfd-btn::after {
  content:""; position:absolute; inset:0; z-index:-1;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.45) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .9s var(--vf-ease-out);
}
.vfd-btn:hover::after { transform: translateX(100%); }

.vfd-btn__arrow { width: 18px; height: 18px; transition: transform .3s var(--vf-ease); }
.vfd-btn:hover .vfd-btn__arrow { transform: translateX(4px); }

/* ---------- 4. Nav ------------------------------------------ */
.vfd-nav {
  position: fixed; top: 14px; left: 50%; transform: translateX(-50%);
  z-index: 1000;
  width: calc(100% - 28px);
  max-width: 1280px;
  padding: 10px 14px 10px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  background: rgba(255,255,255,.75);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border: 1px solid rgba(255,255,255,.8);
  box-shadow: 0 1px 0 rgba(10,61,98,.04), 0 20px 50px -20px rgba(10,61,98,.18);
  border-radius: var(--vf-r-full);
  transition: top .3s var(--vf-ease), box-shadow .3s var(--vf-ease), background .3s var(--vf-ease);
}
.vfd-nav.is-scrolled { top: 10px; background: rgba(255,255,255,.9); box-shadow: 0 1px 0 rgba(10,61,98,.06), 0 22px 60px -20px rgba(10,61,98,.22); }
.vfd-nav__logo {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--vf-font-display); font-weight: 700; font-size: 20px;
  color: var(--vf-primary-900); text-decoration: none;
  letter-spacing: -0.02em;
}
.vfd-nav__logo-mark {
  width: 34px; height: 34px; border-radius: 11px;
  background: linear-gradient(135deg, var(--vf-primary-700) 0%, var(--vf-teal-500) 100%);
  display: grid; place-items: center;
  box-shadow: 0 6px 18px -6px rgba(27,111,179,.55);
}
.vfd-nav__logo-mark svg { width: 18px; height: 18px; color: #fff; }
.vfd-nav__links { display: flex; align-items: center; gap: 4px; }
.vfd-nav__links a {
  padding: 9px 14px; border-radius: var(--vf-r-full);
  color: var(--vf-ink-700); font-weight: 500; font-size: 14.5px;
  transition: background .2s var(--vf-ease), color .2s var(--vf-ease);
}
.vfd-nav__links a:hover { background: var(--vf-primary-50); color: var(--vf-primary-800); }

.vfd-nav__cta { display: inline-flex; }
.vfd-nav__toggle { display: none; background:none; border:0; cursor:pointer; padding:10px; color: var(--vf-ink-800); }
.vfd-nav__toggle svg { width: 22px; height: 22px; }

@media (max-width: 880px) {
  .vfd-nav__links { display: none; position: absolute; top: calc(100% + 10px); left: 0; right: 0;
    background: #fff; border: 1px solid var(--vf-ink-100); border-radius: var(--vf-r-lg);
    padding: 14px; flex-direction: column; align-items: stretch; gap: 2px;
    box-shadow: var(--vf-shadow-lg);
  }
  .vfd-nav__links.is-open { display: flex; }
  .vfd-nav__toggle { display: inline-flex; }
  .vfd-nav__cta .vfd-btn { padding: 10px 14px; font-size: 13.5px; }
}

/* ---------- 5. Hero ----------------------------------------- */
.vfd-hero {
  position: relative;
  padding: clamp(120px, 16vw, 180px) 0 clamp(60px, 8vw, 120px);
  overflow: hidden;
  isolation: isolate;
}

/* Aurora mesh background */
.vfd-aurora {
  position: absolute; inset: -10%; z-index: -2;
  background:
    radial-gradient(40% 50% at 20% 20%, rgba(103, 232, 249, .35) 0%, transparent 60%),
    radial-gradient(45% 55% at 80% 10%, rgba(20, 184, 166, .28) 0%, transparent 65%),
    radial-gradient(55% 65% at 60% 75%, rgba(27, 111, 179, .32) 0%, transparent 65%),
    radial-gradient(35% 40% at 15% 80%, rgba(255, 107, 107, .14) 0%, transparent 60%);
  filter: blur(40px) saturate(1.1);
  animation: vfd-aurora-move 22s var(--vf-ease) infinite;
}
@keyframes vfd-aurora-move {
  0%,100% { transform: translate3d(0,0,0) scale(1); }
  33% { transform: translate3d(4%, -3%, 0) scale(1.06); }
  66% { transform: translate3d(-3%, 3%, 0) scale(.98); }
}
.vfd-grid-bg {
  position: absolute; inset: 0; z-index: -1;
  background-image:
    linear-gradient(to right, rgba(10,61,98,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,61,98,.05) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 85%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 40%, transparent 85%);
}

.vfd-hero__grid {
  display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr);
  gap: clamp(30px, 5vw, 72px);
  align-items: center;
}
@media (max-width: 960px) { .vfd-hero__grid { grid-template-columns: 1fr; } }

.vfd-hero__kicker {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px 8px 10px; border-radius: var(--vf-r-full);
  background: #fff; border: 1px solid var(--vf-ink-200);
  box-shadow: var(--vf-shadow-sm);
  font-size: 13.5px; color: var(--vf-ink-700);
  margin-bottom: 26px;
}
.vfd-hero__kicker strong { color: var(--vf-primary-800); }
.vfd-hero__kicker .pill {
  font-family: var(--vf-font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase;
  padding: 3px 9px; border-radius: var(--vf-r-full);
  background: linear-gradient(135deg, var(--vf-primary-700), var(--vf-teal-500));
  color: #fff; font-weight: 600;
}

.vfd-hero h1 { margin-bottom: 22px; }
.vfd-hero__sub { font-size: clamp(17px, 1.6vw, 20px); color: var(--vf-ink-600); max-width: 580px; margin-bottom: 36px; }
.vfd-hero__cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; margin-bottom: 42px; }
.vfd-hero__note { font-size: 13.5px; color: var(--vf-ink-500); display: flex; align-items: center; gap: 8px; }
.vfd-hero__note svg { width: 16px; height: 16px; color: var(--vf-teal-500); flex: none; }

.vfd-hero__trust { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.vfd-hero__trust-avatars { display: flex; }
.vfd-hero__trust-avatars img {
  width: 38px; height: 38px; border-radius: 50%; object-fit: cover;
  border: 2.5px solid #fff; box-shadow: 0 4px 10px rgba(10,61,98,.15);
  margin-left: -10px;
}
.vfd-hero__trust-avatars img:first-child { margin-left: 0; }
.vfd-hero__trust-text { font-size: 13.5px; color: var(--vf-ink-600); }
.vfd-hero__trust-text strong { color: var(--vf-ink-900); }
.vfd-hero__trust-stars { color: #F59E0B; font-size: 14px; letter-spacing: 1px; }

/* Hero visual */
.vfd-hero__visual { position: relative; height: 100%; min-height: 420px; }
.vfd-hero__image {
  position: relative; z-index: 2;
  width: 100%; aspect-ratio: 4/5; object-fit: cover;
  border-radius: var(--vf-r-2xl);
  box-shadow: 0 40px 80px -30px rgba(10,61,98,.35), 0 0 0 1px rgba(255,255,255,.6);
  animation: vfd-float 7s ease-in-out infinite;
}
@keyframes vfd-float { 0%,100% { transform: translateY(0);} 50% { transform: translateY(-14px);} }

.vfd-hero__card {
  position: absolute; z-index: 3;
  background: rgba(255,255,255,.9);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.8);
  border-radius: var(--vf-r-lg);
  padding: 16px 18px;
  box-shadow: 0 20px 50px -10px rgba(10,61,98,.2);
  display: flex; align-items: center; gap: 12px;
  font-size: 14px;
}
.vfd-hero__card--1 { left: -28px; top: 18%; animation: vfd-float 6s ease-in-out infinite; }
.vfd-hero__card--2 { right: -24px; bottom: 14%; animation: vfd-float 8s ease-in-out infinite reverse; }
.vfd-hero__card-icon {
  width: 40px; height: 40px; border-radius: 12px;
  display: grid; place-items: center;
  background: linear-gradient(135deg, var(--vf-primary-700), var(--vf-teal-500));
  color: #fff; flex: none;
}
.vfd-hero__card-icon svg { width: 20px; height: 20px; }
.vfd-hero__card strong { display: block; color: var(--vf-ink-900); font-weight: 700; }
.vfd-hero__card small { color: var(--vf-ink-500); font-size: 12.5px; }

@media (max-width: 960px) {
  .vfd-hero__visual { min-height: 360px; }
  .vfd-hero__card--1 { left: 8px; }
  .vfd-hero__card--2 { right: 8px; }
}

/* ---------- 6. Marquee / Logos ------------------------------ */
.vfd-marquee {
  overflow: hidden; position: relative;
  padding: 36px 0; border-top: 1px solid var(--vf-ink-100); border-bottom: 1px solid var(--vf-ink-100);
  background: #fff;
  mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 12%, #000 88%, transparent);
}
.vfd-marquee__label {
  text-align: center; font-family: var(--vf-font-mono);
  font-size: 11.5px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--vf-ink-500); margin-bottom: 22px;
}
.vfd-marquee__track { display: flex; width: max-content; gap: 64px; animation: vfd-scroll 40s linear infinite; }
.vfd-marquee__item { display: flex; align-items: center; gap: 8px; color: var(--vf-ink-600); font-weight: 600; font-size: 16px; white-space: nowrap; }
.vfd-marquee__item svg { width: 22px; height: 22px; color: var(--vf-primary-500); }
@keyframes vfd-scroll { from { transform: translateX(0);} to { transform: translateX(-50%);} }

/* ---------- 7. Stats strip --------------------------------- */
.vfd-stats {
  background: linear-gradient(180deg, #fff 0%, var(--vf-primary-50) 100%);
  border-top: 1px solid var(--vf-ink-100);
}
.vfd-stats__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  background: #fff; border-radius: var(--vf-r-xl); padding: 10px;
  box-shadow: var(--vf-shadow-md);
  border: 1px solid var(--vf-ink-100);
}
.vfd-stat { padding: 28px 24px; text-align: center; position: relative; }
.vfd-stat + .vfd-stat::before {
  content: ""; position: absolute; left: 0; top: 20%; bottom: 20%; width: 1px;
  background: var(--vf-ink-100);
}
.vfd-stat__value {
  font-family: var(--vf-font-display);
  font-size: clamp(36px, 4.8vw, 54px); font-weight: 700;
  letter-spacing: -0.03em; line-height: 1;
  background: linear-gradient(135deg, var(--vf-primary-800) 0%, var(--vf-teal-500) 100%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.vfd-stat__label { margin-top: 10px; color: var(--vf-ink-600); font-size: 14.5px; }
@media (max-width: 860px) {
  .vfd-stats__grid { grid-template-columns: repeat(2, 1fr); }
  .vfd-stat:nth-child(3)::before, .vfd-stat:nth-child(odd)::before { display: none; }
}

/* ---------- 8. Problem section ------------------------------ */
.vfd-problem { background: var(--vf-bone); }
.vfd-problem__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px;
}
@media (max-width: 880px) { .vfd-problem__grid { grid-template-columns: 1fr; } }

.vfd-card {
  position: relative; padding: 34px 30px; border-radius: var(--vf-r-lg);
  background: #fff; border: 1px solid var(--vf-ink-100);
  box-shadow: var(--vf-shadow-xs);
  transition: transform .5s var(--vf-ease-out), box-shadow .5s var(--vf-ease-out), border-color .5s var(--vf-ease);
  overflow: hidden;
}
.vfd-card::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(400px circle at var(--mx, 50%) var(--my, 50%), rgba(27,111,179,.08), transparent 40%);
  opacity: 0; transition: opacity .5s var(--vf-ease);
  pointer-events: none;
}
.vfd-card:hover { transform: translateY(-4px); box-shadow: var(--vf-shadow-lg); border-color: var(--vf-primary-200, #D0E4F5); }
.vfd-card:hover::before { opacity: 1; }

.vfd-card__icon {
  width: 54px; height: 54px; border-radius: 16px;
  display: grid; place-items: center; margin-bottom: 20px;
  background: linear-gradient(135deg, var(--vf-primary-100), #fff);
  color: var(--vf-primary-700); border: 1px solid var(--vf-primary-100);
}
.vfd-card__icon svg { width: 26px; height: 26px; }
.vfd-card h3 { margin-bottom: 10px; }
.vfd-card p { margin: 0; color: var(--vf-ink-600); }

/* ---------- 9. How it works -------------------------------- */
.vfd-steps { position: relative; background: #fff; }
.vfd-steps__grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; position: relative;
}
.vfd-steps__line {
  position: absolute; top: 56px; left: 7%; right: 7%; height: 2px;
  background: linear-gradient(90deg, var(--vf-primary-200, #CEE3F3), var(--vf-teal-300));
  z-index: 0;
  opacity: .7;
}
@media (max-width: 960px) { .vfd-steps__grid { grid-template-columns: 1fr 1fr; } .vfd-steps__line { display:none; } }
@media (max-width: 560px) { .vfd-steps__grid { grid-template-columns: 1fr; } }
.vfd-step { position: relative; z-index: 1; text-align: center; padding: 0 8px; }
.vfd-step__num {
  width: 54px; height: 54px; border-radius: 50%; margin: 0 auto 20px;
  background: #fff; border: 2px solid var(--vf-primary-700);
  display: grid; place-items: center;
  color: var(--vf-primary-800);
  font-family: var(--vf-font-display); font-weight: 700; font-size: 22px;
  box-shadow: 0 10px 24px -8px rgba(27,111,179,.35);
  transition: transform .4s var(--vf-ease-bounce);
}
.vfd-step:hover .vfd-step__num { transform: scale(1.1) rotate(-6deg); }
.vfd-step h4 { margin-bottom: 8px; font-family: var(--vf-font-display); font-size: 19px; }
.vfd-step p { color: var(--vf-ink-600); font-size: 15px; margin: 0; }

/* ---------- 10. Price comparison --------------------------- */
.vfd-price {
  background:
    linear-gradient(180deg, var(--vf-primary-50), #fff),
    radial-gradient(ellipse at top, rgba(20,184,166,.1), transparent 70%);
  position: relative;
}
.vfd-price__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px;
  max-width: 980px; margin: 0 auto;
}
@media (max-width: 780px) { .vfd-price__grid { grid-template-columns: 1fr; } }
.vfd-price__col {
  padding: 36px 32px; border-radius: var(--vf-r-xl);
  background: #fff; border: 1px solid var(--vf-ink-100);
  box-shadow: var(--vf-shadow-sm);
  position: relative;
}
.vfd-price__col--accent {
  background: linear-gradient(180deg, #052842 0%, #0A3D62 70%);
  color: #fff; border-color: transparent;
  box-shadow: 0 30px 60px -20px rgba(10,61,98,.5), 0 0 0 1px rgba(20,184,166,.3) inset;
  transform: scale(1.02);
}
.vfd-price__tag {
  display: inline-block; padding: 5px 12px; border-radius: var(--vf-r-full);
  background: var(--vf-ink-100); color: var(--vf-ink-700);
  font-family: var(--vf-font-mono); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase;
  margin-bottom: 14px; font-weight: 500;
}
.vfd-price__col--accent .vfd-price__tag { background: rgba(20,184,166,.2); color: var(--vf-teal-300); }
.vfd-price__col h3 { margin-bottom: 8px; font-size: 22px; }
.vfd-price__col--accent h3 { color: #fff; }
.vfd-price__col p { font-size: 14.5px; color: var(--vf-ink-500); margin-bottom: 20px; }
.vfd-price__col--accent p { color: rgba(255,255,255,.7); }

.vfd-price__row { display: flex; justify-content: space-between; align-items: baseline; padding: 12px 0; border-top: 1px solid var(--vf-ink-100); font-size: 14.5px; }
.vfd-price__col--accent .vfd-price__row { border-color: rgba(255,255,255,.08); }
.vfd-price__row:first-of-type { border-top: 0; }
.vfd-price__row span { color: var(--vf-ink-600); }
.vfd-price__col--accent .vfd-price__row span { color: rgba(255,255,255,.65); }
.vfd-price__row strong { font-family: var(--vf-font-mono); font-size: 15.5px; color: var(--vf-ink-900); font-weight: 600; }
.vfd-price__col--accent .vfd-price__row strong { color: #fff; }
.vfd-price__total { margin-top: 18px; padding-top: 18px; border-top: 2px solid currentColor !important; display: flex; justify-content: space-between; align-items: baseline; }
.vfd-price__total-label { font-weight: 600; font-size: 15px; }
.vfd-price__total-value { font-family: var(--vf-font-display); font-weight: 700; font-size: 34px; letter-spacing: -0.02em; }
.vfd-price__col--accent .vfd-price__total-value {
  background: linear-gradient(135deg, var(--vf-teal-300), var(--vf-cyan));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.vfd-price__savings {
  margin-top: 16px; padding: 12px; border-radius: var(--vf-r-sm);
  background: rgba(20,184,166,.15); border: 1px dashed rgba(20,184,166,.4);
  text-align: center; font-size: 14px; color: var(--vf-teal-300); font-weight: 600;
}
.vfd-price__savings strong { font-family: var(--vf-font-mono); }

/* ---------- 11. Catalog ------------------------------------ */
.vfd-cat { background: var(--vf-bone); }
.vfd-cat__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 1100px) { .vfd-cat__grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 800px)  { .vfd-cat__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .vfd-cat__grid { grid-template-columns: 1fr; } }

.vfd-med {
  position: relative; padding: 24px; border-radius: var(--vf-r-lg);
  background: #fff; border: 1px solid var(--vf-ink-100);
  transition: transform .4s var(--vf-ease-out), box-shadow .4s var(--vf-ease), border-color .4s var(--vf-ease);
  overflow: hidden;
}
.vfd-med:hover { transform: translateY(-4px); box-shadow: var(--vf-shadow-glow); border-color: transparent; }
.vfd-med__badge {
  position: absolute; top: 18px; right: 18px;
  padding: 4px 10px; border-radius: var(--vf-r-full);
  font-size: 11px; font-family: var(--vf-font-mono); font-weight: 500;
  letter-spacing: .08em; text-transform: uppercase;
  background: rgba(16,185,129,.12); color: #047857;
}
.vfd-med__badge--new { background: rgba(103,232,249,.25); color: #0891B2; }
.vfd-med__icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: linear-gradient(135deg, var(--vf-primary-100), var(--vf-teal-300, #5EEAD4) 100%);
  opacity: .65;
  display: grid; place-items: center; color: var(--vf-primary-800);
  margin-bottom: 18px;
}
.vfd-med__icon svg { width: 22px; height: 22px; }
.vfd-med h4 { font-family: var(--vf-font-display); font-size: 18px; margin-bottom: 4px; color: var(--vf-ink-900); }
.vfd-med__desc { font-size: 13.5px; color: var(--vf-ink-500); margin-bottom: 16px; min-height: 38px; }
.vfd-med__foot { display: flex; justify-content: space-between; align-items: baseline; padding-top: 14px; border-top: 1px solid var(--vf-ink-100); }
.vfd-med__foot span { font-size: 12px; color: var(--vf-ink-500); font-family: var(--vf-font-mono); letter-spacing: .06em; text-transform: uppercase; }
.vfd-med__foot strong { font-family: var(--vf-font-display); font-size: 19px; color: var(--vf-primary-800); font-weight: 700; }

/* ---------- 12. Features (bento) --------------------------- */
.vfd-features { background: #fff; }
.vfd-bento {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px;
  grid-auto-rows: minmax(210px, auto);
}
.vfd-bento__item {
  position: relative; padding: 30px; border-radius: var(--vf-r-lg);
  background: linear-gradient(165deg, #fff, var(--vf-primary-50));
  border: 1px solid var(--vf-ink-100);
  overflow: hidden; isolation: isolate;
  transition: transform .4s var(--vf-ease-out), box-shadow .4s var(--vf-ease);
}
.vfd-bento__item:hover { transform: translateY(-3px); box-shadow: var(--vf-shadow-md); }
.vfd-bento__item--lg { grid-column: span 3; grid-row: span 2; padding: 40px; background: linear-gradient(165deg, #0A3D62, #062949); color: #fff; }
.vfd-bento__item--md { grid-column: span 3; }
.vfd-bento__item--sm { grid-column: span 2; }
.vfd-bento__item--sm-3 { grid-column: span 2; }
@media (max-width: 980px) {
  .vfd-bento { grid-template-columns: repeat(2, 1fr); }
  .vfd-bento__item--lg,.vfd-bento__item--md,.vfd-bento__item--sm,.vfd-bento__item--sm-3 { grid-column: span 2; grid-row: auto; }
}

.vfd-bento__item h3 { color: var(--vf-ink-900); font-size: 22px; margin-bottom: 10px; }
.vfd-bento__item--lg h3 { color: #fff; font-size: clamp(26px, 3vw, 36px); }
.vfd-bento__item p { color: var(--vf-ink-600); font-size: 15px; margin: 0; }
.vfd-bento__item--lg p { color: rgba(255,255,255,.75); font-size: 16.5px; max-width: 440px; }

.vfd-bento__icon {
  width: 46px; height: 46px; border-radius: 13px;
  background: #fff; border: 1px solid var(--vf-ink-100);
  display: grid; place-items: center; color: var(--vf-primary-700);
  margin-bottom: 18px;
}
.vfd-bento__icon svg { width: 22px; height: 22px; }
.vfd-bento__item--lg .vfd-bento__icon {
  background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.15); color: var(--vf-cyan);
}

/* animated beam in large card */
.vfd-bento__beam {
  position: absolute; inset: -50% -20%;
  background:
    conic-gradient(from 180deg at 50% 50%, transparent 0deg, rgba(103,232,249,.15) 60deg, transparent 120deg);
  animation: vfd-spin 18s linear infinite; z-index: -1;
}
@keyframes vfd-spin { to { transform: rotate(360deg); } }

/* ---------- 13. Testimonials ------------------------------- */
.vfd-testi { background: var(--vf-bone); }
.vfd-testi__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 960px) { .vfd-testi__grid { grid-template-columns: 1fr; } }

.vfd-testi__card {
  position: relative; padding: 34px 30px; border-radius: var(--vf-r-lg);
  background: #fff; border: 1px solid var(--vf-ink-100);
  display: flex; flex-direction: column; gap: 20px;
  transition: transform .4s var(--vf-ease-out), box-shadow .4s var(--vf-ease);
}
.vfd-testi__card:hover { transform: translateY(-4px); box-shadow: var(--vf-shadow-lg); }

.vfd-testi__stars { color: #F59E0B; font-size: 15px; letter-spacing: 2px; }
.vfd-testi__quote { font-family: var(--vf-font-display); font-size: 18px; line-height: 1.45; color: var(--vf-ink-900); flex: 1; margin: 0; letter-spacing: -0.01em; }
.vfd-testi__author { display: flex; align-items: center; gap: 14px; padding-top: 18px; border-top: 1px solid var(--vf-ink-100); }
.vfd-testi__author img { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid #fff; box-shadow: 0 4px 10px rgba(10,61,98,.15); }
.vfd-testi__author strong { display: block; color: var(--vf-ink-900); font-weight: 700; font-size: 15px; }
.vfd-testi__author small { color: var(--vf-ink-500); font-size: 13px; }

/* ---------- 14. FAQ ---------------------------------------- */
.vfd-faq { background: #fff; }
.vfd-faq__wrap { max-width: 820px; margin: 0 auto; }
.vfd-faq__item {
  border: 1px solid var(--vf-ink-100); border-radius: var(--vf-r-md);
  margin-bottom: 12px; background: #fff;
  overflow: hidden; transition: border-color .3s, box-shadow .3s;
}
.vfd-faq__item.is-open { border-color: var(--vf-primary-300); box-shadow: var(--vf-shadow-md); }
.vfd-faq__q {
  width: 100%; background: none; border: 0; cursor: pointer;
  padding: 22px 24px;
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  font-family: var(--vf-font-display); font-size: 18px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--vf-ink-900); text-align: left;
  transition: color .3s;
}
.vfd-faq__q:hover { color: var(--vf-primary-800); }
.vfd-faq__plus { width: 28px; height: 28px; border-radius: 50%; background: var(--vf-primary-50); display: grid; place-items: center; flex: none; transition: background .3s, transform .3s; color: var(--vf-primary-700); }
.vfd-faq__plus svg { width: 14px; height: 14px; transition: transform .4s var(--vf-ease); }
.vfd-faq__item.is-open .vfd-faq__plus { background: var(--vf-primary-700); color: #fff; }
.vfd-faq__item.is-open .vfd-faq__plus svg { transform: rotate(45deg); }
.vfd-faq__a { max-height: 0; overflow: hidden; transition: max-height .5s var(--vf-ease-out); }
.vfd-faq__a-inner { padding: 0 24px 24px; color: var(--vf-ink-600); font-size: 16px; line-height: 1.6; }

/* ---------- 15. Final CTA ---------------------------------- */
.vfd-final {
  position: relative;
  background:
    radial-gradient(80% 80% at 50% 0%, rgba(103,232,249,.25), transparent 70%),
    radial-gradient(60% 80% at 80% 100%, rgba(20,184,166,.22), transparent 70%),
    linear-gradient(180deg, #041f3a 0%, #062949 50%, #0A3D62 100%);
  color: #fff; overflow: hidden; isolation: isolate;
}
.vfd-final::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, #000 30%, transparent 80%);
}
.vfd-final__inner { text-align: center; max-width: 780px; margin: 0 auto; position: relative; z-index: 1; }
.vfd-final h2 { color: #fff; margin-bottom: 18px; }
.vfd-final .vfd-grad { background: linear-gradient(135deg, #fff 0%, var(--vf-teal-300) 55%, var(--vf-cyan) 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.vfd-final p { color: rgba(255,255,255,.75); font-size: 18px; margin-bottom: 32px; }
.vfd-final .vfd-btn--primary {
  --btn-bg: linear-gradient(135deg, var(--vf-primary-700) 0%, var(--vf-teal-500) 100%);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(255,255,255,.2), 0 20px 50px -10px rgba(20,184,166,.55);
}
.vfd-final .vfd-btn--primary:hover { color: #fff; }
.vfd-final__note { margin-top: 18px; color: rgba(255,255,255,.5); font-size: 13.5px; }

/* ---------- 16. Footer -------------------------------------- */
.vfd-foot {
  background: #020814;
  color: rgba(255,255,255,.7);
  padding: 72px 0 32px;
  position: relative;
}
.vfd-foot__grid {
  display: grid; grid-template-columns: 1.3fr 1fr 1fr 1.3fr; gap: 48px;
  padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.08);
}
@media (max-width: 880px) { .vfd-foot__grid { grid-template-columns: 1fr 1fr; gap: 36px; } }
@media (max-width: 540px) { .vfd-foot__grid { grid-template-columns: 1fr; } }

.vfd-foot__logo { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; color: #fff; font-family: var(--vf-font-display); font-weight: 700; font-size: 22px; }
.vfd-foot__desc { font-size: 14.5px; max-width: 280px; color: rgba(255,255,255,.55); margin-bottom: 20px; }
.vfd-foot h5 { color: #fff; font-family: var(--vf-font-display); font-weight: 600; font-size: 14.5px; margin-bottom: 16px; letter-spacing: -0.005em; }
.vfd-foot ul { list-style: none; margin: 0; padding: 0; }
.vfd-foot li { margin-bottom: 10px; }
.vfd-foot a { color: rgba(255,255,255,.6); font-size: 14px; transition: color .2s; }
.vfd-foot a:hover { color: #fff; }
.vfd-foot__newsletter { display: flex; gap: 8px; }
.vfd-foot__newsletter input {
  flex: 1; padding: 12px 14px; border-radius: var(--vf-r-sm);
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1);
  color: #fff; font-family: inherit; font-size: 14px;
}
.vfd-foot__newsletter input::placeholder { color: rgba(255,255,255,.4); }
.vfd-foot__newsletter input:focus { outline: none; border-color: var(--vf-teal-400); }
.vfd-foot__newsletter button {
  padding: 12px 18px; border-radius: var(--vf-r-sm); border: 0; cursor: pointer;
  background: linear-gradient(135deg, var(--vf-teal-500), var(--vf-primary-500));
  color: #fff; font-weight: 600; font-size: 14px;
}
.vfd-foot__bottom { padding-top: 28px; display: flex; justify-content: space-between; gap: 20px; font-size: 13px; color: rgba(255,255,255,.4); flex-wrap: wrap; }
.vfd-foot__bottom a { color: rgba(255,255,255,.4); }
.vfd-foot__bottom a:hover { color: #fff; }

/* ---------- 17. Scroll reveal ------------------------------ */
[data-reveal] {
  opacity: 0; transform: translateY(24px);
  transition: opacity .9s var(--vf-ease-out), transform .9s var(--vf-ease-out);
}
[data-reveal].is-revealed { opacity: 1; transform: translateY(0); }
[data-reveal="left"] { transform: translateX(-24px); }
[data-reveal="left"].is-revealed { transform: translateX(0); }
[data-reveal="right"] { transform: translateX(24px); }
[data-reveal="right"].is-revealed { transform: translateX(0); }

/* stagger children */
[data-reveal-stagger] > * { opacity: 0; transform: translateY(20px); transition: opacity .75s var(--vf-ease-out), transform .75s var(--vf-ease-out); }
[data-reveal-stagger].is-revealed > *:nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0ms; }
[data-reveal-stagger].is-revealed > *:nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 80ms; }
[data-reveal-stagger].is-revealed > *:nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 160ms; }
[data-reveal-stagger].is-revealed > *:nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 240ms; }
[data-reveal-stagger].is-revealed > *:nth-child(5) { opacity: 1; transform: translateY(0); transition-delay: 320ms; }
[data-reveal-stagger].is-revealed > *:nth-child(6) { opacity: 1; transform: translateY(0); transition-delay: 400ms; }
[data-reveal-stagger].is-revealed > *:nth-child(7) { opacity: 1; transform: translateY(0); transition-delay: 480ms; }
[data-reveal-stagger].is-revealed > *:nth-child(8) { opacity: 1; transform: translateY(0); transition-delay: 560ms; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  .vfd-aurora, .vfd-bento__beam, .vfd-marquee__track, .vfd-hero__image { animation: none !important; }
}

/* ---------- 18. Registration & Thanks page ----------------- */
.vfd-page { padding: clamp(120px, 16vw, 160px) 0 80px; background: var(--vf-bone); min-height: 80vh; }
.vfd-page__wrap { max-width: 760px; margin: 0 auto; padding: clamp(36px, 5vw, 56px); background: #fff; border-radius: var(--vf-r-xl); box-shadow: var(--vf-shadow-md); border: 1px solid var(--vf-ink-100); }
.vfd-page h1 { font-size: clamp(32px, 4.4vw, 46px); margin-bottom: 14px; }
.vfd-page p.lead { font-size: 18px; color: var(--vf-ink-600); margin-bottom: 30px; }

.vfd-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.vfd-form__full { grid-column: 1 / -1; }
.vfd-form label { display: block; font-size: 13.5px; font-weight: 600; color: var(--vf-ink-800); margin-bottom: 6px; }
.vfd-form input, .vfd-form select, .vfd-form textarea {
  width: 100%; padding: 13px 14px; border-radius: var(--vf-r-sm);
  border: 1px solid var(--vf-ink-200); background: #fff; font-family: inherit; font-size: 15px;
  transition: border-color .25s, box-shadow .25s; color: var(--vf-ink-900);
}
.vfd-form input:focus, .vfd-form select:focus, .vfd-form textarea:focus { outline: none; border-color: var(--vf-primary-500); box-shadow: 0 0 0 4px rgba(27,111,179,.14); }
.vfd-form__check { display: flex; gap: 10px; align-items: start; font-size: 14px; color: var(--vf-ink-600); }
.vfd-form__check input { width: auto; margin-top: 3px; }
@media (max-width: 600px) { .vfd-form { grid-template-columns: 1fr; } }

.vfd-thanks__icon { width: 84px; height: 84px; margin: 0 auto 24px; border-radius: 50%; background: linear-gradient(135deg, var(--vf-teal-500), var(--vf-cyan)); display: grid; place-items: center; color: #fff; box-shadow: 0 20px 40px -10px rgba(20,184,166,.55); }
.vfd-thanks__icon svg { width: 40px; height: 40px; }
.vfd-thanks { text-align: center; }
.vfd-thanks ul { list-style: none; padding: 0; margin: 28px 0 30px; text-align: left; }
.vfd-thanks li { padding: 14px 16px; border-radius: var(--vf-r-sm); background: var(--vf-primary-50); border: 1px solid var(--vf-primary-100); margin-bottom: 10px; display: flex; gap: 12px; align-items: center; color: var(--vf-ink-800); font-weight: 500; font-size: 15px; }
.vfd-thanks li svg { color: var(--vf-teal-500); flex: none; }
