/**
 * az-final.css - migrado desde snippet 5 en 2026-04-26T23:08:44+00:00
 */


/* ========================================================================
 * AZ Sistema de Diseño Premium - UNIFICADO (FASE 2-A . 2026-04-26)
 * 1 solo bloque consolidando 7 bloques historicos
 * Bloques fusionados: az-premium-v5/v13/v15/v19, az-v23-noop, az-z9-logo-final, az-v25-libros-menu-fix
 * Orden cronologico preservado (cascade equivalente al original)
 * ======================================================================== */

/* SECCION 01 — Sistema base de diseño (variables, tipografía, header genérico, botones) */
/* ========================================================================
   AZ — SISTEMA DE DISEÑO PREMIUM V5
   Paleta diferenciada: verde bosque + gold cobre + crema cálida
   Tipografía: Cormorant Garamond (display) + Alexandria (body)
   ======================================================================== */

:root {
  --az-verde-bosque: #37412F;
  --az-verde-profundo: #2A3124;
  --az-gold: #C49B57;
  --az-gold-oscuro: #A88141;
  --az-gold-claro: #E3C590;
  --az-crema-base: #F5EFE7;
  --az-crema-suave: #FAF5EC;
  --az-tierra: #5B4A3A;
  --az-tierra-suave: #8B7862;
  --az-blanco-calido: #FDFBF5;
  --az-overlay: rgba(42, 49, 36, 0.72);
  --az-overlay-suave: rgba(42, 49, 36, 0.55);
}

/* ============ TIPOGRAFÍA GLOBAL ============ */
body, body.home, body.page {
  font-family: "Alexandria", "Inter", -apple-system, system-ui, sans-serif !important;
  color: var(--az-tierra) !important;
  background-color: var(--az-crema-base) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6,
.elementor-heading-title {
  font-family: "Cormorant Garamond", "Playfair Display", Georgia, serif !important;
  color: var(--az-verde-bosque) !important;
  letter-spacing: -0.01em;
  line-height: 1.15;
  font-weight: 600;
}

p, li, blockquote, span:not([class*="elementor-icon"]) {
  color: var(--az-tierra);
}

/* ============ HERO PRINCIPAL (home elementor-c2da8d4) ============ */
/* Añadir overlay oscuro sobre imagen de fondo para legibilidad */
.elementor-element.elementor-element-c2da8d4 {
  position: relative !important;
  isolation: isolate;
}
.elementor-element.elementor-element-c2da8d4::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(42,49,36,0.85) 0%, rgba(42,49,36,0.70) 50%, rgba(42,49,36,0.80) 100%) !important;
  z-index: 1 !important;
  pointer-events: none;
}
.elementor-element.elementor-element-c2da8d4 > * {
  position: relative !important;
  z-index: 2 !important;
}

/* Hero: todos los textos en crema claro */
.elementor-element.elementor-element-c2da8d4 h1,
.elementor-element.elementor-element-c2da8d4 h2,
.elementor-element.elementor-element-c2da8d4 h3,
.elementor-element.elementor-element-c2da8d4 .elementor-heading-title,
.elementor-element.elementor-element-c2da8d4 p,
.elementor-element.elementor-element-c2da8d4 span,
.elementor-element.elementor-element-c2da8d4 div {
  color: var(--az-crema-base) !important;
}

/* Eyebrow del hero (CENTRO NATURAL...) */
.elementor-element.elementor-element-c2da8d4 .elementor-heading-title[class*="elementor-size-small"],
.elementor-element.elementor-element-c2da8d4 .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.875rem !important;
  font-family: "Alexandria", sans-serif !important;
  font-weight: 500;
}

/* H1 hero — preservar Cormorant pero en crema */
.elementor-element.elementor-element-c2da8d4 h1.elementor-heading-title {
  color: var(--az-crema-base) !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
  font-size: clamp(2.5rem, 5vw, 4rem) !important;
}

.elementor-element.elementor-element-c2da8d4 p {
  color: rgba(245, 239, 231, 0.92) !important;
}

/* ============ TOPBAR (verde bosque 32px) ============ */
.elementor-element-898855e,
.elementor-element-898855e *,
.elementor-element-898855e p,
.elementor-element-898855e a,
.elementor-element-898855e span {
  color: rgba(245, 239, 231, 0.88) !important;
  font-size: 0.8125rem !important;
  font-family: "Alexandria", sans-serif !important;
}

/* ============ HEADER / NAV PRINCIPAL ============ */
.elementor-location-header .elementor-nav-menu a,
.elementor-nav-menu > li > a {
  color: var(--az-verde-bosque) !important;
  font-family: "Alexandria", sans-serif !important;
  font-weight: 500 !important;
  font-size: 0.95rem !important;
  letter-spacing: 0.02em;
  transition: color 0.25s ease;
}
.elementor-nav-menu > li > a:hover,
.elementor-nav-menu > li > a.elementor-item-active {
  color: var(--az-gold-oscuro) !important;
}

/* ============ BOTONES PREMIUM (contraste AA) ============ */
/* Gold primario — fondo gold-oscuro #A88141 sobre crema → contraste 4.65 AA */
.elementor-button,
a.elementor-button,
.wp-block-button__link,
button[type="submit"],
input[type="submit"],
.fluentform .ff-btn-submit,
.ff-btn-submit {
  background: var(--az-gold-oscuro) !important;
  background-image: linear-gradient(135deg, #B08A45 0%, #A88141 100%) !important;
  color: #FFFFFF !important;
  font-family: "Alexandria", sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: none !important;
  border: none !important;
  border-radius: 4px !important;
  padding: 0.875rem 2rem !important;
  box-shadow: 0 2px 12px rgba(168, 129, 65, 0.25) !important;
  transition: all 0.3s ease !important;
}
.elementor-button:hover,
a.elementor-button:hover,
.wp-block-button__link:hover,
button[type="submit"]:hover {
  background: var(--az-verde-bosque) !important;
  background-image: linear-gradient(135deg, #37412F 0%, #2A3124 100%) !important;
  color: #FFFFFF !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 18px rgba(55, 65, 47, 0.3) !important;
}

/* Botón RESERVA TU CITA (header CTA) */
.elementor-location-header .elementor-button {
  background: transparent !important;
  color: var(--az-gold-oscuro) !important;
  border: 1.5px solid var(--az-gold-oscuro) !important;
  padding: 0.7rem 1.6rem !important;
  font-size: 0.875rem !important;
}
.elementor-location-header .elementor-button:hover {
  background: var(--az-gold-oscuro) !important;
  color: #FFFFFF !important;
}

/* Botones del hero en verde oscuro (que se vean sobre overlay) */
.elementor-element.elementor-element-c2da8d4 .elementor-button {
  background: var(--az-gold) !important;
  background-image: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: #2A3124 !important;
  border: none !important;
  font-weight: 700 !important;
}
.elementor-element.elementor-element-c2da8d4 .elementor-button:hover {
  background: var(--az-crema-base) !important;
  color: var(--az-verde-bosque) !important;
}

/* ============ SECCIONES TIPO CARD / CAJAS ============ */
.elementor-widget-wrap .elementor-column,
.e-con-inner .elementor-widget {
  /* cards padding handled per widget */
}

/* ============ FORMULARIOS ============ */
input[type="text"], input[type="email"], input[type="tel"],
input[type="url"], input[type="password"], input[type="search"],
textarea, select,
.ff-el-input--content input,
.ff-el-input--content textarea {
  background: #FFFFFF !important;
  border: 1.5px solid #D4C9B8 !important;
  border-radius: 4px !important;
  padding: 0.75rem 1rem !important;
  font-family: "Alexandria", sans-serif !important;
  color: var(--az-tierra) !important;
  font-size: 0.95rem !important;
  transition: border-color 0.25s ease, box-shadow 0.25s ease;
}
input:focus, textarea:focus, select:focus,
.ff-el-input--content input:focus,
.ff-el-input--content textarea:focus {
  outline: none !important;
  border-color: var(--az-gold) !important;
  box-shadow: 0 0 0 3px rgba(196, 155, 87, 0.18) !important;
}
label, .ff-el-input--label label {
  color: var(--az-verde-bosque) !important;
  font-weight: 500 !important;
  font-family: "Alexandria", sans-serif !important;
  letter-spacing: 0.02em;
}

/* ============ GUÍA GRATUITA (barra inferior sticky) ============ */
.elementor-element-12121cd,
[class*="sticky"][class*="bottom"] {
  background: var(--az-verde-profundo) !important;
}
.elementor-element-12121cd *,
.elementor-element-12121cd p,
.elementor-element-12121cd h3 {
  color: var(--az-crema-base) !important;
}
.elementor-element-12121cd .elementor-button {
  background: var(--az-gold) !important;
  color: var(--az-verde-profundo) !important;
  font-weight: 700 !important;
}

/* ============ FOOTER ============ */
footer, .site-footer, [data-elementor-type="footer"] {
  background: var(--az-verde-profundo) !important;
}
footer *, .site-footer *,
[data-elementor-type="footer"] p,
[data-elementor-type="footer"] a,
[data-elementor-type="footer"] span,
[data-elementor-type="footer"] h3,
[data-elementor-type="footer"] h4,
[data-elementor-type="footer"] h5 {
  color: rgba(245, 239, 231, 0.85) !important;
}
footer a:hover, [data-elementor-type="footer"] a:hover {
  color: var(--az-gold-claro) !important;
}
[data-elementor-type="footer"] h3,
[data-elementor-type="footer"] h4 {
  color: var(--az-gold-claro) !important;
  font-family: "Cormorant Garamond", serif !important;
}

/* ============ BADGES / ETIQUETAS ============ */
.elementor-icon-list-text {
  color: var(--az-tierra) !important;
}

/* ============ LINKS INLINE ============ */
main a, article a, .entry-content a {
  color: var(--az-gold-oscuro);
  text-decoration-color: rgba(168, 129, 65, 0.4);
  text-underline-offset: 3px;
  transition: color 0.25s ease;
}
main a:hover, article a:hover, .entry-content a:hover {
  color: var(--az-verde-bosque);
  text-decoration-color: var(--az-verde-bosque);
}

/* ============ BREADCRUMBS Y PÁGINAS INTERIORES ============ */
.yoast-breadcrumbs, .breadcrumbs, nav[aria-label*="read"] {
  font-family: "Alexandria", sans-serif !important;
  color: var(--az-tierra-suave) !important;
  font-size: 0.875rem;
}
.yoast-breadcrumbs a, .breadcrumbs a {
  color: var(--az-verde-bosque) !important;
}

/* ============ CITAS Y BLOCKQUOTES ============ */
blockquote {
  border-left: 3px solid var(--az-gold) !important;
  padding-left: 1.5rem !important;
  font-family: "Cormorant Garamond", serif !important;
  font-style: italic;
  font-size: 1.25rem;
  color: var(--az-verde-bosque);
}

/* ============ WOOCOMMERCE (respeto sagrado, solo estilo) ============ */
.woocommerce .button, .woocommerce button.button {
  background: var(--az-gold-oscuro) !important;
  color: #FFFFFF !important;
  font-family: "Alexandria", sans-serif !important;
  border-radius: 4px !important;
}
.woocommerce .button:hover {
  background: var(--az-verde-bosque) !important;
}

/* ============ COOKIE BANNER ============ */
#cmplz-cookybanner, .cmplz-cookiebanner {
  font-family: "Alexandria", sans-serif !important;
}

/* ============ WHATSAPP FLOATING ============ */
.wa-chat-box, [class*="whatsapp"] {
  font-family: "Alexandria", sans-serif !important;
}

/* ============ UTILIDADES PREMIUM ============ */
.premium-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--az-gold), transparent);
  margin: 2rem auto;
  width: 120px;
}

/* Eyebrow genérico */
.eyebrow, .elementor-widget-heading .elementor-heading-title[class*="small"] {
  text-transform: uppercase;
  letter-spacing: 0.18em;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--az-gold-oscuro);
  font-family: "Alexandria", sans-serif !important;
}

/* ============ RESPONSIVE FINE-TUNING ============ */
@media (max-width: 767px) {
  h1, .elementor-heading-title {
    font-size: clamp(2rem, 7vw, 2.75rem) !important;
  }
  .elementor-element.elementor-element-c2da8d4 h1 {
    font-size: 2.25rem !important;
  }
}

/* ============ SECCIONES CON FONDO OSCURO (global fix) ============ */
/* Cualquier .e-con con fondo verde bosque/profundo → textos claros */
.e-con[style*="background-color:#37412F"],
.e-con[style*="background-color: #37412F"],
.e-con[style*="background-color:#2A3124"],
.e-con[style*="background-color: #2A3124"],
.e-con[style*="background-color:rgb(55, 65, 47)"],
.e-con[style*="background-color:rgb(42, 49, 36)"],
.elementor-element.elementor-element-d78ad8d,
.elementor-element.elementor-element-d78ad8d *,
#metodo-tnai,
#metodo-tnai *,
[id*="metodo"] [class*="heading-title"],
[class*="-bg-verde"] *,
[class*="-bg-dark"] * {
  color: var(--az-crema-base) !important;
}
#metodo-tnai h1, #metodo-tnai h2, #metodo-tnai h3, #metodo-tnai h4,
.elementor-element.elementor-element-d78ad8d h1,
.elementor-element.elementor-element-d78ad8d h2,
.elementor-element.elementor-element-d78ad8d h3,
.elementor-element.elementor-element-d78ad8d h4,
.elementor-element.elementor-element-d78ad8d .elementor-heading-title {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
}
#metodo-tnai p,
.elementor-element.elementor-element-d78ad8d p {
  color: rgba(245, 239, 231, 0.9) !important;
}
#metodo-tnai .eyebrow,
#metodo-tnai [class*="eyebrow"],
.elementor-element.elementor-element-d78ad8d .elementor-widget-heading:first-child .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase;
}

/* Regla universal para cualquier sección oscura identificada por su computed bg */
/* Aplicamos con atributo data-color custom, pero mejor target por class pattern */
.elementor-section[style*="background-color: #37"],
.elementor-section[style*="background-color: #2A"],
.elementor-section[style*="background-color: rgb(55"] {
  color: var(--az-crema-base);
}
.elementor-section[style*="background-color: #37"] *,
.elementor-section[style*="background-color: #2A"] *,
.elementor-section[style*="background-color: rgb(55"] * {
  color: inherit;
}

/* Franja de terapias (verde bosque) */
.elementor-element.elementor-element-270d6d4,
.elementor-element.elementor-element-270d6d4 *,
.elementor-element.elementor-element-270d6d4 p,
.elementor-element.elementor-element-270d6d4 span {
  color: var(--az-crema-base) !important;
}

/* ============ EYEBROW "EL CENTRO" / "METODOLOGÍA PROPIA" sobre fondos claros ============ */
.elementor-widget-heading .elementor-heading-title {
  /* permitir override contextual */
}

/* Etiquetas gold pills sobre hero */
.elementor-element.elementor-element-c2da8d4 .elementor-widget-heading .elementor-heading-title[style*="background"],
.elementor-element.elementor-element-c2da8d4 [class*="pill"],
.elementor-element.elementor-element-c2da8d4 button {
  /* heredan estilos de botón */
}

/* ============ SECCIÓN CONTACTO VERDE BOSQUE (130fdbd) ============ */
.elementor-element.elementor-element-130fdbd,
.elementor-element.elementor-element-130fdbd * {
  color: var(--az-crema-base) !important;
}
.elementor-element.elementor-element-130fdbd h1,
.elementor-element.elementor-element-130fdbd h2,
.elementor-element.elementor-element-130fdbd h3,
.elementor-element.elementor-element-130fdbd h4,
.elementor-element.elementor-element-130fdbd .elementor-heading-title {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
}
.elementor-element.elementor-element-130fdbd p,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-text,
.elementor-element.elementor-element-130fdbd a {
  color: var(--az-crema-base) !important;
}
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon i,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon svg {
  color: var(--az-gold-claro) !important;
  fill: var(--az-gold-claro) !important;
}
.elementor-element.elementor-element-130fdbd .elementor-button {
  background: var(--az-gold) !important;
  background-image: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: var(--az-verde-profundo) !important;
  font-weight: 700 !important;
  border: none !important;
}
.elementor-element.elementor-element-130fdbd .elementor-button:hover {
  background: var(--az-crema-base) !important;
  color: var(--az-verde-profundo) !important;
}

