/* =============================================================
   AYC GROUP — Preguntas Frecuentes (page id 90)
   Scoped to body.page-id-90
   ============================================================= */

body.page-id-90 {
  --faq-navy: #15296A;
  --faq-navy-text: #1e2751;
  --faq-navy-deep: #003366;
  --faq-green: #9dc41a;
  --faq-bg-light: #F4F5F7;
  --faq-gray: #6B7280;
  --faq-gray-dark: #4B5563;
  --faq-border: #E5E7EB;
}

/* ============================================================
   HERO SECTION  ([data-id="faq-hero-sec"])
   ============================================================ */
html body.page-id-90 .elementor-element[data-id="faq-hero-sec"] {
  position: relative !important;
  min-height: 540px !important;
  background-size: cover !important;
  background-position: center center !important;
  justify-content: flex-end !important;
  padding-bottom: 60px !important;
  overflow: hidden !important;
}

/* Filtro azul SOLIDO homogeneo — igual que los otros 6 hero
   (rgba(0,15,40,0.65)). Antes era un gradiente diagonal que no coincidia
   con el resto y dejaba el disclaimer sobre zona clara de la foto. */
html body.page-id-90 .elementor-element[data-id="faq-hero-sec"]::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background-image: none !important;
  background-color: rgba(0,15,40,0.65) !important;
  pointer-events: none !important;
  z-index: 1 !important;
}
/* Banda inferior desactivada — el filtro solido ya cubre todo el hero. */
html body.page-id-90 .elementor-element[data-id="faq-hero-sec"]::after {
  content: none !important;
  position: absolute !important;
  inset: auto 0 0 0 !important;
  height: 45% !important;
  background-image: linear-gradient(180deg, rgba(21,41,106,0) 0%, rgba(21,41,106,0.55) 100%) !important;
  background-color: transparent !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

body.page-id-90 [data-id="faq-hero-inner"] {
  position: relative !important;
  z-index: 2 !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  width: 100% !important;
  align-items: flex-start !important;
}

body.page-id-90 [data-id="faq-hero-inner"] > .e-con-inner {
  align-items: flex-start !important;
  justify-content: flex-end !important;
  width: 100% !important;
  max-width: 1280px !important;
}

/* H1 hero title */
body.page-id-90 [data-id="faq-hero-title"] .elementor-heading-title {
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 42px !important;
  line-height: 1.18 !important;
  color: #FFFFFF !important;
  text-align: left !important;
  margin: 0 !important;
  max-width: 720px !important;
  letter-spacing: -0.5px !important;
}

/* H2 subtitle */
body.page-id-90 [data-id="faq-hero-sub"] .elementor-heading-title {
  font-family: 'Futura Medium', 'Open Sans', sans-serif !important;
  font-weight: 500 !important;
  font-size: 22px !important;
  line-height: 1.5 !important;
  color: rgba(255,255,255,0.96) !important;
  text-align: left !important;
  margin: 0 !important;
  max-width: 720px !important;
}

/* Disclaimer legal */
body.page-id-90 [data-id="faq-hero-legal"] {
  margin-top: 8px !important;
}
body.page-id-90 [data-id="faq-hero-legal"] p {
  font-family: 'Futura Medium', 'Open Sans', sans-serif !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  font-weight: 500 !important;
  color: rgba(255,255,255,0.82) !important;
  margin: 0 !important;
  max-width: 1100px !important;
}

/* ============================================================
   FAQ LIST SECTION ([data-id="faq-list-sec"])
   ============================================================ */
html body.page-id-90 .elementor-element[data-id="faq-list-sec"] {
  background-color: #FFFFFF !important;
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}

body.page-id-90 [data-id="faq-list-inner"] {
  max-width: 1080px !important;
  margin: 0 auto !important;
  width: 100% !important;
}
body.page-id-90 [data-id="faq-list-inner"] > .e-con-inner {
  max-width: 1080px !important;
  width: 100% !important;
  gap: 60px !important;
}

/* Group title (h2) */
body.page-id-90 [data-id^="faq-grp-"][data-id$="-title"] .elementor-heading-title,
body.page-id-90 [data-id="faq-grp-1-title"] .elementor-heading-title,
body.page-id-90 [data-id="faq-grp-2-title"] .elementor-heading-title,
body.page-id-90 [data-id="faq-grp-3-title"] .elementor-heading-title,
body.page-id-90 [data-id="faq-grp-4-title"] .elementor-heading-title {
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 34px !important;
  line-height: 1.2 !important;
  color: var(--faq-navy-deep) !important;
  text-align: left !important;
  margin: 0 0 12px 0 !important;
  letter-spacing: -0.3px !important;
}

/* FAQ list container per group */
body.page-id-90 .faq-list {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
}

/* FAQ item */
body.page-id-90 .faq-item {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 22px !important;
  padding: 22px 0 22px 0 !important;
  border-bottom: 1px solid var(--faq-border) !important;
}
body.page-id-90 .faq-item:first-child {
  padding-top: 14px !important;
}
body.page-id-90 .faq-item:last-child {
  border-bottom: none !important;
}

/* Number badge - green circle */
body.page-id-90 .faq-num {
  flex: 0 0 36px !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: var(--faq-green) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-top: 2px !important;
  box-shadow: 0 2px 6px rgba(157,196,26,0.25) !important;
}
body.page-id-90 .faq-num span {
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 16px !important;
  color: #FFFFFF !important;
  line-height: 1 !important;
  letter-spacing: -0.2px !important;
}

/* Question / Answer block */
body.page-id-90 .faq-content {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
body.page-id-90 .faq-q {
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 700 !important;
  font-size: 19px !important;
  line-height: 1.4 !important;
  color: var(--faq-navy-deep) !important;
  margin: 0 !important;
}
body.page-id-90 .faq-a {
  font-family: 'Futura Medium', 'Open Sans', sans-serif !important;
  font-weight: 500 !important;
  font-size: 17px !important;
  line-height: 1.62 !important;
  color: var(--faq-gray-dark) !important;
  margin: 0 !important;
}
body.page-id-90 .faq-a strong {
  color: var(--faq-navy-deep) !important;
  font-weight: 700 !important;
}

/* Reveal animation: visible by default; JS adds .faq-anim then .is-visible for staggered slide-in */
body.page-id-90 .faq-item {
  transition: opacity .55s ease, transform .55s ease;
}
body.page-id-90 .faq-item.faq-anim {
  opacity: 0;
  transform: translateY(14px);
}
body.page-id-90 .faq-item.faq-anim.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   CTA SECTION ([data-id="faq-cta-sec"]) — clones contacto pattern
   ============================================================ */
html body.page-id-90 .elementor-element[data-id="faq-cta-sec"] {
  background-image: linear-gradient(180deg, #0E5A88 0%, #0F1A3D 100%) !important;
  background-color: #0E5A88 !important;
  padding-top: 90px !important;
  padding-bottom: 90px !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
}
body.page-id-90 [data-id="faq-cta-inner"] {
  max-width: 1080px !important;
  margin: 0 auto !important;
  align-items: center !important;
  text-align: center !important;
}
body.page-id-90 [data-id="faq-cta-inner"] > .e-con-inner {
  align-items: center !important;
  text-align: center !important;
  max-width: 1080px !important;
  width: 100% !important;
}

body.page-id-90 [data-id="faq-cta-h2"] .elementor-heading-title {
  color: #FFFFFF !important;
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 800 !important;
  font-size: 50px !important;
  text-align: center !important;
  line-height: 1.15 !important;
  margin: 0 !important;
  letter-spacing: -0.5px !important;
}
body.page-id-90 [data-id="faq-cta-sub"] .elementor-heading-title {
  color: #FFFFFF !important;
  font-family: 'Futura Medium', 'Open Sans', sans-serif !important;
  font-weight: 500 !important;
  font-size: 22px !important;
  text-align: center !important;
  line-height: 1.4 !important;
  margin: 0 !important;
  opacity: 0.92 !important;
}

html body.page-id-90 [data-id="faq-cta-btn"] {
  text-align: center !important;
  width: 100% !important;
  margin-top: 14px !important;
}
body.page-id-90 [data-id="faq-cta-btn"] .elementor-button-wrapper {
  text-align: center !important;
}
html body.page-id-90 [data-id="faq-cta-btn"] .elementor-button {
  background: var(--faq-green) !important;
  background-color: var(--faq-green) !important;
  color: var(--faq-navy-deep) !important;
  font-family: 'Futura Bold', 'Montserrat', sans-serif !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  border: none !important;
  letter-spacing: 0.2px !important;
  box-shadow: 0 6px 18px rgba(157,196,26,0.35) !important;
  transition: transform .25s ease, box-shadow .25s ease, background-color .25s ease !important;
}
html body.page-id-90 [data-id="faq-cta-btn"] .elementor-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 24px rgba(157,196,26,0.45) !important;
  background-color: #b6dd28 !important;
}
body.page-id-90 [data-id="faq-cta-btn"] .elementor-button-text {
  color: var(--faq-navy-deep) !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  body.page-id-90 [data-id="faq-list-inner"] > .e-con-inner {
    padding-left: 32px !important;
    padding-right: 32px !important;
  }
  body.page-id-90 [data-id="faq-hero-title"] .elementor-heading-title {
    font-size: 34px !important;
  }
  body.page-id-90 [data-id="faq-hero-sub"] .elementor-heading-title {
    font-size: 18px !important;
  }
  body.page-id-90 [data-id="faq-cta-h2"] .elementor-heading-title {
    font-size: 38px !important;
  }
}

@media (max-width: 767px) {
  html body.page-id-90 .elementor-element[data-id="faq-hero-sec"] {
    min-height: 420px !important;
    padding-bottom: 32px !important;
  }
  body.page-id-90 [data-id="faq-hero-inner"] > .e-con-inner {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
  body.page-id-90 [data-id="faq-hero-title"] .elementor-heading-title {
    font-size: 26px !important;
  }
  body.page-id-90 [data-id="faq-hero-sub"] .elementor-heading-title {
    font-size: 16px !important;
  }
  body.page-id-90 [data-id="faq-hero-legal"] p {
    font-size: 10px !important;
  }
  html body.page-id-90 .elementor-element[data-id="faq-list-sec"] {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
  body.page-id-90 [data-id="faq-list-inner"] > .e-con-inner {
    padding-left: 18px !important;
    padding-right: 18px !important;
    gap: 40px !important;
  }
  body.page-id-90 [data-id^="faq-grp-"] .elementor-heading-title {
    font-size: 24px !important;
  }
  body.page-id-90 .faq-item {
    gap: 14px !important;
    padding: 18px 0 !important;
  }
  body.page-id-90 .faq-num {
    flex: 0 0 30px !important;
    width: 30px !important;
    height: 30px !important;
  }
  body.page-id-90 .faq-num span {
    font-size: 14px !important;
  }
  body.page-id-90 .faq-q {
    font-size: 17px !important;
  }
  body.page-id-90 .faq-a {
    font-size: 15.5px !important;
  }
  html body.page-id-90 .elementor-element[data-id="faq-cta-sec"] {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
  body.page-id-90 [data-id="faq-cta-h2"] .elementor-heading-title {
    font-size: 28px !important;
  }
  body.page-id-90 [data-id="faq-cta-sub"] .elementor-heading-title {
    font-size: 16px !important;
  }
}