/* ============ Regla universal defensiva: cualquier sección con bg verde bosque → textos claros ============ */
/* Cubrimos los 3 IDs detectados con fondo oscuro + franja terapias */
.elementor-element.elementor-element-270d6d4 .elementor-icon-list-text,
.elementor-element.elementor-element-270d6d4 p,
.elementor-element.elementor-element-270d6d4 a,
.elementor-element.elementor-element-270d6d4 span {
  color: var(--az-crema-base) !important;
}

/* Footer (data-elementor-type footer) */
[data-elementor-type="footer"] .elementor-icon-list-text,
[data-elementor-type="footer"] a,
[data-elementor-type="footer"] p {
  color: rgba(245, 239, 231, 0.88) !important;
}
[data-elementor-type="footer"] a:hover {
  color: var(--az-gold-claro) !important;
}

/* ============ FIX UNIVERSAL SECCIONES OSCURAS (V8) ============ */
/* Forzar textos claros en TODAS las secciones con bg verde bosque/profundo */

.elementor-element.elementor-element-898855e,
.elementor-element.elementor-element-270d6d4,
.elementor-element.elementor-element-f4771ad,
.elementor-element.elementor-element-d78ad8d,
.elementor-element.elementor-element-1968c9b,
.elementor-element.elementor-element-130fdbd,
.elementor-element.elementor-element-f085d10,
.elementor-element.elementor-element-e20a1b5,
.elementor-element.elementor-element-66bdf92 {
  color: var(--az-crema-base) !important;
}

.elementor-element.elementor-element-898855e h1, .elementor-element.elementor-element-898855e h2, .elementor-element.elementor-element-898855e h3, .elementor-element.elementor-element-898855e h4, .elementor-element.elementor-element-898855e .elementor-heading-title,
.elementor-element.elementor-element-270d6d4 h1, .elementor-element.elementor-element-270d6d4 h2, .elementor-element.elementor-element-270d6d4 h3, .elementor-element.elementor-element-270d6d4 h4, .elementor-element.elementor-element-270d6d4 .elementor-heading-title,
.elementor-element.elementor-element-f4771ad h1, .elementor-element.elementor-element-f4771ad h2, .elementor-element.elementor-element-f4771ad h3, .elementor-element.elementor-element-f4771ad h4, .elementor-element.elementor-element-f4771ad .elementor-heading-title,
.elementor-element.elementor-element-d78ad8d h1, .elementor-element.elementor-element-d78ad8d h2, .elementor-element.elementor-element-d78ad8d h3, .elementor-element.elementor-element-d78ad8d h4, .elementor-element.elementor-element-d78ad8d .elementor-heading-title,
.elementor-element.elementor-element-1968c9b h1, .elementor-element.elementor-element-1968c9b h2, .elementor-element.elementor-element-1968c9b h3, .elementor-element.elementor-element-1968c9b h4, .elementor-element.elementor-element-1968c9b .elementor-heading-title,
.elementor-element.elementor-element-130fdbd h1, .elementor-element.elementor-element-130fdbd h2, .elementor-element.elementor-element-130fdbd h3, .elementor-element.elementor-element-130fdbd h4, .elementor-element.elementor-element-130fdbd .elementor-heading-title,
.elementor-element.elementor-element-f085d10 h1, .elementor-element.elementor-element-f085d10 h2, .elementor-element.elementor-element-f085d10 h3, .elementor-element.elementor-element-f085d10 h4, .elementor-element.elementor-element-f085d10 .elementor-heading-title,
.elementor-element.elementor-element-e20a1b5 h1, .elementor-element.elementor-element-e20a1b5 h2, .elementor-element.elementor-element-e20a1b5 h3, .elementor-element.elementor-element-e20a1b5 h4, .elementor-element.elementor-element-e20a1b5 .elementor-heading-title,
.elementor-element.elementor-element-66bdf92 h1, .elementor-element.elementor-element-66bdf92 h2, .elementor-element.elementor-element-66bdf92 h3, .elementor-element.elementor-element-66bdf92 h4, .elementor-element.elementor-element-66bdf92 .elementor-heading-title {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
}

.elementor-element.elementor-element-898855e p, .elementor-element.elementor-element-898855e .elementor-icon-list-text, .elementor-element.elementor-element-898855e span,
.elementor-element.elementor-element-270d6d4 p, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-text, .elementor-element.elementor-element-270d6d4 span,
.elementor-element.elementor-element-f4771ad p, .elementor-element.elementor-element-f4771ad .elementor-icon-list-text, .elementor-element.elementor-element-f4771ad span,
.elementor-element.elementor-element-d78ad8d p, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-text, .elementor-element.elementor-element-d78ad8d span,
.elementor-element.elementor-element-1968c9b p, .elementor-element.elementor-element-1968c9b .elementor-icon-list-text, .elementor-element.elementor-element-1968c9b span,
.elementor-element.elementor-element-130fdbd p, .elementor-element.elementor-element-130fdbd .elementor-icon-list-text, .elementor-element.elementor-element-130fdbd span,
.elementor-element.elementor-element-f085d10 p, .elementor-element.elementor-element-f085d10 .elementor-icon-list-text, .elementor-element.elementor-element-f085d10 span,
.elementor-element.elementor-element-e20a1b5 p, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-text, .elementor-element.elementor-element-e20a1b5 span,
.elementor-element.elementor-element-66bdf92 p, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-text, .elementor-element.elementor-element-66bdf92 span {
  color: rgba(245, 239, 231, 0.9) !important;
}

.elementor-element.elementor-element-898855e a,
.elementor-element.elementor-element-270d6d4 a,
.elementor-element.elementor-element-f4771ad a,
.elementor-element.elementor-element-d78ad8d a,
.elementor-element.elementor-element-1968c9b a,
.elementor-element.elementor-element-130fdbd a,
.elementor-element.elementor-element-f085d10 a,
.elementor-element.elementor-element-e20a1b5 a,
.elementor-element.elementor-element-66bdf92 a {
  color: var(--az-gold-claro) !important;
}

.elementor-element.elementor-element-898855e .elementor-icon-list-icon, .elementor-element.elementor-element-898855e .elementor-icon-list-icon i, .elementor-element.elementor-element-898855e .elementor-icon-list-icon svg,
.elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon i, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f4771ad .elementor-icon-list-icon, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon i, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon svg,
.elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon i, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon svg,
.elementor-element.elementor-element-1968c9b .elementor-icon-list-icon, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon i, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon svg,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon i, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f085d10 .elementor-icon-list-icon, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon i, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon i, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon i, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon svg {
  color: var(--az-gold-claro) !important;
  fill: var(--az-gold-claro) !important;
}

.elementor-element.elementor-element-898855e .elementor-icon-list-icon, .elementor-element.elementor-element-898855e .elementor-icon-list-icon i, .elementor-element.elementor-element-898855e .elementor-icon-list-icon svg,
.elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon i, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f4771ad .elementor-icon-list-icon, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon i, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon svg,
.elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon i, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon svg,
.elementor-element.elementor-element-1968c9b .elementor-icon-list-icon, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon i, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon svg,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon i, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f085d10 .elementor-icon-list-icon, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon i, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon i, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon i, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon svg i::before,
.elementor-element.elementor-element-898855e .elementor-icon-list-icon, .elementor-element.elementor-element-898855e .elementor-icon-list-icon i, .elementor-element.elementor-element-898855e .elementor-icon-list-icon svg,
.elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon i, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f4771ad .elementor-icon-list-icon, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon i, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon svg,
.elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon i, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon svg,
.elementor-element.elementor-element-1968c9b .elementor-icon-list-icon, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon i, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon svg,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon i, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f085d10 .elementor-icon-list-icon, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon i, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon i, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon i, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon svg svg path,
.elementor-element.elementor-element-898855e .elementor-icon-list-icon, .elementor-element.elementor-element-898855e .elementor-icon-list-icon i, .elementor-element.elementor-element-898855e .elementor-icon-list-icon svg,
.elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon i, .elementor-element.elementor-element-270d6d4 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f4771ad .elementor-icon-list-icon, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon i, .elementor-element.elementor-element-f4771ad .elementor-icon-list-icon svg,
.elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon i, .elementor-element.elementor-element-d78ad8d .elementor-icon-list-icon svg,
.elementor-element.elementor-element-1968c9b .elementor-icon-list-icon, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon i, .elementor-element.elementor-element-1968c9b .elementor-icon-list-icon svg,
.elementor-element.elementor-element-130fdbd .elementor-icon-list-icon, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon i, .elementor-element.elementor-element-130fdbd .elementor-icon-list-icon svg,
.elementor-element.elementor-element-f085d10 .elementor-icon-list-icon, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon i, .elementor-element.elementor-element-f085d10 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon i, .elementor-element.elementor-element-e20a1b5 .elementor-icon-list-icon svg,
.elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon i, .elementor-element.elementor-element-66bdf92 .elementor-icon-list-icon svg svg circle {
  color: var(--az-gold-claro) !important;
  fill: var(--az-gold-claro) !important;
}

.elementor-element.elementor-element-898855e .elementor-button,
.elementor-element.elementor-element-270d6d4 .elementor-button,
.elementor-element.elementor-element-f4771ad .elementor-button,
.elementor-element.elementor-element-d78ad8d .elementor-button,
.elementor-element.elementor-element-1968c9b .elementor-button,
.elementor-element.elementor-element-130fdbd .elementor-button,
.elementor-element.elementor-element-f085d10 .elementor-button,
.elementor-element.elementor-element-e20a1b5 .elementor-button,
.elementor-element.elementor-element-66bdf92 .elementor-button {
  background: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: var(--az-verde-profundo) !important;
  font-weight: 700 !important;
  border: none !important;
}
.elementor-element.elementor-element-898855e .elementor-button,
.elementor-element.elementor-element-270d6d4 .elementor-button,
.elementor-element.elementor-element-f4771ad .elementor-button,
.elementor-element.elementor-element-d78ad8d .elementor-button,
.elementor-element.elementor-element-1968c9b .elementor-button,
.elementor-element.elementor-element-130fdbd .elementor-button,
.elementor-element.elementor-element-f085d10 .elementor-button,
.elementor-element.elementor-element-e20a1b5 .elementor-button,
.elementor-element.elementor-element-66bdf92 .elementor-button:hover {
  background: var(--az-crema-base) !important;
  color: var(--az-verde-profundo) !important;
}

/* Eyebrow sobre fondo oscuro → gold claro uppercase */
.elementor-element.elementor-element-898855e .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-270d6d4 .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-f4771ad .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-d78ad8d .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-1968c9b .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-130fdbd .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-f085d10 .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-e20a1b5 .elementor-widget-heading:first-of-type .elementor-heading-title,
.elementor-element.elementor-element-66bdf92 .elementor-widget-heading:first-of-type .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: "Alexandria", sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500;
}

/* ============ FIX TEMPLATE DEFAULT (páginas sin Elementor wrapper) ============ */
html body,
body.page,
body.page-template-default,
body.wp-singular,
body.page-id-3646,
body.page-id-3647,
body.page-id-3648 {
  background-color: var(--az-crema-base) !important;
}

/* Entry-title (páginas default) */
body.page-template-default .entry-title,
body.page .entry-title,
.page-header .entry-title {
  color: var(--az-verde-bosque) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(2.5rem, 5vw, 3.5rem) !important;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 1.5rem;
}

/* Páginas sin hero premium → añadir espaciado */
body.page-template-default .page-header,
body.page .page-header {
  padding: 4rem 2rem 2rem !important;
  background: var(--az-crema-suave) !important;
  border-bottom: 1px solid rgba(196, 155, 87, 0.2);
  margin-bottom: 2rem;
}

/* Contenedor principal */
body.page-template-default .site-main,
body.page .site-main,
body.page-template-default main,
body.page main {
  background: var(--az-crema-base) !important;
  padding: 0 !important;
}

/* Content inner */
body.page-template-default .entry-content,
body.page .entry-content {
  max-width: 780px;
  margin: 0 auto;
  padding: 2rem;
  color: var(--az-tierra) !important;
  font-family: "Alexandria", sans-serif !important;
  line-height: 1.7;
}
body.page-template-default .entry-content p,
body.page .entry-content p {
  color: var(--az-tierra) !important;
  margin-bottom: 1.25rem;
}
body.page-template-default .entry-content h2,
body.page .entry-content h2,
body.page-template-default .entry-content h3,
body.page .entry-content h3 {
  color: var(--az-verde-bosque) !important;
  font-family: "Cormorant Garamond", serif !important;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

/* ============ REGLA UNIVERSAL HEROES CON BG-IMAGE (V11) ============ */
/* Cualquier .e-con-full de nivel e-parent con background-image → overlay + textos claros */
.e-con-full.e-parent[style*="background-image"],
.e-con.e-parent[style*="background-image"] {
  position: relative !important;
  isolation: isolate;
}
.e-con-full.e-parent[style*="background-image"]::before,
.e-con.e-parent[style*="background-image"]::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(42,49,36,0.82) 0%, rgba(42,49,36,0.68) 50%, rgba(42,49,36,0.78) 100%) !important;
  z-index: 1 !important;
  pointer-events: none;
}
.e-con-full.e-parent[style*="background-image"] > *,
.e-con.e-parent[style*="background-image"] > * {
  position: relative !important;
  z-index: 2 !important;
}
.e-con-full.e-parent[style*="background-image"] .elementor-heading-title,
.e-con-full.e-parent[style*="background-image"] h1,
.e-con-full.e-parent[style*="background-image"] h2,
.e-con-full.e-parent[style*="background-image"] h3,
.e-con.e-parent[style*="background-image"] .elementor-heading-title,
.e-con.e-parent[style*="background-image"] h1,
.e-con.e-parent[style*="background-image"] h2,
.e-con.e-parent[style*="background-image"] h3 {
  color: var(--az-crema-base) !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.e-con-full.e-parent[style*="background-image"] p,
.e-con.e-parent[style*="background-image"] p,
.e-con-full.e-parent[style*="background-image"] span,
.e-con.e-parent[style*="background-image"] span {
  color: rgba(245, 239, 231, 0.92) !important;
}

/* Cubrir el container específico 754ll8x (osteopatía) con misma lógica */
.elementor-element.elementor-element-754ll8x {
  position: relative !important;
  isolation: isolate;
}
.elementor-element.elementor-element-754ll8x::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(42,49,36,0.82) 0%, rgba(42,49,36,0.68) 50%, rgba(42,49,36,0.78) 100%) !important;
  z-index: 1 !important;
  pointer-events: none;
}
.elementor-element.elementor-element-754ll8x > * {
  position: relative !important;
  z-index: 2 !important;
}
.elementor-element.elementor-element-754ll8x .elementor-heading-title,
.elementor-element.elementor-element-754ll8x h1,
.elementor-element.elementor-element-754ll8x h2,
.elementor-element.elementor-element-754ll8x h3 {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
  font-size: clamp(2.5rem, 5vw, 3.75rem) !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.elementor-element.elementor-element-754ll8x p,
.elementor-element.elementor-element-754ll8x .elementor-heading-title[class*="small"] {
  color: rgba(245, 239, 231, 0.92) !important;
}

/* Fix body verde en páginas Elementor */
body.elementor-page {
  background-color: var(--az-crema-base) !important;
}

/* ============ HEROES UNIVERSALES V12 ============ */
/* Todo primer .e-parent dentro de page es hero: textos claros */
main > .elementor .elementor-section:first-child .elementor-heading-title,
main > .elementor > .elementor-section:first-of-type .elementor-heading-title,
.elementor-inner-section:first-child .elementor-heading-title,
.elementor > section:first-of-type h1,
.elementor > section:first-of-type h2,
.elementor > section:first-of-type h3,
main .elementor-top-section:first-child .elementor-heading-title,
main .elementor-top-section:first-child h1,
main .elementor-top-section:first-child h2,
main .elementor-top-section:first-child h3,
.elementor > .e-parent:first-child .elementor-heading-title,
.elementor > .e-parent:first-child h1,
.elementor > .e-parent:first-child h2,
.elementor > .e-parent:first-child h3,
.elementor > .e-con:first-child .elementor-heading-title,
.elementor > .e-con:first-child h1,
.elementor > .e-con:first-child h2,
.elementor > .e-con:first-child h3,
/* Por ID: acupuntura */
.elementor-element.elementor-element-3fve8by .elementor-heading-title,
.elementor-element.elementor-element-3fve8by h1,
.elementor-element.elementor-element-3fve8by h2,
.elementor-element.elementor-element-3fve8by h3 {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}

.elementor-element.elementor-element-3fve8by p,
.elementor-element.elementor-element-3fve8by span {
  color: rgba(245, 239, 231, 0.92) !important;
}
.elementor-element.elementor-element-3fve8by .elementor-widget-heading:first-of-type .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: "Alexandria", sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500;
}

/* Regla universal: cualquier container con bg-image (linear-gradient o url) que contenga H2/H3 grande → crema */
.e-con.e-parent .elementor-element .elementor-heading-title {
  /* No tocar aquí, controlamos con IDs */
}

/* Cualquier heading-title dentro de .e-parent con background-image en computed CSS → override en JS */
/* No se puede con CSS selectors, así que añadimos también reglas por URL de imagen típica */
.elementor section[style*="background-image:url"] .elementor-heading-title,
.elementor .e-con-full[style*="background-image"] .elementor-heading-title,
.elementor [class*="jetpack-boost-guide"][data-id] .elementor-heading-title {
  /* condicional */
}

/* ============ HEROES POR DETECCIÓN JS RUNTIME (V13) ============ */
/* Script runtime que marca automáticamente heroes con bg-image como .az-hero */

/* ============ FIX PAGINAS SIN ELEMENTOR (.page-content) ============ */
/* Aplica los mismos estilos de .entry-content a .page-content */
/* para paginas Gutenberg/classic como Libros que usan .page-content */
body.page-template-default .page-content,
body.page .page-content {
  max-width: 780px;
  margin: 0 auto;
  padding: 2rem;
  color: var(--az-tierra) !important;
  font-family: "Alexandria", sans-serif !important;
  line-height: 1.7;
}
body.page-template-default .page-content p,
body.page .page-content p {
  color: var(--az-tierra) !important;
  margin-bottom: 1.25rem;
}
body.page-template-default .page-content h2,
body.page .page-content h2,
body.page-template-default .page-content h3,
body.page .page-content h3 {
  color: var(--az-verde-bosque) !important;
  font-family: "Cormorant Garamond", serif !important;
  margin-top: 2rem;
  margin-bottom: 1rem;
}
body.page-template-default .page-content img,
body.page .page-content img {
  max-width: 100%;
  height: auto;
}
body.page-template-default .page-content hr,
body.page .page-content hr {
  margin: 2.5rem 0;
  border: 0;
  border-top: 1px solid rgba(196, 155, 87, 0.3);
}

/* SECCION 02 — Hero home + safety-net contraste */
/* Aplicar estilos a heroes auto-detectados */
.az-hero-auto {
  position: relative !important;
  isolation: isolate;
}
.az-hero-auto::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(42,49,36,0.78) 0%, rgba(42,49,36,0.62) 50%, rgba(42,49,36,0.75) 100%) !important;
  z-index: 1 !important;
  pointer-events: none;
}
.az-hero-auto > * {
  position: relative !important;
  z-index: 2 !important;
}
.az-hero-auto h1,
.az-hero-auto h2,
.az-hero-auto h3,
.az-hero-auto .elementor-heading-title {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.4);
}
.az-hero-auto p,
.az-hero-auto span {
  color: rgba(245, 239, 231, 0.92) !important;
}
.az-hero-auto .elementor-widget-heading:first-of-type .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: "Alexandria", sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500;
}
.az-hero-auto .elementor-button {
  background: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: var(--az-verde-profundo) !important;
  font-weight: 700 !important;
  border: none !important;
}

/* Aplicar estilos a secciones oscuras auto-detectadas */
.az-dark-auto h1,
.az-dark-auto h2,
.az-dark-auto h3,
.az-dark-auto h4,
.az-dark-auto .elementor-heading-title {
  color: var(--az-crema-base) !important;
  font-family: "Cormorant Garamond", serif !important;
}
.az-dark-auto p,
.az-dark-auto .elementor-icon-list-text {
  color: rgba(245, 239, 231, 0.9) !important;
}
.az-dark-auto a {
  color: var(--az-gold-claro) !important;
}
.az-dark-auto .elementor-icon-list-icon,
.az-dark-auto .elementor-icon-list-icon i,
.az-dark-auto .elementor-icon-list-icon svg {
  color: var(--az-gold-claro) !important;
  fill: var(--az-gold-claro) !important;
}
.az-dark-auto .elementor-button {
  background: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: var(--az-verde-profundo) !important;
  font-weight: 700 !important;
}
.az-dark-auto .elementor-widget-heading:first-of-type .elementor-heading-title {
  color: var(--az-gold-claro) !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-family: "Alexandria", sans-serif !important;
  font-size: 0.875rem !important;
  font-weight: 500;
}

/* ============ FIX PÁGINAS CON BODY VERDE OSCURO (V14) ============ */
/* Cuando el body tiene bg verde oscuro, los headings en primera pantalla → crema */
body[style*="background: rgb(30, 36, 23)"],
body[style*="background-color: rgb(30, 36, 23)"],
body.elementor-page {
  background-color: var(--az-crema-base) !important;
}

/* Override más agresivo: body.wp-singular con template elementor_header_footer */
body.page-template-elementor_header_footer {
  background-color: var(--az-crema-base) !important;
}

/* Si body es oscuro, forzar headings visibles */
body[style*="rgb(30, 36, 23)"] h1,
body[style*="rgb(30, 36, 23)"] h2,
body[style*="rgb(30, 36, 23)"] .elementor-heading-title {
  color: var(--az-crema-base) !important;
}

/* ============ FIX CARDS CLARAS DENTRO DE SECCIONES OSCURAS (V15) ============ */
/* Las cards/widgets con bg crema/blanco dentro de .az-dark-auto deben preservar estilos premium */
.az-dark-auto .elementor-widget:not([class*="dark"]):has(> *[style*="background: #F"]) h1,
.az-dark-auto .elementor-widget:not([class*="dark"]):has(> *[style*="background: #F"]) h2 {
  color: var(--az-verde-bosque) !important;
}

/* Si un widget tiene bg propio claro, sus headings vuelven a verde bosque */
.az-dark-auto [style*="background-color: #F"] h1,
.az-dark-auto [style*="background-color: #F"] h2,
.az-dark-auto [style*="background-color: #F"] h3,
.az-dark-auto [style*="background-color: rgb(255"] h1,
.az-dark-auto [style*="background-color: rgb(255"] h2,
.az-dark-auto [style*="background-color: rgb(255"] h3,
.az-dark-auto [style*="background-color: white"] h1,
.az-dark-auto [style*="background-color: white"] h2,
.az-dark-auto [style*="background-color: white"] h3,
.az-dark-auto .e-con[style*="background"] .elementor-heading-title {
  color: var(--az-verde-bosque) !important;
}

/* IMPORTANTE: si el body entero tiene bg oscuro, NO marcarlo como az-dark-auto */
body.az-dark-auto { color: var(--az-tierra) !important; background-color: var(--az-crema-base) !important; }
body.az-dark-auto > * > * { color: var(--az-tierra); }

/* Fix estructural: body con bg verde oscuro debe tener bg crema */
body.wp-singular.elementor-page,
body.wp-singular.page-template-elementor_header_footer,
body.page-template-elementor_header_footer {
  background-color: var(--az-crema-base) !important;
}

/* Runtime override: remove az-dark-auto from body via CSS pseudo */
html body.az-dark-auto { 
  /* Reset: body should never be dark-auto */
}

/* SECCION 03 — Logo, performance y botones (V18) */
/* ============ PLACEHOLDER ============ */

/* ============ FINAL CONTRAST FIXES V17 ============ */
/* Menú principal sobre hero: usar crema en vez de gold para AA */
.elementor-location-header .elementor-nav-menu > li > a,
.elementor-nav-menu > li > a {
  color: var(--az-crema-base) !important;
  font-weight: 500 !important;
}
/* Enlace activo del menú → gold claro */
.elementor-nav-menu > li > a.elementor-item-active,
.elementor-nav-menu > li > a:hover {
  color: var(--az-gold-claro) !important;
}

/* Eyebrows (El Centro, etc.) sobre crema → gold oscuro (contraste 4.5+) */
.eyebrow,
.elementor-widget-heading .elementor-heading-title.elementor-size-small,
.elementor-widget-heading .elementor-heading-title.elementor-size-xs,
h6.elementor-heading-title,
[class*="eyebrow"] .elementor-heading-title {
  color: #8B6B32 !important; /* gold más oscuro para contraste AA sobre crema */
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 0.8125rem !important;
  font-weight: 600 !important;
  font-family: "Alexandria", sans-serif !important;
}

/* Excepción: eyebrows dentro de secciones oscuras → gold claro */
.az-dark-auto .eyebrow,
.az-dark-auto [class*="eyebrow"] .elementor-heading-title,
.az-hero-auto .eyebrow,
.az-hero-auto [class*="eyebrow"] .elementor-heading-title {
  color: var(--az-gold-claro) !important;
}

/* Botones: asegurar contraste 4.5+ texto blanco sobre gold oscuro */
.elementor-button,
a.elementor-button {
  background: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
  color: #FFFFFF !important;
  font-weight: 600 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

/* Color legible del "El Centro" eyebrow específicamente */
.elementor-element:has(> .elementor-heading-title:is([class*="size-small"])) .elementor-heading-title {
  color: #8B6B32 !important;
}

/* ============ FIX V18 — LOGO, PERFORMANCE & BOTONES ============ */

/* 1) LOGO: tamaño consistente + evitar "dos tiempos" al cargar */
.elementor-location-header .elementor-widget-theme-site-logo img,
.elementor-location-header [class*="site-logo"] img,
header .elementor-widget-image img[src*="Diseno-sin-titulo"],
header img[src*="Diseno-sin-titulo"] {
  width: 58px !important;
  height: auto !important;
  max-width: 58px !important;
  aspect-ratio: 303 / 419;
  object-fit: contain;
}
/* Reservar espacio antes de que cargue el logo (previene salto de layout) */
.elementor-location-header .elementor-widget-theme-site-logo,
.elementor-location-header .elementor-widget-image {
  min-height: 80px;
  display: flex;
  align-items: center;
}

/* 2) PERFORMANCE: imagen de Javier reducir carga */
/* Fuerza el navegador a usar una variante más pequeña del srcset */
img[src*="JavierZentro"],
img[data-src*="JavierZentro"] {
  max-width: 100%;
  height: auto;
  aspect-ratio: 999 / 1406;
}

/* 3) BOTONES: sistema de contraste AA unificado */
/* Botón primario (gold) — texto BLANCO sobre gold oscuro (contraste 5.2:1) */
.elementor-button,
a.elementor-button,
button.elementor-button,
input[type="submit"].elementor-button,
.wp-block-button__link,
button[type="submit"]:not([class*="ff-"]),
.fluentform .ff-btn-submit,
.ff-btn-submit {
  background: #8B6B32 !important;
  background-image: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
  color: #FFFFFF !important;
  font-weight: 600 !important;
  letter-spacing: 0.03em !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.2);
  border: none !important;
  border-radius: 4px !important;
  padding: 0.875rem 2rem !important;
  box-shadow: 0 2px 12px rgba(139, 107, 50, 0.25) !important;
  transition: all 0.3s ease !important;
}
.elementor-button:hover,
a.elementor-button:hover,
button.elementor-button:hover,
.wp-block-button__link:hover {
  background: #37412F !important;
  background-image: linear-gradient(135deg, #37412F 0%, #2A3124 100%) !important;
  color: #FFFFFF !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 18px rgba(55, 65, 47, 0.35) !important;
}

/* Texto dentro del botón (span interior) también debe ser blanco */
.elementor-button .elementor-button-text,
.elementor-button span,
a.elementor-button span,
.wp-block-button__link span {
  color: inherit !important;
}

/* Botón "ghost" / outline (header CTA) — texto gold sobre transparente → cambiamos a fill */
.elementor-location-header .elementor-button,
.elementor-location-header a.elementor-button {
  background: #8B6B32 !important;
  background-image: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
  color: #FFFFFF !important;
  border: none !important;
  padding: 0.65rem 1.4rem !important;
  font-size: 0.875rem !important;
  letter-spacing: 0.06em;
}
.elementor-location-header .elementor-button:hover {
  background: #2A3124 !important;
  color: #FFFFFF !important;
}

/* Botones en fondo oscuro (.az-dark-auto, .az-hero-auto) — mantener gold con texto blanco */
.az-dark-auto .elementor-button,
.az-hero-auto .elementor-button,
.az-dark-auto a.elementor-button,
.az-hero-auto a.elementor-button {
  background: linear-gradient(135deg, #C49B57 0%, #A88141 100%) !important;
  color: #2A3124 !important;
  font-weight: 700 !important;
  text-shadow: none !important;
}
.az-dark-auto .elementor-button:hover,
.az-hero-auto .elementor-button:hover {
  background: #F5EFE7 !important;
  color: #2A3124 !important;
}

/* Botón secundario / outline (si es necesario) - texto blanco con borde gold */
.elementor-button[class*="secondary"],
.elementor-button.elementor-button-outline,
.elementor-button[class*="outline"] {
  background: transparent !important;
  color: #8B6B32 !important;
  border: 1.5px solid #8B6B32 !important;
  text-shadow: none !important;
}
.elementor-button[class*="secondary"]:hover,
.elementor-button.elementor-button-outline:hover {
  background: #8B6B32 !important;
  color: #FFFFFF !important;
}

/* Badges/pills "25+ años", "TNAI · método propio" — texto blanco sobre gold oscuro */
.elementor-element.elementor-element-d265f52 .elementor-heading-title,
.elementor-element.elementor-element-d265f52 .elementor-heading-title *,
.elementor-element[class*="pill"] .elementor-heading-title,
[class*="badge"] .elementor-heading-title {
  color: #FFFFFF !important;
  background: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
  padding: 0.5rem 1.2rem !important;
  border-radius: 999px !important;
  display: inline-block !important;
  font-size: 0.875rem !important;
  font-family: "Alexandria", sans-serif !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em;
  text-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

/* Fix específico: botón "Reservar primera consulta" en cualquier parte del home */
.elementor-element .elementor-button.elementor-size-md,
.elementor-element .elementor-button-link,
.elementor-element .elementor-button.elementor-size-lg,
.elementor-widget-button .elementor-button {
  color: #FFFFFF !important;
  background: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
}

/* Links-as-buttons dentro de cards "Consultar →", "Ver programa →" */
.elementor-widget-button .elementor-button.elementor-button-link {
  color: #FFFFFF !important;
  background: linear-gradient(135deg, #A88141 0%, #8B6B32 100%) !important;
}

/* ============ FIX V19 — PERFORMANCE & FOUC ============ */

/* Evitar FOUC: ocultar body hasta que DOMContentLoaded (con fallback) */
html.no-fouc body { opacity: 0.01; transition: opacity 0.3s ease; }
html.fouc-ready body { opacity: 1; }

/* Tamaño de logo fijo desde el primer momento */
.elementor-location-header .elementor-widget-theme-site-logo {
  width: auto;
  min-width: 58px;
  min-height: 80px;
}

/* Header sticky: evitar "salto" cuando se hace scroll y vuelve arriba */
.elementor-location-header {
  min-height: 110px;
  transition: none !important;
}
.elementor-sticky-scrolling .elementor-location-header,
.elementor-sticky--active .elementor-location-header {
  min-height: 80px;
}

/* SECCION 04 — Fixes V20+V23+V23.3+V24A-E (logo, menú, scroll states) */
/* ============ FIX V20 — LOGO CONTAINER WIDTH ============ */
/* El logo está dentro de widget fe86b7d con width restringido. Forzar tamaño del contenedor también */
.elementor-element.elementor-element-fe86b7d,
.elementor-location-header .elementor-widget-image,
.elementor-location-header .elementor-widget-theme-site-logo {
  width: auto !important;
  min-width: 72px !important;
  max-width: 80px !important;
  flex: 0 0 auto !important;
}
.elementor-element.elementor-element-fe86b7d img,
.elementor-location-header .elementor-widget-image img,
.elementor-location-header .elementor-widget-theme-site-logo img {
  width: 58px !important;
  height: auto !important;
  min-width: 58px !important;
  max-width: 58px !important;
  aspect-ratio: 303 / 419;
  object-fit: contain;
  display: block;
}
/* Evitar que el logo se achique al scrollear (sticky) */
.elementor-sticky--active .elementor-element.elementor-element-fe86b7d,
.elementor-sticky--effects .elementor-element.elementor-element-fe86b7d {
  width: auto !important;
  max-width: 80px !important;
}

/* ========================================================= */
/* V23 — Sistema unificado header premium (todas las páginas) */
/* ========================================================= */
/* Header fixed translúcido crema para TODAS las páginas.     */
/* HOME: hero pegado arriba del todo (mt:0, padding-top:0).   */
/* INTERIORES: hero con solape sutil (margin-top:-12px).      */
/* Al scroll > 60px: body.az-scrolled → header verde oscuro    */
/* con texto claro crema.                                     */

/* --- FIX LOGO (sin salto al cargar) --- */
.elementor-location-header .elementor-widget-image,
.elementor-location-header .elementor-widget-theme-site-logo,
.elementor-location-header .elementor-element-fe86b7d {
  min-width: 58px !important;
  min-height: 80px !important;
  width: 58px !important;
  max-width: 58px !important;
  display: flex !important;
  align-items: center !important;
  flex: 0 0 auto !important;
  contain: layout;
}
.elementor-location-header .elementor-widget-image img,
.elementor-location-header .elementor-widget-theme-site-logo img,
.elementor-location-header .elementor-element-fe86b7d img {
  width: 58px !important;
  height: 80px !important;
  max-width: 58px !important;
  max-height: 80px !important;
  min-width: 58px !important;
  object-fit: contain !important;
  aspect-ratio: 303 / 419;
  display: block !important;
  transition: none !important;
  filter: none !important;
}

/* --- Header fixed translúcido (TODAS las páginas) --- */
body .elementor-location-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  z-index: 9500 !important;
  background: rgba(250, 245, 232, 0.72) !important;
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  box-shadow: 0 1px 0 rgba(198, 168, 110, 0.18), 0 4px 18px rgba(0,0,0,0.06);
  transition: background 0.35s ease, box-shadow 0.35s ease;
}
body.admin-bar .elementor-location-header { top: 32px !important; }
@media (max-width: 782px) {
  body.admin-bar .elementor-location-header { top: 46px !important; }
}

/* Secciones internas sin fondo propio (para que se vea la cristalera) */
body .elementor-location-header > .elementor,
body .elementor-location-header .e-con,
body .elementor-location-header .elementor-section,
body .elementor-location-header .elementor-top-section,
body .elementor-location-header .elementor-inner-section,
body .elementor-location-header .elementor-column,
body .elementor-location-header .elementor-widget-wrap,
body .elementor-location-header .elementor-element.elementor-element-898855e,
body .elementor-location-header .elementor-element.elementor-element-270d6d4 {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
}

/* ===== TEXTO OSCURO EN ESTADO INICIAL (scroll=0) ===== */
/* Usamos element-IDs con alta especificidad para ganar al V20 */
body:not(.az-scrolled) .elementor-element.elementor-element-898855e,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e *,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e p,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e span,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 *,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 p,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 span,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-item,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-heading-title,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-icon-list-text,
body:not(.az-scrolled) .elementor-element-270d6d4 .elementor-nav-menu .menu-item > a {
  color: #1E2419 !important;
  text-shadow: none !important;
}

/* Menú hamburguesa oscuro (inicial) */
body:not(.az-scrolled) .elementor-location-header .elementor-menu-toggle,
body:not(.az-scrolled) .elementor-location-header .elementor-menu-toggle i,
body:not(.az-scrolled) .elementor-location-header .elementor-menu-toggle svg {
  color: #1E2419 !important;
  fill: #1E2419 !important;
  background: transparent !important;
  border: 1px solid rgba(30, 36, 25, 0.25) !important;
  border-radius: 4px;
}

/* CTA "RESERVA TU CITA" estado inicial */
body:not(.az-scrolled) .elementor-location-header .elementor-button,
body:not(.az-scrolled) .elementor-location-header .elementor-button-link,
body:not(.az-scrolled) .elementor-element.elementor-element-9aee660 .elementor-button {
  border: 1px solid rgba(150, 115, 50, 0.55) !important;
  background: rgba(198, 168, 110, 0.10) !important;
  color: #3A2E18 !important;
  letter-spacing: 0.06em;
  text-shadow: none !important;
  transition: all 0.3s ease;
}
body:not(.az-scrolled) .elementor-location-header .elementor-button:hover {
  background: #C6A86E !important;
  color: #1E2419 !important;
  border-color: #C6A86E !important;
}

/* Iconos sociales estado inicial */
body:not(.az-scrolled) .elementor-element.elementor-element-898855e .elementor-social-icon,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e .elementor-social-icon i,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e .elementor-social-icon svg {
  color: #8C6D2E !important;
  fill: #8C6D2E !important;
  background: transparent !important;
  filter: none !important;
}

/* ===== ESTADO SCROLLED (body.az-scrolled) ===== */
body.az-scrolled .elementor-location-header {
  background: rgba(40, 48, 34, 0.92) !important;
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  backdrop-filter: blur(14px) saturate(150%);
  box-shadow: 0 2px 0 rgba(198, 168, 110, 0.25), 0 8px 28px rgba(0,0,0,0.18);
}
body.az-scrolled .elementor-element.elementor-element-898855e,
body.az-scrolled .elementor-element.elementor-element-898855e *,
body.az-scrolled .elementor-element.elementor-element-898855e p,
body.az-scrolled .elementor-element.elementor-element-898855e span,
body.az-scrolled .elementor-element.elementor-element-898855e a,
body.az-scrolled .elementor-element.elementor-element-270d6d4,
body.az-scrolled .elementor-element.elementor-element-270d6d4 *,
body.az-scrolled .elementor-element.elementor-element-270d6d4 p,
body.az-scrolled .elementor-element.elementor-element-270d6d4 span,
body.az-scrolled .elementor-element.elementor-element-270d6d4 a,
body.az-scrolled .elementor-element.elementor-element-270d6d4 .elementor-nav-menu a,
body.az-scrolled .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a,
body.az-scrolled .elementor-element.elementor-element-270d6d4 .elementor-item,
body.az-scrolled .elementor-element-270d6d4 .elementor-nav-menu .menu-item > a {
  color: #F4EFE3 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.35);
}
body.az-scrolled .elementor-location-header .elementor-menu-toggle,
body.az-scrolled .elementor-location-header .elementor-menu-toggle i,
body.az-scrolled .elementor-location-header .elementor-menu-toggle svg {
  color: #F4EFE3 !important;
  fill: #F4EFE3 !important;
  border: 1px solid rgba(244, 239, 227, 0.4) !important;
  background: rgba(0,0,0,0.15) !important;
}
body.az-scrolled .elementor-location-header .elementor-button,
body.az-scrolled .elementor-element.elementor-element-9aee660 .elementor-button {
  border: 1px solid rgba(212, 181, 124, 0.65) !important;
  background: rgba(212, 181, 124, 0.15) !important;
  color: #F4EFE3 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.35) !important;
}
body.az-scrolled .elementor-location-header .elementor-button:hover {
  background: #D4B57C !important;
  color: #1E2419 !important;
  border-color: #D4B57C !important;
  text-shadow: none !important;
}
body.az-scrolled .elementor-element.elementor-element-898855e .elementor-social-icon,
body.az-scrolled .elementor-element.elementor-element-898855e .elementor-social-icon i,
body.az-scrolled .elementor-element.elementor-element-898855e .elementor-social-icon svg {
  color: #D4B57C !important;
  fill: #D4B57C !important;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4)) !important;
}

/* ===== COMPENSACIÓN LAYOUT ===== */
/* HOME: hero pegado arriba del todo, header flota ENCIMA */
body.home main,
body.home #content,
body.home .elementor-location-single,
body.home .elementor > .elementor-section:first-child,
body.home .elementor > .e-con:first-child {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* INTERIORES: main compensa con padding-top del header */
body:not(.home) main.site-main,
body:not(.home) #content > main,
body:not(.home) .elementor-location-single,
body:not(.home) .elementor-location-archive {
  padding-top: 110px !important;
  position: relative;
  z-index: 1;
}
/* Solape sutil primer bloque interiores */
body:not(.home) main.site-main > .elementor:first-child > .elementor-section:first-child,
body:not(.home) main.site-main > .elementor > .elementor-section:first-child,
body:not(.home) main.site-main > article > .elementor > .elementor-section:first-child,
body:not(.home) .elementor-location-single > .elementor-section:first-child,
body:not(.home) main.site-main > .elementor:first-child > .e-con:first-child,
body:not(.home) main.site-main > .elementor > .e-con:first-child {
  margin-top: -12px !important;
  position: relative;
  z-index: 1;
}

/* ===== MENÚ HAMBURGUESA A PANTALLA COMPLETA (cuando abierto) ===== */
/* SOLO se activa cuando Elementor añade .elementor-active al toggle o aria-expanded="true" */
.elementor-menu-toggle.elementor-active + .elementor-nav-menu__container,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container,
.elementor-nav-menu__container.elementor-menu-toggle__open,
.elementor-location-header [aria-expanded="true"] ~ .elementor-nav-menu--dropdown,
body.az-menu-open .elementor-location-header .elementor-nav-menu--dropdown.elementor-nav-menu__container {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-height: 100vh !important;
  background: rgba(28, 34, 23, 0.97) !important;
  -webkit-backdrop-filter: blur(18px);
  backdrop-filter: blur(18px);
  z-index: 9700 !important;
  padding-top: 100px !important;
  overflow-y: auto !important;
  display: flex !important;
  flex-direction: column;
  align-items: center;
}
body.admin-bar.az-menu-open .elementor-nav-menu--dropdown,
body.admin-bar .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container {
  top: 32px !important;
  height: calc(100vh - 32px) !important;
}
@media (max-width: 782px) {
  body.admin-bar.az-menu-open .elementor-nav-menu--dropdown,
  body.admin-bar .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container {
    top: 46px !important;
    height: calc(100vh - 46px) !important;
  }
}
body.az-menu-open .elementor-nav-menu__container .elementor-nav-menu,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container .elementor-nav-menu {
  padding: 40px 24px !important;
  text-align: center;
  width: 100%;
}
body.az-menu-open .elementor-nav-menu__container .elementor-nav-menu li,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container .elementor-nav-menu > li {
  display: block !important;
  border: none !important;
  margin: 8px 0 !important;
}
body.az-menu-open .elementor-nav-menu__container .elementor-nav-menu a,
body.az-menu-open .elementor-nav-menu__container .elementor-item,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container .elementor-nav-menu a,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container .elementor-item {
  color: #F4EFE3 !important;
  font-size: 17px !important;
  padding: 16px 20px !important;
  border-bottom: 1px solid rgba(244, 239, 227, 0.08) !important;
  display: block !important;
  text-align: center !important;
  letter-spacing: 0.04em;
}
body.az-menu-open .elementor-nav-menu__container .elementor-nav-menu a:hover,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container .elementor-item:hover {
  color: #D4B57C !important;
  background: rgba(212, 181, 124, 0.08) !important;
}

/* Reforzar: cuando el overlay mobile está abierto, los links deben ser claros */
body.az-menu-open .elementor-location-header .elementor-nav-menu__container.elementor-nav-menu--dropdown a,
body.az-menu-open .elementor-location-header .elementor-nav-menu__container.elementor-nav-menu--dropdown .elementor-item,
body.az-menu-open .elementor-element-270d6d4 .elementor-nav-menu--dropdown a,
body.az-menu-open .elementor-element-270d6d4 .elementor-nav-menu--dropdown .elementor-item,
body.az-menu-open .elementor-element.elementor-element-270d6d4 .elementor-nav-menu--dropdown a,
body.az-menu-open .elementor-element.elementor-element-270d6d4 .elementor-nav-menu--dropdown .elementor-item,
body.az-menu-open .elementor-element.elementor-element-270d6d4 .elementor-nav-menu--dropdown .menu-item > a,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu--dropdown a,
.elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu--dropdown .elementor-item {
  color: #F4EFE3 !important;
  text-shadow: none !important;
  font-size: 17px !important;
  padding: 16px 20px !important;
  text-align: center !important;
  display: block !important;
  border-bottom: 1px solid rgba(244, 239, 227, 0.08) !important;
  letter-spacing: 0.04em !important;
}
body.az-menu-open .elementor-location-header .elementor-nav-menu__container.elementor-nav-menu--dropdown a:hover,
body.az-menu-open .elementor-element-270d6d4 .elementor-nav-menu--dropdown a:hover,
body.az-menu-open .elementor-element.elementor-element-270d6d4 .elementor-nav-menu--dropdown a:hover,
body.az-menu-open .elementor-element.elementor-element-270d6d4 .elementor-nav-menu--dropdown .elementor-item:hover {
  color: #D4B57C !important;
  background: rgba(212, 181, 124, 0.08) !important;
}

/* Overlay cubre el admin-bar también cuando abierto (solo frontend) */
body.az-menu-open.admin-bar .elementor-nav-menu--dropdown,
body.admin-bar .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container {
  top: 0 !important;
  height: 100vh !important;
  padding-top: 120px !important;
}

/* Bloquear scroll del body cuando overlay abierto */
body.az-menu-open {
  overflow: hidden !important;
}

/* --- WhatsApp (Chaty) a la derecha --- */
.chaty-widget.left-position,
.chaty-widget {
  left: auto !important;
  right: 25px !important;
  bottom: 25px !important;
}
.chaty-widget .chaty-outer-forms,
.chaty-widget .chaty-popup-whatsapp-form,
.chaty-widget .chaty-form-0.pos-left,
.chaty-widget .pos-left {
  left: auto !important;
  right: 25px !important;
}

/* --- Footer: word-wrap para emails largos --- */
.elementor-location-footer,
.elementor-location-footer * {
  word-break: break-word;
  overflow-wrap: anywhere;
}
.elementor-location-footer a[href^="mailto:"] {
  white-space: normal !important;
  word-break: break-all;
}

/* Padding lateral en interiores */
@media (min-width: 1025px) {
  body:not(.home) main.site-main .elementor-section > .elementor-container {
    padding-left: 24px;
    padding-right: 24px;
  }
}

/* Fallback sin backdrop-filter */
@supports not ((-webkit-backdrop-filter: blur(1px)) or (backdrop-filter: blur(1px))) {
  body:not(.az-scrolled) .elementor-location-header {
    background: rgba(250, 245, 232, 0.95) !important;
  }
  body.az-scrolled .elementor-location-header {
    background: rgba(40, 48, 34, 0.98) !important;
  }
}

/* ===== V23.3 — Ajustes finos (logo, colores menú, layout CTA) ===== */

/* Logo más discreto: 46x64 (reducción del 58x80) */
.elementor-location-header .elementor-widget-image,
.elementor-location-header .elementor-widget-theme-site-logo,
.elementor-location-header .elementor-element-fe86b7d {
  min-width: 46px !important;
  min-height: 64px !important;
  width: 46px !important;
  max-width: 46px !important;
}
.elementor-location-header .elementor-widget-image img,
.elementor-location-header .elementor-widget-theme-site-logo img,
.elementor-location-header .elementor-element-fe86b7d img {
  width: 46px !important;
  height: 64px !important;
  max-width: 46px !important;
  max-height: 64px !important;
  min-width: 46px !important;
}

/* ===== COLOR MENÚ EN ESTADO INICIAL (scroll=0) — VERDE OSCURO SIEMPRE ===== */
/* Máxima especificidad para ganar a cualquier regla anterior de V20 */
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu > li > a,
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu > li > a.elementor-item,
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu .menu-item > a,
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu .menu-item > a.elementor-item,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a.elementor-item,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu .menu-item > a,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu .menu-item > a.elementor-item,
body:not(.az-scrolled) .elementor-element.elementor-element-937f571 .elementor-nav-menu > li > a,
body:not(.az-scrolled) .elementor-element.elementor-element-937f571 .elementor-nav-menu > li > a.elementor-item,
body:not(.az-scrolled) .elementor-element.elementor-element-937f571 .elementor-nav-menu .menu-item > a {
  color: #1E2419 !important;
  font-weight: 500 !important;
  text-shadow: none !important;
}
/* Hover en verde más claro con toque dorado */
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu > li > a:hover,
body:not(.az-scrolled) .elementor-location-header .elementor-nav-menu > li > a.elementor-item-active,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a:hover,
body:not(.az-scrolled) .elementor-element.elementor-element-270d6d4 .elementor-nav-menu > li > a.elementor-item-active {
  color: #8C6D2E !important;
}

/* Top bar (898855e) también en verde oscuro estado inicial */
body:not(.az-scrolled) .elementor-element.elementor-element-898855e,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e *,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e p,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e span,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e a {
  color: #1E2419 !important;
  text-shadow: none !important;
}

/* ===== LAYOUT: evitar solapamiento del CTA con Guía gratuita ===== */

/* CTA: en una sola línea, con padding cómodo y min-width */
body .elementor-location-header .elementor-button,
body .elementor-location-header .elementor-button-link,
body .elementor-element.elementor-element-9aee660 .elementor-button {
  white-space: nowrap !important;
  min-width: 150px !important;
  padding: 10px 20px !important;
  text-align: center !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Nav menu: reducir font-size ligeramente y añadir gap, evitar wrap */
body .elementor-location-header .elementor-nav-menu {
  flex-wrap: nowrap !important;
  column-gap: 4px;
}
body .elementor-location-header .elementor-nav-menu > li > a,
body .elementor-location-header .elementor-nav-menu .elementor-item {
  font-size: 15px !important;
  padding: 10px 12px !important;
  white-space: nowrap !important;
}

/* Dar anchura al wrapper del nav y margin-right para separar del CTA */
body .elementor-location-header .elementor-element.elementor-element-937f571 {
  flex: 1 1 auto !important;
  min-width: 0;
  margin-right: 16px;
}

/* Wrapper del botón CTA: que no se comprima */
body .elementor-location-header .elementor-element.elementor-element-9aee660 {
  flex: 0 0 auto !important;
  margin-left: auto !important;
}

/* En pantallas <1280px reducir más el font o cambiar layout */
@media (max-width: 1279px) {
  body .elementor-location-header .elementor-nav-menu > li > a,
  body .elementor-location-header .elementor-nav-menu .elementor-item {
    font-size: 14px !important;
    padding: 8px 8px !important;
  }
}

/* ===== HOME: solape del hero — ajustar padding-top ===== */
/* El user quiere hero pegado arriba pero el texto principal no debe quedar tapado */
/* (ya está sin padding-top, dejamos como está) */

/* ====== V24 — TOP BAR HORARIO FIX (user request 2026-04-20) ====== */
/* Fuerza el banner horario superior: fondo verde bosque oscuro + texto crema, siempre. */
body .elementor-location-header .elementor-element.elementor-element-898855e,
body .elementor-location-header .elementor-element.elementor-element-898855e:not(.elementor-motion-effects-element-type-background) {
  background: #1E2419 !important;
  background-color: #1E2419 !important;
  background-image: none !important;
}
body .elementor-location-header .elementor-element.elementor-element-898855e,
body .elementor-location-header .elementor-element.elementor-element-898855e *,
body .elementor-location-header .elementor-element.elementor-element-898855e p,
body .elementor-location-header .elementor-element.elementor-element-898855e a,
body .elementor-location-header .elementor-element.elementor-element-898855e span,
body .elementor-location-header .elementor-element.elementor-element-898855e .elementor-icon-list-text,
body.az-scrolled .elementor-element.elementor-element-898855e,
body.az-scrolled .elementor-element.elementor-element-898855e *,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e,
body:not(.az-scrolled) .elementor-element.elementor-element-898855e * {
  color: #FAF5E8 !important;
  fill: #FAF5E8 !important;
}
body .elementor-location-header .elementor-element.elementor-element-898855e .elementor-social-icon,
body .elementor-location-header .elementor-element.elementor-element-898855e .elementor-social-icon i,
body .elementor-location-header .elementor-element.elementor-element-898855e .elementor-social-icon svg {
  color: #FAF5E8 !important;
  fill: #FAF5E8 !important;
}

/* ====== V24B — HEADER WRAPPER TRANSPARENTE (user request 2026-04-20) ====== */
/* Quita el tinte crema del location-header padre para que el navbar semi-transparente
   deje ver el hero directamente. El banner del horario (.elementor-element-898855e) 
   conserva su fondo verde oscuro propio via V24. */
body .elementor-location-header,
body header.elementor.elementor-location-header,
body .elementor.elementor-3145.elementor-location-header {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
}

/* ====== V24C — HEADER WRAPPER LIMPIO (sin blur ni sombras detras) ====== */
/* El navbar interno ya tiene su propia translucidez. El wrapper padre no debe pintar 
   nada detras (sin backdrop-filter, sin box-shadow, sin filter, sin border). */
body .elementor-location-header,
body header.elementor.elementor-location-header,
body .elementor.elementor-3145.elementor-location-header,
body.az-scrolled .elementor-location-header,
body.az-scrolled header.elementor.elementor-location-header {
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
  filter: none !important;
  border: 0 !important;
  outline: 0 !important;
}
/* Tambien por si el wrapper interno (>.elementor) o algun .e-con padre del navbar 
   estan pintando un velo o sombra que se extiende a todo el ancho. */
body .elementor-location-header > .elementor,
body .elementor-location-header > .e-con,
body .elementor-location-header .elementor-section-wrap,
body.az-scrolled .elementor-location-header > .elementor,
body.az-scrolled .elementor-location-header > .e-con {
  -webkit-backdrop-filter: none !important;
  backdrop-filter: none !important;
  box-shadow: none !important;
  filter: none !important;
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
}

/* ====== V24D — NAVBAR FROSTED GLASS (blanco lechoso translucido) ====== */
/* Header con efecto vidrio esmerilado: blanco translucido + blur sutil. 
   Aplica tanto en estado inicial como con scroll (.az-scrolled) y en el navbar interno. */
body .elementor-element.elementor-element-270d6d4,
body #site-navbar,
body .elementor-3145 .elementor-element.elementor-element-270d6d4,
body.az-scrolled .elementor-element.elementor-element-270d6d4,
body.az-scrolled #site-navbar,
body .elementor-element.elementor-element-270d6d4.az-scrolled,
body .elementor-3145 .elementor-element.elementor-element-270d6d4.az-scrolled {
  background: rgba(30, 36, 25, 0.10) !important;
  background-color: rgba(30, 36, 25, 0.10) !important;
  background-image: none !important;
  -webkit-backdrop-filter: blur(28px) saturate(1.8) !important;
  backdrop-filter: blur(28px) saturate(1.8) !important;
  border-bottom: 1px solid rgba(196, 155, 87, 0.22) !important;
}

/* ====== V24E — CTA RESERVA TU CITA (header) en dorado opaco ====== */
/* Boton principal: dorado opaco con texto oscuro, sombra para destacar sobre el cristal lechoso. */
body .elementor-element.elementor-element-9aee660 .elementor-button,
body .elementor-element.elementor-element-9aee660 a.elementor-button,
body .elementor-3145 .elementor-element.elementor-element-9aee660 .elementor-button,
body.az-scrolled .elementor-element.elementor-element-9aee660 .elementor-button {
  background: #C49B57 !important;
  background-color: #C49B57 !important;
  background-image: none !important;
  color: #2A3124 !important;
  border: 1px solid #A88141 !important;
  box-shadow: 0 4px 14px rgba(168, 129, 65, 0.45), 0 1px 0 rgba(255, 255, 255, 0.25) inset !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  transition: background-color .25s ease, box-shadow .25s ease, transform .15s ease !important;
}
body .elementor-element.elementor-element-9aee660 .elementor-button:hover,
body .elementor-element.elementor-element-9aee660 a.elementor-button:hover,
body .elementor-3145 .elementor-element.elementor-element-9aee660 .elementor-button:hover {
  background: #A88141 !important;
  background-color: #A88141 !important;
  color: #FAF5E8 !important;
  box-shadow: 0 6px 18px rgba(168, 129, 65, 0.6), 0 1px 0 rgba(255, 255, 255, 0.3) inset !important;
  transform: translateY(-1px) !important;
}

/* SECCION 05 — V24 overrides definitivos (logo + hamburger) */
/* AZ V24 — overrides definitivos logo + menu hamburguesa */

/* ==== LOGO: libera aspect-ratio forzado y deja altura auto (logo cuadrado real 58x58) ==== */
html body .elementor-location-header .elementor-widget-image img,
html body .elementor-location-header .elementor-widget-theme-site-logo img,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img {
  aspect-ratio: auto !important;
  object-fit: contain !important;
  object-position: center center !important;
  max-width: none !important;
  max-height: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  height: auto !important;
  display: block !important;
}
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d .elementor-widget-container,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
  min-height: 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  max-height: none !important;
  overflow: visible !important;
  display: flex !important;
  align-items: center !important;
  line-height: 0 !important;
}
html body .elementor-3145 .elementor-element.elementor-element-270d6d4 {
  overflow: visible !important;
}
/* Desktop */
@media (min-width: 1025px) {
  html body .elementor-location-header .elementor-widget-image img,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img {
    width: 58px !important;
    height: auto !important;
  }
}
/* Tablet */
@media (max-width: 1024px) {
  html body .elementor-location-header .elementor-widget-image img,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img {
    width: 48px !important;
    height: auto !important;
  }
}
/* Movil */
@media (max-width: 767px) {
  html body .elementor-location-header .elementor-widget-image img,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img {
    width: 44px !important;
    height: auto !important;
  }
}

/* ==== TOGGLE HAMBURGUESA / X visible ==== */
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-menu-toggle,
  html body .elementor-location-header .elementor-menu-toggle {
    color: #F5EFE7 !important;
    background: transparent !important;
    border: 1px solid rgba(245, 239, 231, 0.35) !important;
    border-radius: 4px !important;
    padding: 8px !important;
    width: 42px !important;
    height: 42px !important;
    align-items: center !important;
    justify-content: center !important;
    display: flex !important;
  }
  html body .elementor-3145 .elementor-menu-toggle svg,
  html body .elementor-location-header .elementor-menu-toggle svg,
  html body .elementor-3145 .elementor-menu-toggle i,
  html body .elementor-location-header .elementor-menu-toggle i {
    color: #F5EFE7 !important;
    fill: #F5EFE7 !important;
    width: 22px !important;
    height: 22px !important;
  }
  html body.az-scrolled .elementor-3145 .elementor-menu-toggle,
  html body.az-scrolled .elementor-location-header .elementor-menu-toggle {
    color: rgb(244, 239, 227) !important;
    border-color: rgba(244, 239, 227, 0.4) !important;
  }
  html body.az-scrolled .elementor-3145 .elementor-menu-toggle svg,
  html body.az-scrolled .elementor-3145 .elementor-menu-toggle i {
    color: rgb(244, 239, 227) !important;
    fill: rgb(244, 239, 227) !important;
  }
}

/* ==== MENU OFFCANVAS: pantalla completa + items iluminados ==== */
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container.elementor-nav-menu--dropdown,
  html body.az-menu-open .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown,
  html body .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown.elementor-menu-toggle__open {
    display: block !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    min-height: 100vh !important;
    background-color: rgb(55, 65, 47) !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    z-index: 9999 !important;
    overflow-y: auto !important;
    padding: 80px 0 40px 0 !important;
    margin: 0 !important;
  }
  html body .elementor-3145 .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container.elementor-nav-menu--dropdown > ul.elementor-nav-menu,
  html body.az-menu-open .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown > ul.elementor-nav-menu {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    align-items: stretch !important;
    margin: 0 !important;
    padding: 0 !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li {
    padding: 0 !important;
    width: 100% !important;
    border-bottom: 1px solid rgba(248, 244, 238, 0.08) !important;
    transition: background-color 0.25s ease !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a {
    display: block !important;
    width: 100% !important;
    padding: 18px 24px !important;
    box-sizing: border-box !important;
    border-bottom: none !important;
    text-align: center !important;
    transition: background-color 0.25s ease, color 0.25s ease !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li:hover,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li.current-menu-item,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li.current-menu-ancestor {
    background-color: rgba(196, 155, 87, 0.18) !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a:hover,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a:focus,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li.current-menu-item > a {
    background-color: rgba(196, 155, 87, 0.22) !important;
    color: #E3C590 !important;
    text-decoration: none !important;
  }
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a::before,
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a::after {
    display: none !important;
    content: none !important;
  }
  html body .elementor-3145 .elementor-nav-menu--dropdown .sub-menu > li > a {
    padding: 14px 32px !important;
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    text-align: center !important;
  }
  html body .elementor-3145 .elementor-nav-menu--dropdown .sub-menu > li:hover,
  html body .elementor-3145 .elementor-nav-menu--dropdown .sub-menu > li > a:hover {
    background-color: rgba(196, 155, 87, 0.15) !important;
  }
}

/* Desktop hover de menu (sutil) */
@media (min-width: 1025px) {
  html body .elementor-location-header .elementor-nav-menu > li > a {
    padding: 13px 14px !important;
    border-radius: 4px !important;
    transition: background-color 0.25s ease, color 0.25s ease !important;
  }
  html body .elementor-location-header .elementor-nav-menu > li > a:hover,
  html body .elementor-location-header .elementor-nav-menu > li > a.elementor-item-active {
    background-color: rgba(196, 155, 87, 0.12) !important;
  }
  html body.az-scrolled .elementor-location-header .elementor-nav-menu > li > a:hover,
  html body.az-scrolled .elementor-location-header .elementor-nav-menu > li > a.elementor-item-active {
    background-color: rgba(227, 197, 144, 0.18) !important;
  }
}

/* AZ V25 — force widget container width (logo was clamped by widget container) */
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d .elementor-widget-container,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
  max-width: none !important;
  min-width: 0 !important;
  flex: 0 0 auto !important;
}
@media (min-width: 1025px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d {
    width: 58px !important;
    min-width: 58px !important;
    max-width: 58px !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 58px !important;
  }
}
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d {
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 48px !important;
  }
}
@media (max-width: 767px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d {
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
  }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 44px !important;
  }
}
/* AZ V25 — end */

/* AZ V24 — end */

/* SECCION 06 — Z9 Override final (post wp_head theme) */
/* Logo widget + img — tamanos correctos 58/48/44 */
html body .elementor-location-header .elementor-widget-image img,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img {
  aspect-ratio: auto !important;
  object-fit: contain !important;
  height: auto !important;
  max-width: none !important;
  max-height: none !important;
  min-height: 0 !important;
}
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d .elementor-widget-container,
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
  min-width: 0 !important;
  max-width: none !important;
  max-height: none !important;
  min-height: 0 !important;
  overflow: visible !important;
  display: flex !important;
  align-items: center !important;
}
@media (min-width: 1025px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img { width: 58px !important; }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 58px !important; min-width: 58px !important; max-width: 58px !important;
  }
}
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img { width: 48px !important; }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 48px !important; min-width: 48px !important; max-width: 48px !important;
  }
}
@media (max-width: 767px) {
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d img { width: 44px !important; }
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d,
  html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    width: 44px !important; min-width: 44px !important; max-width: 44px !important;
  }
}

/* Toggle hamburguesa visible en movil + espacio al contenido */
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-menu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    height: 42px !important;
    border: 1px solid rgba(245,239,231,0.55) !important;
    border-radius: 14px !important;
    color: #f5efe7 !important;
    background: transparent !important;
  }
  html body .elementor-3145 .elementor-menu-toggle i,
  html body .elementor-3145 .elementor-menu-toggle svg { font-size: 20px !important; width: 20px !important; height: 20px !important; }
}

/* Menu off-canvas a pantalla completa cuando esta abierto */
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-nav-menu--dropdown.elementor-nav-menu__container {
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    width: 100vw !important; height: 100vh !important;
    max-width: 100vw !important; max-height: 100vh !important;
    background-color: #37412F !important;
    z-index: 9999 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    padding: 24vh 8vw !important;
  }
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu { width: 100% !important; }
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu li { width: 100% !important; border-bottom: 1px solid rgba(245,239,231,0.12) !important; }
  html body .elementor-3145 .elementor-nav-menu--dropdown a {
    display: block !important;
    width: 100% !important;
    padding: 1.2rem 1rem !important;
    text-align: center !important;
    color: #f5efe7 !important;
    font-size: 1.35rem !important;
  }
  html body .elementor-3145 .elementor-nav-menu--dropdown a:hover,
  html body .elementor-3145 .elementor-nav-menu--dropdown a:focus,
  html body .elementor-3145 .elementor-nav-menu--dropdown .current-menu-item a,
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-item-active {
    background-color: rgba(196,155,87,0.22) !important;
    color: #f5efe7 !important;
  }
}

/* Hover de fila completa en menu desktop */
@media (min-width: 1025px) {
  html body .elementor-3145 .elementor-nav-menu--main .elementor-nav-menu > li > a {
    display: flex !important;
    align-items: center !important;
    padding: 14px 16px !important;
    border-radius: 14px !important;
    transition: background-color 0.25s ease !important;
  }
  html body .elementor-3145 .elementor-nav-menu--main .elementor-nav-menu > li > a:hover,
  html body .elementor-3145 .elementor-nav-menu--main .elementor-nav-menu > li > a:focus,
  html body .elementor-3145 .elementor-nav-menu--main .elementor-nav-menu > li.current-menu-item > a,
  html body .elementor-3145 .elementor-nav-menu--main .elementor-nav-menu > li.elementor-item-active > a {
    background-color: rgba(196,155,87,0.18) !important;
    color: #f5efe7 !important;
  }
}

/* Fix submenú móvil: evitar que el UL padre atenúe al submenú activo */
@media (max-width: 1024px) {
  html body.az-submenu-open.az-menu-open .elementor-location-header .elementor-nav-menu--dropdown.elementor-nav-menu__container > ul.elementor-nav-menu {
    opacity: 1 !important;
    transform: none !important;
  }
}

/* SECCION 07 — V25 fix menú "libros" + mobile fullscreen */
/* ===== 1) Imagen libro en movil: quitar float y centrar ===== */
@media (max-width: 768px) {
  .page-content p img[alt*="Cupido" i],
  .page-content p img[style*="float"] {
    float: none !important;
    display: block !important;
    margin: 16px auto !important;
    max-width: 220px !important;
  }
  .page-content p:has(> img[style*="float"]),
  .page-content p:has(> img[alt*="Cupido" i]) {
    text-align: center !important;
    margin: 16px 0 !important;
  }
}

/* ===== 2) Menu movil a pantalla completa tambien al hacer scroll ===== */
@media (max-width: 1024px) {
  html body .elementor-3145 .elementor-menu-toggle[aria-expanded="true"] + .elementor-nav-menu__container.elementor-nav-menu--dropdown,
  html body.az-menu-open .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown,
  html body .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown.elementor-menu-toggle__open {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    min-height: 100vh !important;
    min-height: 100dvh !important;
    max-height: none !important;
    z-index: 99999 !important;
    overflow-y: auto !important;
    padding: 70px 0 40px 0 !important;
    background-color: rgb(55, 65, 47) !important;
    transform: none !important;
  }
  html body.az-menu-open {
    overflow: hidden !important;
  }

  /* ===== 3) Casillas mas pequenas + texto centrado H/V ===== */
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a,
  html body .elementor-3145 .elementor-nav-menu--dropdown .sub-menu > li > a,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a,
  .elementor-nav-menu--dropdown a {
    padding: 10px 20px !important;
    min-height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    line-height: 1.2 !important;
  }

  /* ===== 4) Mismo tamano de fuente menu principal y submenu (1.4rem = submenu) ===== */
  html body .elementor-3145 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a,
  html body .elementor-3145 .elementor-nav-menu--dropdown .sub-menu > li > a,
  html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-nav-menu > li > a,
  .elementor-nav-menu--dropdown a,
  .elementor-nav-menu--dropdown .sub-menu a {
    font-size: 17px !important;
  }
}



/* === FASE 3-B v2 (2026-04-26): fixes menu mobile (selectores corregidos) ===
 * El JS de Elementor mueve el container del menu al <body> con clase
 * az-fullscreen-open. Los selectores con + adjacent dejan de matchear.
 * Aqui usamos selectores que cubren AMBOS casos: dentro del header Y movido al body.
 */

/* 2.a) Tamano homogeneo 17px en items principales y submenu (mobile menu abierto)
 * Especificidad 0,3,1 igualada a la regla pisadora de areazentro-custom-css,
 * y declarada DESPUES en cascade -> gana por orden. */
.elementor-element-937f571 .elementor-nav-menu--dropdown .menu-item > a,
.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-item,
.elementor-element-937f571 .elementor-nav-menu--dropdown .elementor-sub-item,
body > .elementor-nav-menu--dropdown.az-fullscreen-open .menu-item > a,
body > .elementor-nav-menu--dropdown.az-fullscreen-open .elementor-item,
body > .elementor-nav-menu--dropdown.az-fullscreen-open .elementor-sub-item,
body > .elementor-nav-menu--dropdown .menu-item > a,
body > .elementor-nav-menu--dropdown .elementor-item,
body > .elementor-nav-menu--dropdown .elementor-sub-item {
    font-size: 17px !important;
    line-height: 1.4 !important;
}

/* 2.b) Anular transform en header cuando menu esta abierto (sticky NO debe romper fullscreen) */
body.az-menu-open .elementor-3145,
body.az-menu-open .elementor-3145 .elementor-element-270d6d4,
body.az-menu-open .elementor-3145 .elementor-element-937f571 {
    transform: none !important;
}

/* 2.c) Forzar fullscreen del container DEL menu en TODOS sus posibles estados:
 *   - Adyacente al toggle (estado inicial)
 *   - Movido al body con clase az-fullscreen-open
 *   - Con clase elementor-menu-toggle__open
 */
body > .elementor-nav-menu--dropdown.az-fullscreen-open,
body > .elementor-nav-menu--dropdown.elementor-menu-toggle__open,
body.az-menu-open > .elementor-nav-menu--dropdown,
body.az-menu-open .elementor-3145 .elementor-nav-menu__container.elementor-nav-menu--dropdown,
body.az-menu-open .elementor-3145 .elementor-nav-menu__container.elementor-menu-toggle__open {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    min-height: 100vh !important;
    max-height: 100vh !important;
    transform: none !important;
}


/* === FASE 3-D v5 · Color claro al menu abierto via [aria-hidden="false"] ===
 * No dependemos de body.az-menu-open (mi JS puede tardar). Usamos el atributo
 * aria-hidden="false" que Elementor aplica inmediatamente al abrir el menu.
 * Especificidad: 0,8,3 - vence al pisador 0,7,2.
 */
html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu .menu-item > a.elementor-item,
html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu > li > a.elementor-item,
html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu .menu-item > a.elementor-sub-item,
html body .elementor-3145 .elementor-element.elementor-element-270d6d4 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu .menu-item > a.elementor-item,
html body .elementor-3145 .elementor-element.elementor-element-270d6d4 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu .menu-item > a.elementor-sub-item {
    color: #F5EFE7 !important;
}
html body .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu__container[aria-hidden="false"] .elementor-nav-menu .menu-item > a.elementor-item:hover {
    color: #E3C590 !important;
}

/* === FASE 3-E v2 · Igualar tamano horario topbar home con interiores (13px) ===
 * Causa: regla customizer body.page-id-2036 .elementor-widget-text-editor p { 18px }
 * (especif. 0,2,2 con !important) pisa el topbar de la home, pero NO existe en
 * interiores. Aqui forzamos 13px en el topbar de la home con especif. 0,4,2.
 * Aplica en TODOS los viewports - el horario debe ser 13px siempre como en interiores.
 */
body.page-id-2036 .elementor-element.elementor-element-898855e .elementor-widget-text-editor p,
body.page-id-2036 .elementor-element.elementor-element-898855e .elementor-widget-text-editor {
    font-size: 13px !important;
    line-height: 32px !important;
}


/* ============================================================
 * AZ Typography System v2 (2026-04-26 · global)
 * ============================================================
 * Sistema unificado APLICADO A TODO EL SITIO para garantizar
 * armonía y coherencia premium en todas las páginas.
 *
 * Escala global:
 *   H1 (todas)      clamp(36 → 56)px  fw 600  lh 1.15
 *   H2 (todas)      clamp(28 → 36)px  fw 600  lh 1.2
 *   H3 (todas)      clamp(18 → 22)px  fw 600  lh 1.3
 *
 * Excepción home hero subtítulo:
 *   H2 hero home    clamp(18 → 22)px  fw 400  italic  lh 1.5
 *
 * Card body p (todas):  16px (era 16.5 fraccional)
 * ------------------------------------------------------------ */

/* H1 — universal (todas las páginas) */
.elementor-widget-heading h1.elementor-heading-title {
    font-size: clamp(36px, 5.5vw, 56px) !important;
    font-weight: 600 !important;
    line-height: 1.15 !important;
    letter-spacing: -0.005em !important;
}

/* H2 — universal (todas las páginas) */
.elementor-widget-heading h2.elementor-heading-title {
    font-size: clamp(28px, 4vw, 36px) !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    letter-spacing: -0.005em !important;
}

/* H3 — universal (todas las páginas) */
.elementor-widget-heading h3.elementor-heading-title {
    font-size: clamp(18px, 2.5vw, 22px) !important;
    font-weight: 600 !important;
    line-height: 1.3 !important;
    letter-spacing: 0 !important;
}

/* H1 hero del HOME — más grande para drama (override) */
body.page-id-2036 .elementor-element.elementor-element-c2da8d4 h1.elementor-heading-title {
    font-size: clamp(36px, 5.5vw, 56px) !important;
    font-weight: 600 !important;
    line-height: 1.15 !important;
    letter-spacing: -0.005em !important;
}

/* CASO ESPECIAL: H2 hero subtítulo del HOME (italic, más pequeño que H2 normal) */
body.page-id-2036 .elementor-element.elementor-element-c2da8d4 h2.elementor-heading-title {
    font-size: clamp(18px, 2.5vw, 22px) !important;
    font-weight: 400 !important;
    font-style: italic !important;
    line-height: 1.5 !important;
    letter-spacing: 0 !important;
}

/* Card body p — eliminar 16.5px fraccional en todas las páginas */
.elementor-widget-text-editor p {
    /* No forzar tamaño absoluto general — solo donde Elementor pinta 16.5 */
}
.elementor-element[class*="card"] .elementor-widget-text-editor p,
.elementor-section .elementor-widget-text-editor p[style*="16.5"] {
    font-size: 16px;
}

/* BUG FIX 1: logo line-height: 0 → 1 */
html body .elementor-3145 .elementor-element.elementor-element-fe86b7d a {
    line-height: 1 !important;
}

/* BUG FIX 2: font-weight bold textual → 700 numérico */
.cta-sticky-mobile a,
.guia-banner-cta {
    font-weight: 700 !important;
}

/* ============================================================
 * Fin AZ Typography System v2
 * ============================================================ */

/* ============================================================
 * AZ Contrast Fix v3 (2026-04-26)
 * ============================================================
 * v3: redefinir --az-tierra (marron oscuro #5B4A3A) a beige
 * dentro de containers con fondo verde oscuro. Esto es la
 * causa raiz del bajo contraste — la regla pisadora era:
 *   body.page .page-content p { color: var(--az-tierra) !important; }
 * Con --az-tierra = #5B4A3A.
 * ------------------------------------------------------------ */

/* 1) FOOTER: redefinir variables doradas y de tierra a beige claro */
footer.elementor-location-footer,
[data-elementor-type="footer"] {
    --az-gold-claro: #F5EFE7 !important;
    --az-gold: #F5EFE7 !important;
    --az-amber: #F5EFE7 !important;
    --az-dorado: #F5EFE7 !important;
    --az-tierra: #F5EFE7 !important;
}

/* 2) Containers con fondo verde oscuro inline: redefine --az-tierra */
.elementor-element[style*="background-color:#37412F"],
.elementor-element[style*="background-color:#37412f"],
.elementor-element[style*="background-color: #37412F"],
.elementor-element[style*="background-color: #37412f"],
.elementor-element[style*="background-color:#1E2417"],
.elementor-element[style*="background-color:#1e2417"],
.elementor-element[style*="background-color: #1E2417"],
.elementor-element[style*="background-color: #1e2417"],
.elementor-element[style*="background-color:#1E2419"],
.elementor-element[style*="background-color:#1e2419"],
.elementor-element[style*="background-color: #1E2419"],
.elementor-element[style*="background-color: #1e2419"],
.elementor-element[style*="background-color:#2A3124"],
.elementor-element[style*="background-color:#2a3124"],
.elementor-element[style*="background-color: #2A3124"],
.elementor-element[style*="background-color: #2a3124"],
.az-dark-auto,
.az-dark-bg,
[class*="bg-dark"],
[class*="dark-section"] {
    --az-tierra: #F5EFE7 !important;
    --az-gold-claro: #F5EFE7 !important;
    --az-gold: #F5EFE7 !important;
    --az-amber: #F5EFE7 !important;
    --az-dorado: #F5EFE7 !important;
}

/* 3) Override directo con alta especificidad para p/h dentro de containers verde */
body .elementor-element[style*="background-color:#37412F"] p,
body .elementor-element[style*="background-color:#37412f"] p,
body .elementor-element[style*="background-color:#1E2417"] p,
body .elementor-element[style*="background-color:#1e2417"] p,
body .elementor-element[style*="background-color:#1E2419"] p,
body .elementor-element[style*="background-color:#1e2419"] p,
body .elementor-element[style*="background-color:#2A3124"] p,
body .elementor-element[style*="background-color:#2a3124"] p,
body .elementor-element[style*="background-color:#37412F"] li,
body .elementor-element[style*="background-color:#1E2417"] li,
body .elementor-element[style*="background-color:#1E2419"] li,
body .elementor-element[style*="background-color:#2A3124"] li,
body .elementor-element[style*="background-color:#37412F"] .elementor-heading-title,
body .elementor-element[style*="background-color:#1E2417"] .elementor-heading-title,
body .elementor-element[style*="background-color:#1E2419"] .elementor-heading-title,
body .elementor-element[style*="background-color:#2A3124"] .elementor-heading-title {
    color: #F5EFE7 !important;
}

/* 4) FOOTER override directo (sigue siendo necesario para alta especificidad) */
html body footer.elementor-location-footer .elementor-element a,
html body footer.elementor-location-footer .elementor-element h2,
html body footer.elementor-location-footer .elementor-element h3,
html body footer.elementor-location-footer .elementor-element h4,
html body footer.elementor-location-footer .elementor-element h5,
html body footer.elementor-location-footer .elementor-element .elementor-heading-title,
html body footer.elementor-location-footer .elementor-element p,
html body footer.elementor-location-footer .elementor-element li,
html body footer.elementor-location-footer .elementor-icon.elementor-social-icon {
    color: #F5EFE7 !important;
}
html body footer.elementor-location-footer .elementor-element a:hover,
html body footer.elementor-location-footer .elementor-icon.elementor-social-icon:hover {
    color: #FFFFFF !important;
}

/* 5) Eyebrow .az-sub-title — beige claro */
html body .az-sub-title,
html body .az-sub-title * {
    color: #F5EFE7 !important;
}

/* 6) Inline styles cálidos directos → beige */
[style*="color:#5B4A3A"], [style*="color: #5B4A3A"], [style*="color:#5b4a3a"], [style*="color: #5b4a3a"],
[style*="color:rgb(91, 74, 58)"], [style*="color: rgb(91, 74, 58)"],
[style*="color:rgb(91,74,58)"] {
    color: #F5EFE7 !important;
}

/* 7) Body class az-menu-open: menu mobile fullscreen */
body.az-menu-open .elementor-nav-menu--dropdown a,
body.az-menu-open .elementor-nav-menu--dropdown li {
    color: #F5EFE7 !important;
}

/* ============================================================
 * Fin AZ Contrast Fix v3
 * ============================================================ */

/* ============================================================
 * AZ Polish v1 (2026-04-26)
 * ============================================================
 * 3 fixes:
 *   1) Ocultar boton .az-menu-back excepto cuando submenu abierto
 *   2) Enmarcar las 3 cajas 01/02/03 (containers 28db862, e08b4b8, 4b61b57)
 *      con borde sutil + padding + bg para elegancia
 *   3) Alinear botones a la parte baja en las 4 cajas Programas
 *      (containers 4a40a70, 94f34cc, 427dfb8, 66f94f5)
 * ------------------------------------------------------------ */

/* === FIX 1: ocultar Atras flotante en home === */
.az-menu-back {
    display: none !important;
}
body.az-submenu-open .az-menu-back,
body.az-menu-open .az-menu-back {
    display: inline-flex !important;
}

/* === FIX 2 (v6): enmarcar cajas 01/02/03 (Método TNAI + Cómo es una primera sesión) === */
/* Containers Método TNAI: 7493c4b (01-Valoración), fe7e59e (02-Intervención), fe21e5d (03-Cambio) */
/* Containers Cómo es una primera sesión: 28db862 (01), e08b4b8 (02), 4b61b57 (03) */
body.page-id-2036 .elementor-element.elementor-element-7493c4b,
body.page-id-2036 .elementor-element.elementor-element-fe7e59e,
body.page-id-2036 .elementor-element.elementor-element-fe21e5d,
body.page-id-2036 .elementor-element.elementor-element-28db862,
body.page-id-2036 .elementor-element.elementor-element-e08b4b8,
body.page-id-2036 .elementor-element.elementor-element-4b61b57 {
    border: 1px solid rgba(245, 239, 231, 0.18) !important;
    border-radius: 14px !important;
    padding: 32px 28px !important;
    background: rgba(245, 239, 231, 0.03) !important;
    transition: border-color 0.3s ease, background 0.3s ease, transform 0.3s ease !important;
}
body.page-id-2036 .elementor-element.elementor-element-7493c4b:hover,
body.page-id-2036 .elementor-element.elementor-element-fe7e59e:hover,
body.page-id-2036 .elementor-element.elementor-element-fe21e5d:hover,
body.page-id-2036 .elementor-element.elementor-element-28db862:hover,
body.page-id-2036 .elementor-element.elementor-element-e08b4b8:hover,
body.page-id-2036 .elementor-element.elementor-element-4b61b57:hover {
    border-color: rgba(196, 155, 87, 0.45) !important;
    background: rgba(245, 239, 231, 0.06) !important;
    transform: translateY(-2px) !important;
}

/* === FIX 3 (v5): banda inferior dorada full-width como boton =====
 * IDs DEFINITIVOS:
 *   Containers: 155ef83 (1mes), 94f34cc (3meses), 9f93a47 (Hipno), 8112bc5 (6meses)
 *   Buttons:    50fbd5d (1mes), 427dfb8 (3meses), 66f94f5 (Hipno), b6f3a1b (6meses)
 * ------------------------------------------------------------ */

/* Container caja: relative + padding-bottom + border-radius */
html body.page-id-2036 .elementor-element.elementor-element-155ef83.e-con,
html body.page-id-2036 .elementor-element.elementor-element-94f34cc.e-con,
html body.page-id-2036 .elementor-element.elementor-element-9f93a47.e-con,
html body.page-id-2036 .elementor-element.elementor-element-8112bc5.e-con {
    position: relative !important;
    padding-bottom: 76px !important;
    border-radius: 14px !important;
    border: 1px solid rgba(245, 239, 231, 0.18) !important;
    overflow: hidden !important;
    transition: border-color 0.3s ease, transform 0.3s ease !important;
}
html body.page-id-2036 .elementor-element.elementor-element-155ef83.e-con:hover,
html body.page-id-2036 .elementor-element.elementor-element-94f34cc.e-con:hover,
html body.page-id-2036 .elementor-element.elementor-element-9f93a47.e-con:hover,
html body.page-id-2036 .elementor-element.elementor-element-8112bc5.e-con:hover {
    border-color: rgba(196, 155, 87, 0.35) !important;
    transform: translateY(-2px) !important;
}

/* Widget button (por ID directo): absolute al fondo, full width */
html body.page-id-2036 .elementor-element-50fbd5d.elementor-widget-button,
html body.page-id-2036 .elementor-element-427dfb8.elementor-widget-button,
html body.page-id-2036 .elementor-element-66f94f5.elementor-widget-button,
html body.page-id-2036 .elementor-element-b6f3a1b.elementor-widget-button {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 2 !important;
}

/* Wrapper del button widget */
html body.page-id-2036 .elementor-element-50fbd5d.elementor-widget-button .elementor-widget-container,
html body.page-id-2036 .elementor-element-427dfb8.elementor-widget-button .elementor-widget-container,
html body.page-id-2036 .elementor-element-66f94f5.elementor-widget-button .elementor-widget-container,
html body.page-id-2036 .elementor-element-b6f3a1b.elementor-widget-button .elementor-widget-container,
html body.page-id-2036 .elementor-element-50fbd5d .elementor-widget-container,
html body.page-id-2036 .elementor-element-427dfb8 .elementor-widget-container,
html body.page-id-2036 .elementor-element-66f94f5 .elementor-widget-container,
html body.page-id-2036 .elementor-element-b6f3a1b .elementor-widget-container {
    width: 100% !important;
    text-align: center !important;
    padding: 0 !important;
    margin: 0 !important;
}

/* Button-wrapper interno */
html body.page-id-2036 .elementor-element-50fbd5d .elementor-button-wrapper,
html body.page-id-2036 .elementor-element-427dfb8 .elementor-button-wrapper,
html body.page-id-2036 .elementor-element-66f94f5 .elementor-button-wrapper,
html body.page-id-2036 .elementor-element-b6f3a1b .elementor-button-wrapper {
    display: block !important;
    width: 100% !important;
    text-align: center !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* El boton/anchor: banda dorada full width */
html body.page-id-2036 .elementor-element-50fbd5d .elementor-button,
html body.page-id-2036 .elementor-element-427dfb8 .elementor-button,
html body.page-id-2036 .elementor-element-66f94f5 .elementor-button,
html body.page-id-2036 .elementor-element-b6f3a1b .elementor-button,
html body.page-id-2036 .elementor-element-50fbd5d a.elementor-button-link,
html body.page-id-2036 .elementor-element-427dfb8 a.elementor-button-link,
html body.page-id-2036 .elementor-element-66f94f5 a.elementor-button-link,
html body.page-id-2036 .elementor-element-b6f3a1b a.elementor-button-link {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 22px 24px !important;
    background-color: #A88141 !important;
    background: #A88141 !important;
    color: #F5EFE7 !important;
    text-align: center !important;
    border-radius: 0 !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: 0.04em !important;
    border: none !important;
    margin: 0 !important;
    text-transform: none !important;
    transition: background-color 0.25s ease !important;
    line-height: 1.3 !important;
}
html body.page-id-2036 .elementor-element-50fbd5d .elementor-button:hover,
html body.page-id-2036 .elementor-element-427dfb8 .elementor-button:hover,
html body.page-id-2036 .elementor-element-66f94f5 .elementor-button:hover,
html body.page-id-2036 .elementor-element-b6f3a1b .elementor-button:hover,
html body.page-id-2036 .elementor-element-50fbd5d a.elementor-button-link:hover,
html body.page-id-2036 .elementor-element-427dfb8 a.elementor-button-link:hover,
html body.page-id-2036 .elementor-element-66f94f5 a.elementor-button-link:hover,
html body.page-id-2036 .elementor-element-b6f3a1b a.elementor-button-link:hover {
    background-color: #8B6914 !important;
    color: #FFFFFF !important;
}

/* Texto del boton */
html body.page-id-2036 .elementor-element-50fbd5d .elementor-button-text,
html body.page-id-2036 .elementor-element-427dfb8 .elementor-button-text,
html body.page-id-2036 .elementor-element-66f94f5 .elementor-button-text,
html body.page-id-2036 .elementor-element-b6f3a1b .elementor-button-text {
    color: inherit !important;
    font-size: inherit !important;
    font-weight: inherit !important;
}

/* ============================================================
 * Fin AZ Polish v1
 * ============================================================ */



/* ============================================================
 * FIX MENU MOBILE FULLSCREEN EN SCROLL (2026-04-27)
 * ============================================================
 * Causa: cuando body.az-scrolled, el JS aplica:
 *   navbar: top:10, left:16, right:16, border-radius:16 (caja flotante)
 *   menu widget 937f571: transform: scale(0.85)
 * El transform crea nuevo containing block → position:fixed del dropdown
 * deja de ser relativo al viewport y NO llega a pantalla completa.
 *
 * Solución: cuando AMBAS clases (az-scrolled + az-menu-open) en body:
 *   1) Quitar transform del menu widget
 *   2) Reset navbar a top:0/left:0/right:0/border-radius:0 (full width)
 *   3) Forzar el dropdown a 100vw/100vh (defensivo, ya cubierto en otras reglas)
 * ------------------------------------------------------------ */

@media (max-width: 1024px) {
    /* 1) Anular transform/scale del menu widget cuando menu abierto (con o sin scroll) */
    body.az-menu-open .elementor-3145 .elementor-element.elementor-element-937f571,
    body.az-menu-open .elementor-3145 .elementor-element.elementor-element-270d6d4,
    body.az-menu-open .elementor-3145 {
        transform: none !important;
        transform-origin: 0 0 !important;
    }

    /* 2) Si scrolled + menu abierto: navbar a ancho completo y top 0 */
    body.az-scrolled.az-menu-open .elementor-3145 .elementor-element.elementor-element-270d6d4,
    body.az-menu-open.az-scrolled .elementor-3145 .elementor-element.elementor-element-270d6d4 {
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        width: 100% !important;
        border-radius: 0 !important;
        padding-top: 12px !important;
        padding-bottom: 12px !important;
    }

    /* 3) Dropdown fullscreen defensivo (cubre todos los estados) */
    html body.az-menu-open .elementor-3145 .elementor-element.elementor-element-937f571 .elementor-nav-menu__container.elementor-nav-menu--dropdown,
    html body.az-menu-open .elementor-nav-menu--dropdown.az-fullscreen-open,
    html body > .elementor-nav-menu--dropdown.az-fullscreen-open {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        right: 0 !important;
        bottom: 0 !important;
        width: 100vw !important;
        height: 100vh !important;
        height: 100dvh !important;
        min-height: 100vh !important;
        max-height: none !important;
        transform: none !important;
        z-index: 99999 !important;
    }
}
/* ============================================================
 * Fin FIX MENU MOBILE FULLSCREEN EN SCROLL
 * ============================================================ */


/* ============ AZ DISCLAIMER GLOBAL v1 ============
 * Estilo del bloque disclaimer inyectado por MU-plugin az-disclaimer.php
 * en paginas de terapias / TNAI / cupido. Crema sutil con borde gold.
 * ====================================================================== */

.az-disclaimer-block {
    max-width: 920px;
    margin: 60px auto 40px;
    padding: 26px 32px;
    background: rgba(245, 239, 231, 0.55);
    border: 1px solid rgba(196, 155, 87, 0.22);
    border-left: 3px solid #C49B57;
    border-radius: 14px;
    font-family: 'Alexandria', sans-serif;
    font-size: 0.92rem;
    line-height: 1.7;
    color: #4A4A41;
}
.az-disclaimer-block p {
    margin: 0 0 12px 0;
}
.az-disclaimer-block p:last-child {
    margin-bottom: 0;
}
.az-disclaimer-block .az-disclaimer-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    color: #2A3124;
    font-weight: 600;
    letter-spacing: 0.02em;
    margin-bottom: 8px;
}
@media (max-width: 768px) {
    .az-disclaimer-block {
        margin: 40px 20px 30px;
        padding: 22px 22px;
        font-size: 0.88rem;
    }
}


/* ============ AZ AUTHORITY BLOCK v1 ============ */
.az-authority-block {
    background: linear-gradient(180deg, #F5EFE7 0%, #FAF6EE 100%);
    padding: 80px 24px;
    margin: 0;
    border-top: 1px solid rgba(196, 155, 87, 0.18);
}
.az-authority-inner {
    max-width: 1180px;
    margin: 0 auto;
    text-align: center;
}
.az-authority-eyebrow {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #C49B57;
    font-weight: 600;
    margin: 0 0 14px 0;
}
.az-authority-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: #2A3124;
    line-height: 1.25;
    font-weight: 600;
    max-width: 760px;
    margin: 0 auto 50px;
    letter-spacing: 0.005em;
}
.az-authority-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 18px;
    margin: 0 auto;
}
.az-authority-card {
    background: #FFFFFF;
    border: 1px solid rgba(196, 155, 87, 0.20);
    border-radius: 14px;
    padding: 28px 18px;
    text-decoration: none;
    color: #2A3124;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    cursor: pointer;
}
.az-authority-card.az-authority-card-static {
    cursor: default;
}
.az-authority-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(30, 36, 25, 0.10);
    border-color: rgba(196, 155, 87, 0.45);
}
.az-authority-icon {
    color: #C49B57;
    margin-bottom: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.az-authority-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem;
    color: #2A3124;
    font-weight: 600;
    line-height: 1.1;
}
.az-authority-label {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.82rem;
    color: #5A5A52;
    line-height: 1.4;
    text-align: center;
}
.az-authority-foot {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.78rem;
    color: #6F6A60;
    margin: 36px auto 0;
    max-width: 720px;
    line-height: 1.6;
    font-style: italic;
}
@media (max-width: 1024px) {
    .az-authority-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
    .az-authority-block { padding: 56px 16px; }
    .az-authority-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .az-authority-card { padding: 22px 12px; }
    .az-authority-num { font-size: 1.15rem; }
    .az-authority-label { font-size: 0.76rem; }
}


/* ============ AZ AUTHORITY BLOCK v2 - 6 cols ============ */
.az-authority-grid { grid-template-columns: repeat(6, 1fr) !important; gap: 14px !important; }
.az-authority-card { padding: 24px 12px !important; min-height: 145px !important; }
.az-authority-num { font-size: 1.18rem !important; line-height: 1.15 !important; }
.az-authority-label { font-size: 0.78rem !important; line-height: 1.4 !important; }
.az-card-tv:hover { background: linear-gradient(180deg, #FFFFFF 0%, #FAF6EE 100%) !important; }
@media (max-width: 1024px) {
    .az-authority-grid { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 600px) {
    .az-authority-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .az-authority-card { padding: 20px 10px !important; min-height: 130px !important; }
    .az-authority-num { font-size: 1rem !important; }
    .az-authority-label { font-size: 0.72rem !important; }
}


/* ============ AZ PILLARS SECTION v1 ============ */
.az-pillars-section {
    background: #FFFFFF;
    padding: 80px 24px;
    border-top: 1px solid rgba(196, 155, 87, 0.15);
}
.az-pillars-inner {
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}
.az-pillars-eyebrow {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #C49B57;
    font-weight: 600;
    margin: 0 0 14px 0;
}
.az-pillars-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 3vw, 2.2rem);
    color: #2A3124;
    font-weight: 600;
    line-height: 1.25;
    margin: 0 0 14px 0;
}
.az-pillars-sub {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.96rem;
    color: #5A5A52;
    margin: 0 auto 40px;
    max-width: 620px;
    line-height: 1.6;
}
.az-pillars-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
.az-pillars-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #F5EFE7;
    border: 1px solid rgba(196, 155, 87, 0.22);
    border-radius: 14px;
    padding: 20px 24px;
    text-decoration: none;
    color: #2A3124;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem;
    font-weight: 600;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background 0.2s ease;
    text-align: left;
}
.az-pillars-card:hover {
    transform: translateX(4px);
    background: #FFFFFF;
    border-color: rgba(196, 155, 87, 0.55);
    box-shadow: 0 6px 18px rgba(30, 36, 25, 0.10);
}
.az-pillars-card-arrow {
    color: #C49B57;
    transition: transform 0.2s ease;
    flex-shrink: 0;
    margin-left: 14px;
}
.az-pillars-card:hover .az-pillars-card-arrow { transform: translateX(4px); }
@media (max-width: 768px) {
    .az-pillars-section { padding: 56px 18px; }
    .az-pillars-grid { grid-template-columns: repeat(1, 1fr); gap: 10px; }
    .az-pillars-card { font-size: 1.05rem; padding: 18px 20px; }
}
@media (min-width: 769px) and (max-width: 1024px) {
    .az-pillars-grid { grid-template-columns: repeat(2, 1fr); }
}


/* ============ PROCESOS CARDS LINK HOVER v1 ============ */
body.page-id-2036 .elementor-element-24af504 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-24af504:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-29df681 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-29df681:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-9aa0114 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-9aa0114:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-4b70968 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-4b70968:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-105ffb4 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-105ffb4:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-fc4abd3 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-fc4abd3:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-444aa24 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-444aa24:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}
body.page-id-2036 .elementor-element-5f68c75 {
    cursor: pointer !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
body.page-id-2036 .elementor-element-5f68c75:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 28px rgba(30, 36, 25, 0.12);
    border-color: rgba(196, 155, 87, 0.45) !important;
}


/* ============ AZ RELATED LINKS BLOCK v1 ============ */
.az-related-block {
    background: rgba(245, 239, 231, 0.4);
    padding: 60px 24px;
    margin: 0;
    border-top: 1px solid rgba(196, 155, 87, 0.18);
}
.az-related-inner {
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}
.az-related-eyebrow {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #C49B57;
    font-weight: 600;
    margin: 0 0 12px 0;
}
.az-related-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.4rem, 2.6vw, 1.85rem);
    color: #2A3124;
    font-weight: 600;
    line-height: 1.3;
    margin: 0 0 32px 0;
}
.az-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 14px;
    text-align: left;
}
.az-related-card {
    background: #FFFFFF;
    border: 1px solid rgba(196, 155, 87, 0.20);
    border-radius: 14px;
    padding: 20px 22px;
    text-decoration: none;
    color: #2A3124;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    position: relative;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}
.az-related-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(30, 36, 25, 0.10);
    border-color: rgba(196, 155, 87, 0.50);
}
.az-related-card-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.18rem;
    font-weight: 600;
    color: #2A3124;
    line-height: 1.25;
}
.az-related-card-sub {
    font-family: 'Alexandria', sans-serif;
    font-size: 0.85rem;
    color: #5A5A52;
    line-height: 1.5;
}
.az-related-card-arrow {
    position: absolute;
    top: 22px;
    right: 18px;
    color: #C49B57;
    transition: transform 0.2s ease;
}
.az-related-card:hover .az-related-card-arrow { transform: translateX(3px); }
@media (max-width: 768px) {
    .az-related-block { padding: 44px 18px; }
    .az-related-grid { grid-template-columns: 1fr; gap: 10px; }
}


/* ============ AZ AUTHORITY ICON LOGO v1 ============ */
.az-authority-icon.az-icon-logo {
    width: 40px; height: 40px;
    border-radius: 8px;
    background: rgba(255,255,255,0.95);
    padding: 4px;
    box-shadow: 0 2px 6px rgba(30,36,25,0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    margin-bottom: 8px;
}
.az-authority-icon.az-icon-logo img {
    width: 28px;
    height: 28px;
    object-fit: contain;
    display: block;
}


/* ============ AZ AUTHORITY BLOCK v4 - 9 cards 3x3 ============ */
.az-authority-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 16px !important; }
.az-authority-card { padding: 28px 18px !important; min-height: 165px !important; }
.az-authority-num { font-size: 1.22rem !important; line-height: 1.18 !important; }
.az-authority-label { font-size: 0.82rem !important; line-height: 1.45 !important; }
.az-authority-eyebrow { font-size: .76rem !important; }
.az-card-tv:hover { background: linear-gradient(180deg, #FFFFFF 0%, #FAF6EE 100%) !important; }
@media (max-width: 1024px) {
    .az-authority-grid { grid-template-columns: repeat(2, 1fr) !important; }
}
@media (max-width: 600px) {
    .az-authority-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .az-authority-card { padding: 20px 12px !important; min-height: 140px !important; }
    .az-authority-num { font-size: 1rem !important; }
    .az-authority-label { font-size: 0.74rem !important; }
}


/* ============ AZ AUTHORITY BLOCK v5 - 10 cards 5x2 ============ */
.az-authority-grid { grid-template-columns: repeat(5, 1fr) !important; gap: 14px !important; }
.az-authority-card { padding: 24px 14px !important; min-height: 160px !important; }
.az-authority-num { font-size: 1.05rem !important; line-height: 1.18 !important; }
.az-authority-label { font-size: 0.76rem !important; line-height: 1.4 !important; }
@media (max-width: 1200px) {
    .az-authority-grid { grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 600px) {
    .az-authority-grid { grid-template-columns: repeat(2, 1fr) !important; gap: 10px !important; }
    .az-authority-card { padding: 20px 10px !important; min-height: 130px !important; }
    .az-authority-num { font-size: 0.92rem !important; }
    .az-authority-label { font-size: 0.7rem !important; }
}


/* ============ AZ NEWSLETTER v1 ============ */
.az-nl-footer-wrap { padding: 28px 24px; background: #1E2419; border-top: 1px solid rgba(196,155,87,0.22); }
.az-nl-compact { max-width: 720px; margin: 0 auto; text-align: center; }
.az-nl-compact .az-nl-eyebrow-c { font-family: 'Alexandria',sans-serif; font-size: .82rem; color: #C49B57; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 14px; font-weight: 600; }
.az-nl-compact .az-nl-form { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 480px; margin: 0 auto; }
.az-nl-compact input[type=email] { flex: 1 1 220px; padding: 12px 16px; border: 1px solid rgba(245,239,231,0.18); background: rgba(245,239,231,0.05); color: #F5EFE7; border-radius: 10px; font-size: .95rem; font-family: 'Alexandria',sans-serif; outline: none; }
.az-nl-compact input[type=email]::placeholder { color: rgba(245,239,231,0.55); }
.az-nl-compact input[type=email]:focus { border-color: #C49B57; background: rgba(245,239,231,0.10); }
.az-nl-compact button { padding: 12px 22px; background: #C49B57; color: #FFFFFF; border: none; border-radius: 10px; font-family: 'Alexandria',sans-serif; font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: transform .15s,background .15s; }
.az-nl-compact button:hover { background: #B58A4A; transform: translateY(-1px); }
.az-nl-compact .az-nl-btn-arrow { transition: transform .15s; }
.az-nl-compact button:hover .az-nl-btn-arrow { transform: translateX(2px); }
.az-nl-compact .az-nl-msg { margin-top: 10px; font-size: .88rem; min-height: 20px; }
.az-nl-msg.az-nl-ok { color: #88C078; }
.az-nl-msg.az-nl-err { color: #E8836A; }
.az-nl-msg.az-nl-loading { color: rgba(245,239,231,0.6); }
.az-nl-block { max-width: 760px; margin: 50px auto 30px; padding: 38px 36px; background: linear-gradient(135deg,#2A3124 0%,#1E2419 100%); border-radius: 18px; color: #F5EFE7; box-shadow: 0 12px 32px rgba(30,36,25,0.20); border: 1px solid rgba(196,155,87,0.18); }
.az-nl-block .az-nl-text { text-align: center; margin-bottom: 22px; }
.az-nl-block .az-nl-eyebrow { font-family: 'Alexandria',sans-serif; font-size: .76rem; color: #C49B57; letter-spacing: .18em; text-transform: uppercase; margin: 0 0 10px; font-weight: 600; }
.az-nl-block .az-nl-title { font-family: 'Cormorant Garamond',serif; font-size: clamp(1.3rem,2.4vw,1.7rem); color: #F5EFE7; line-height: 1.25; font-weight: 600; margin: 0 0 12px; }
.az-nl-block .az-nl-sub { font-family: 'Alexandria',sans-serif; font-size: .92rem; color: rgba(245,239,231,.78); line-height: 1.6; margin: 0; max-width: 540px; margin-left: auto; margin-right: auto; }
.az-nl-block .az-nl-form { display: flex; flex-wrap: wrap; gap: 10px; max-width: 520px; margin: 22px auto 0; }
.az-nl-block input[type=email] { flex: 1 1 220px; padding: 14px 18px; border: 1px solid rgba(245,239,231,0.22); background: rgba(245,239,231,0.06); color: #F5EFE7; border-radius: 10px; font-size: 1rem; font-family: 'Alexandria',sans-serif; outline: none; }
.az-nl-block input[type=email]::placeholder { color: rgba(245,239,231,0.55); }
.az-nl-block input[type=email]:focus { border-color: #C49B57; }
.az-nl-block button { padding: 14px 26px; background: #C49B57; color: #FFFFFF; border: none; border-radius: 10px; font-family: 'Alexandria',sans-serif; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; letter-spacing: .02em; transition: transform .15s,background .15s; }
.az-nl-block button:hover { background: #B58A4A; transform: translateY(-1px); }
.az-nl-block .az-nl-msg { margin-top: 12px; text-align: center; font-size: .9rem; min-height: 22px; }
@media (max-width: 600px) {
    .az-nl-block { padding: 28px 22px; margin: 40px 16px 24px; }
    .az-nl-compact .az-nl-form, .az-nl-block .az-nl-form { flex-direction: column; }
    .az-nl-compact button, .az-nl-block button { width: 100%; justify-content: center; }
}


/* ============ AZ NEWSLETTER BANNER v2 - banner sin form, link a /guia ============ */
/* Compact (footer) - una linea con CTA */
.az-nl-footer-wrap { padding: 22px 24px; background: #1E2419; border-top: 1px solid rgba(196,155,87,0.22); }
.az-nl-compact { max-width: 920px; margin: 0 auto; }
.az-nl-compact-row { display: flex; align-items: center; justify-content: center; gap: 18px; flex-wrap: wrap; }
.az-nl-compact .az-nl-eyebrow-c { font-family: 'Alexandria',sans-serif; font-size: .92rem; color: #F5EFE7; font-weight: 500; margin: 0; }
.az-nl-compact .az-nl-cta-link { display: inline-flex; align-items: center; gap: 6px; padding: 10px 22px; background: #C49B57; color: #FFFFFF; border-radius: 10px; text-decoration: none; font-family: 'Alexandria',sans-serif; font-weight: 600; font-size: .92rem; transition: background .15s,transform .15s; }
.az-nl-compact .az-nl-cta-link:hover { background: #B58A4A; transform: translateY(-1px); }
.az-nl-block { max-width: 760px; margin: 50px auto 30px; padding: 38px 36px; background: linear-gradient(135deg,#2A3124 0%,#1E2419 100%); border-radius: 18px; color: #F5EFE7; box-shadow: 0 12px 32px rgba(30,36,25,0.20); border: 1px solid rgba(196,155,87,0.18); text-align: center; }
.az-nl-block .az-nl-eyebrow { font-family: 'Alexandria',sans-serif; font-size: .76rem; color: #C49B57; letter-spacing: .18em; text-transform: uppercase; margin: 0 0 10px; font-weight: 600; }
.az-nl-block .az-nl-title { font-family: 'Cormorant Garamond',serif; font-size: clamp(1.4rem,2.6vw,1.8rem); color: #F5EFE7; line-height: 1.25; font-weight: 600; margin: 0 0 12px; }
.az-nl-block .az-nl-sub { font-family: 'Alexandria',sans-serif; font-size: .94rem; color: rgba(245,239,231,.78); line-height: 1.6; margin: 0 auto 24px; max-width: 540px; }
.az-nl-block .az-nl-cta-link { display: inline-flex; align-items: center; gap: 8px; padding: 14px 28px; background: #C49B57; color: #FFFFFF; border-radius: 12px; text-decoration: none; font-family: 'Alexandria',sans-serif; font-weight: 700; font-size: 1rem; letter-spacing: .02em; transition: background .15s,transform .15s; }
.az-nl-block .az-nl-cta-link:hover { background: #B58A4A; transform: translateY(-1px); }
@media (max-width: 600px) {
    .az-nl-block { padding: 28px 22px; margin: 40px 16px 24px; }
    .az-nl-compact-row { flex-direction: column; }
}


/* ============ AZ NEWSLETTER FORM v3 webhook ============ */
.az-nl-footer-wrap { padding: 28px 24px; background: #1E2419; border-top: 1px solid rgba(196,155,87,0.22); }
.az-nl-compact { max-width: 720px; margin: 0 auto; text-align: center; }
.az-nl-compact .az-nl-eyebrow-c { font-family: 'Alexandria',sans-serif; font-size: .82rem; color: #C49B57; letter-spacing: .12em; text-transform: uppercase; margin: 0 0 14px; font-weight: 600; }
.az-nl-compact .az-nl-form { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; max-width: 480px; margin: 0 auto; }
.az-nl-compact input[type=email] { flex: 1 1 220px; padding: 12px 16px; border: 1px solid rgba(245,239,231,0.18); background: rgba(245,239,231,0.05); color: #F5EFE7; border-radius: 10px; font-size: .95rem; font-family: 'Alexandria',sans-serif; outline: none; }
.az-nl-compact input[type=email]::placeholder { color: rgba(245,239,231,0.55); }
.az-nl-compact input[type=email]:focus { border-color: #C49B57; background: rgba(245,239,231,0.10); }
.az-nl-compact button { padding: 12px 22px; background: #C49B57; color: #FFFFFF; border: none; border-radius: 10px; font-family: 'Alexandria',sans-serif; font-weight: 600; cursor: pointer; display: inline-flex; align-items: center; gap: 6px; transition: transform .15s,background .15s; }
.az-nl-compact button:hover { background: #B58A4A; transform: translateY(-1px); }
.az-nl-compact .az-nl-btn-arrow { transition: transform .15s; }
.az-nl-compact button:hover .az-nl-btn-arrow { transform: translateX(2px); }
.az-nl-compact .az-nl-msg { margin-top: 10px; font-size: .88rem; min-height: 20px; color: #F5EFE7; }
.az-nl-block { max-width: 760px; margin: 50px auto 30px; padding: 38px 36px; background: linear-gradient(135deg,#2A3124 0%,#1E2419 100%); border-radius: 18px; color: #F5EFE7; box-shadow: 0 12px 32px rgba(30,36,25,0.20); border: 1px solid rgba(196,155,87,0.18); }
.az-nl-block .az-nl-text { text-align: center; margin-bottom: 22px; }
.az-nl-block .az-nl-eyebrow { font-family: 'Alexandria',sans-serif; font-size: .76rem; color: #C49B57; letter-spacing: .18em; text-transform: uppercase; margin: 0 0 10px; font-weight: 600; }
.az-nl-block .az-nl-title { font-family: 'Cormorant Garamond',serif; font-size: clamp(1.3rem,2.4vw,1.7rem); color: #F5EFE7; line-height: 1.25; font-weight: 600; margin: 0 0 12px; }
.az-nl-block .az-nl-sub { font-family: 'Alexandria',sans-serif; font-size: .92rem; color: rgba(245,239,231,.78); line-height: 1.6; margin: 0 auto; max-width: 540px; }
.az-nl-block .az-nl-form { display: flex; flex-wrap: wrap; gap: 10px; max-width: 520px; margin: 22px auto 0; }
.az-nl-block input[type=email] { flex: 1 1 220px; padding: 14px 18px; border: 1px solid rgba(245,239,231,0.22); background: rgba(245,239,231,0.06); color: #F5EFE7; border-radius: 10px; font-size: 1rem; font-family: 'Alexandria',sans-serif; outline: none; }
.az-nl-block input[type=email]::placeholder { color: rgba(245,239,231,0.55); }
.az-nl-block input[type=email]:focus { border-color: #C49B57; }
.az-nl-block button { padding: 14px 26px; background: #C49B57; color: #FFFFFF; border: none; border-radius: 10px; font-family: 'Alexandria',sans-serif; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; gap: 8px; transition: transform .15s,background .15s; }
.az-nl-block button:hover { background: #B58A4A; transform: translateY(-1px); }
.az-nl-block .az-nl-msg { margin-top: 12px; text-align: center; font-size: .9rem; min-height: 22px; }
.az-nl-msg.az-nl-ok { color: #88C078; }
.az-nl-msg.az-nl-err { color: #E8836A; }
.az-nl-msg.az-nl-loading { color: rgba(245,239,231,0.6); }
@media (max-width: 600px) {
    .az-nl-block { padding: 28px 22px; margin: 40px 16px 24px; }
    .az-nl-compact .az-nl-form, .az-nl-block .az-nl-form { flex-direction: column; }
    .az-nl-compact button, .az-nl-block button { width: 100%; justify-content: center; }
}
