﻿/* =====================================================
   DISEÑO HOMEPAGE — ASERTIVA CONSULTORES
   Versión: 4.0 — UX/UI Pro
   DOM real verificado 2026-04-18
   ===================================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

/* =====================================================
   VARIABLES LOCALES
   ===================================================== */
:root {
  --navy:        #0d1f3c;
  --navy-mid:    #1a3d7e;
  --navy-light:  #2e5499;
  --gold:        #f0ad14;
  --gold-dark:   #c48200;
  --white:       #ffffff;
  --gray-50:     #f8f9fc;
  --gray-100:    #f1f3f7;
  --gray-600:    #4b5563;
  --gray-700:    #374151;
  --gray-900:    #111827;
  --radius:      8px;
  --radius-lg:   14px;
  --trans:       0.22s cubic-bezier(0.4, 0, 0.2, 1);
  --shadow-sm:   0 1px 4px rgba(13,31,60,0.08);
  --shadow-md:   0 4px 20px rgba(13,31,60,0.14);
  --shadow-lg:   0 10px 40px rgba(13,31,60,0.20);
  --shadow-gold: 0 4px 18px rgba(240,173,20,0.35);
}

/* =====================================================
   BASE
   ===================================================== */
body,
.elementor-page-11 {
  font-family: "Inter", sans-serif !important;
  background: var(--gray-50) !important;
  color: var(--gray-700) !important;
  -webkit-font-smoothing: antialiased !important;
  text-rendering: optimizeLegibility !important;
}

/* =====================================================
   1. HEADER — BANDA SUPERIOR  (e88b477)
   ===================================================== */

/* Contenedor externo: fondo full-width */
.elementor-element-e88b477 {
  background: var(--white) !important;
  border-bottom: 3px solid var(--gold) !important;
  padding: 0 !important;
  box-shadow: var(--shadow-sm) !important;
  position: relative !important;
  z-index: 100 !important;
  width: 100% !important;
}

/* e-con-inner: forzar fila horizontal con espacio entre columnas */
.elementor-element-e88b477 > .e-con-inner {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 8px 24px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Columna LOGO — oculta */
.elementor-element-77a52aeb {
  display: none !important;
}

/* Columna SLOGAN — crece y se centra */
.elementor-element-44b0416f {
  flex: 1 1 auto !important;
  width: auto !important;
  min-width: 0 !important;
  padding: 0 16px !important;
}

/* =====================================================
   BARRA SOCIAL FIJA — todas las páginas
   ===================================================== */
#asertiva-social-sidebar {
  position: fixed;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9990;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
#asertiva-social-sidebar .asertiva-social-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background-color: var(--navy-mid);
  box-shadow: 0 2px 10px rgba(13,31,60,0.22);
  transition: background-color 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
  text-decoration: none;
}
#asertiva-social-sidebar .asertiva-social-icon:hover {
  background-color: var(--gold);
  transform: scale(1.12) translateX(-3px);
  box-shadow: 0 6px 20px rgba(240,173,20,0.40);
}
#asertiva-social-sidebar .asertiva-social-icon svg {
  width: 20px;
  height: 20px;
  fill: #fff;
  stroke: none;
}
@media (max-width: 767px) {
  #asertiva-social-sidebar {
    right: 10px;
    gap: 8px;
  }
  #asertiva-social-sidebar .asertiva-social-icon {
    width: 38px;
    height: 38px;
  }
  #asertiva-social-sidebar .asertiva-social-icon svg {
    width: 17px;
    height: 17px;
  }
}

/* Columna SOCIAL de Elementor — oculta (reemplazada por #asertiva-social-sidebar) */
.elementor-element-6ff52193 {
  display: none !important;
}

/* Logo — tamaño razonable */
.elementor-element-be83560 img {
  max-width: 75px !important;
  height: auto !important;
  display: block !important;
  transition: transform var(--trans) !important;
}
.elementor-element-be83560 img:hover {
  transform: scale(1.06) !important;
}

/* Slogan — reducir tamaño agresivamente */
.elementor-element-4c07a74b,
.elementor-element-4c07a74b .elementor-widget-container {
  overflow: hidden !important;
}
.elementor-element-4c07a74b h4 {
  font-family: "Inter", sans-serif !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  line-height: 1.5 !important;
  margin: 0 !important;
  padding: 0 !important;
}
.elementor-element-4c07a74b h4 span,
.elementor-element-4c07a74b h4 * {
  font-family: "Inter", sans-serif !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  color: var(--navy-mid) !important;
  line-height: 1.5 !important;
}
.elementor-widget-text-editor.elementor-element-4c07a74b *:not(style) {
  color: var(--navy-mid) !important;
  font-size: 0.82rem !important;
}

/* Redes sociales de Elementor en header — ocultas (usamos sidebar PHP) */
.elementor-element-7f3158f0 {
  display: none !important;
}

/* =====================================================
   2. BARRA NAV  (e877121) — fondo forzado con máxima especificidad
   ===================================================== */

/* Fondo full-width con múltiples selectores para ganar la cascada */
.elementor-page-11 .elementor-element.elementor-element-e877121,
.elementor-element-e877121.e-con,
div.elementor-element-e877121 {
  background-color: var(--navy) !important;
  background: var(--navy) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9990 !important;
  box-shadow: 0 3px 24px rgba(0,0,0,0.5) !important;
  width: 100% !important;
}

/* Franja de color también como pseudo para garantizar cobertura */
.elementor-element-e877121::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: var(--navy) !important;
  z-index: -1 !important;
  pointer-events: none !important;
}

.elementor-element-e877121 .e-con-inner {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  min-height: 0 !important;
}

/* Nav widget container — sin padding extra */
.elementor-element-e877121 .elementor-widget-container,
.elementor-element-c2894d0 .elementor-widget-container {
  padding: 0 !important;
  margin: 0 !important;
}

/* Links — altura compacta */
.elementor-element-e877121 .elementor-nav-menu__container .elementor-nav-menu > li > a,
.elementor-element-e877121 .elementor-item {
  font-family: "Inter", sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: rgba(197,212,238,0.9) !important;
  padding: 11px 18px !important;
  display: block !important;
  position: relative !important;
  line-height: 1 !important;
  transition: color var(--trans) !important;
}

/* Línea dorada animada bajo el link */
.elementor-element-e877121 .elementor-item::after {
  content: "" !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 50% !important;
  transform: translateX(-50%) scaleX(0) !important;
  width: 80% !important;
  height: 3px !important;
  background: var(--gold) !important;
  border-radius: 2px !important;
  transition: transform var(--trans) !important;
}

.elementor-element-e877121 .elementor-item:hover,
.elementor-element-e877121 .elementor-item-active,
.elementor-element-e877121 .elementor-item.elementor-item-active {
  color: var(--gold) !important;
}

.elementor-element-e877121 .elementor-item:hover::after,
.elementor-element-e877121 .elementor-item-active::after,
.elementor-element-e877121 .elementor-item.elementor-item-active::after {
  transform: translateX(-50%) scaleX(1) !important;
}

/* Pointer overline nativo de Elementor — dorado */
.elementor-element-e877121 .e--pointer-overline .elementor-item::before {
  background-color: var(--gold) !important;
  height: 3px !important;
}

/* =====================================================
   3. TIPOGRAFÍA DE CONTENIDO
   ===================================================== */

/* Párrafos */
.elementor-widget-text-editor p,
.elementor-widget-text-editor div {
  font-family: "Inter", sans-serif !important;
  font-size: 1.02rem !important;
  line-height: 1.85 !important;
  color: var(--gray-700) !important;
  margin-bottom: 1.1rem !important;
}

/* Encabezados */
.elementor-widget-heading h1 {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(2rem, 5vw, 3.4rem) !important;
  font-weight: 800 !important;
  color: var(--navy) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
}

.elementor-widget-heading h2 {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(1.5rem, 3.5vw, 2.3rem) !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  line-height: 1.2 !important;
  letter-spacing: -0.02em !important;
}

.elementor-widget-heading h3 {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(1.15rem, 2.5vw, 1.6rem) !important;
  font-weight: 600 !important;
  color: var(--navy-mid) !important;
  line-height: 1.3 !important;
}

.elementor-widget-heading h4 {
  font-family: "Inter", sans-serif !important;
  font-size: 1.12rem !important;
  font-weight: 600 !important;
  color: var(--navy-mid) !important;
  line-height: 1.4 !important;
}

.elementor-widget-heading h5,
.elementor-widget-heading h6 {
  font-family: "Inter", sans-serif !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  color: var(--gold-dark) !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
}

/* =====================================================
   4. SECCIONES — FONDOS Y ESPACIADO
   ===================================================== */

/* Separación vertical entre secciones */
.elementor-page-11 .e-con.e-parent {
  padding-top: 80px !important;
  padding-bottom: 80px !important;
  position: relative !important;
}

/* Sin padding extra en header/nav */
.elementor-element-e88b477,
.elementor-element-e877121 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Secciones impares — fondo blanco */
.elementor-page-11 .e-con.e-parent:nth-child(odd):not(.elementor-element-e88b477):not(.elementor-element-e877121) {
  background: #ffffff !important;
}

/* Secciones pares — fondo gris suave con ligero patrón */
.elementor-page-11 .e-con.e-parent:nth-child(even):not(.elementor-element-e88b477):not(.elementor-element-e877121) {
  background: #f4f6fb !important;
}

/* Línea decorativa dorada en la parte superior de cada sección par */
.elementor-page-11 .e-con.e-parent:nth-child(even):not(.elementor-element-e88b477):not(.elementor-element-e877121)::before {
  content: "" !important;
  position: absolute !important;
  top: 0; left: 0; right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, transparent, var(--gold), transparent) !important;
  opacity: 0.5 !important;
}

/* =====================================================
   5. TARJETAS / COLUMNAS — EFECTO HOVER
   ===================================================== */

.elementor-column .elementor-widget-wrap.elementor-element-populated {
  border-radius: 16px !important;
  padding: 36px 32px !important;
  transition: transform var(--trans), box-shadow var(--trans), background var(--trans), border-color var(--trans) !important;
  border: 1.5px solid transparent !important;
  background: #ffffff !important;
}

.elementor-column .elementor-widget-wrap.elementor-element-populated:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 20px 48px rgba(13,31,60,0.14) !important;
  background: #ffffff !important;
  border-color: rgba(240,173,20,0.4) !important;
}

/* =====================================================
   6. BOTONES — PROFESIONALES
   ===================================================== */

.elementor-widget-button .elementor-button {
  font-family: "Inter", sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.82rem !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  border-radius: 50px !important;
  padding: 15px 36px !important;
  background: linear-gradient(135deg, var(--navy-mid) 0%, var(--navy-light) 100%) !important;
  color: var(--white) !important;
  border: none !important;
  box-shadow: 0 4px 18px rgba(26,61,126,0.35) !important;
  transition: all var(--trans) !important;
  position: relative !important;
  overflow: hidden !important;
}

.elementor-widget-button .elementor-button::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 55%) !important;
  opacity: 0 !important;
  transition: opacity var(--trans) !important;
  border-radius: inherit !important;
}

.elementor-widget-button .elementor-button:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 30px rgba(26,61,126,0.45) !important;
}

.elementor-widget-button .elementor-button:hover::after {
  opacity: 1 !important;
}

.elementor-widget-button .elementor-button:active {
  transform: translateY(-1px) !important;
  box-shadow: 0 2px 10px rgba(26,61,126,0.25) !important;
}

/* Botón acento — dorado */
.elementor-widget-button .elementor-button.elementor-size-lg,
.elementor-widget-button .elementor-button[class*="accent"] {
  background: linear-gradient(135deg, #f0ad14 0%, #c48200 100%) !important;
  color: var(--navy) !important;
  box-shadow: 0 4px 18px rgba(240,173,20,0.40) !important;
}
.elementor-widget-button .elementor-button.elementor-size-lg:hover,
.elementor-widget-button .elementor-button[class*="accent"]:hover {
  box-shadow: 0 8px 28px rgba(240,173,20,0.55) !important;
}

/* =====================================================
   7. ÍCONOS SOCIALES — SECCIÓN CONTENIDO
   ===================================================== */

.elementor-widget-social-icons:not([class*="elementor-element-7f3158f0"]) .elementor-social-icon {
  background-color: var(--navy-mid) !important;
  border-radius: 50% !important;
  width: 44px !important;
  height: 44px !important;
  transition: background-color var(--trans), transform var(--trans), box-shadow var(--trans) !important;
  box-shadow: var(--shadow-sm) !important;
}
.elementor-widget-social-icons:not([class*="elementor-element-7f3158f0"]) .elementor-social-icon:hover {
  background-color: var(--gold) !important;
  transform: translateY(-4px) scale(1.1) !important;
  box-shadow: var(--shadow-gold) !important;
}
.elementor-widget-social-icons .elementor-social-icon i { color: var(--white) !important; }

/* =====================================================
   8. DIVISORES — ACENTO DORADO
   ===================================================== */

.elementor-widget-divider .elementor-divider-separator {
  border-color: var(--gold) !important;
  border-width: 3px !important;
  width: 56px !important;
  border-radius: 9999px !important;
}

/* =====================================================
   9. IMÁGENES — ZOOM SUAVE
   ===================================================== */

.elementor-widget-image {
  overflow: hidden !important;
  border-radius: 16px !important;
}
.elementor-widget-image img {
  border-radius: 16px !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  display: block !important;
  box-shadow: 0 6px 28px rgba(13,31,60,0.13) !important;
  transition: transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94), box-shadow 0.4s ease !important;
  will-change: transform !important;
}
.elementor-widget-image img:hover {
  transform: scale(1.04) !important;
  box-shadow: 0 16px 50px rgba(13,31,60,0.22) !important;
}
/* Imágenes en columnas — aspect ratio consistente */
.elementor-column .elementor-widget-image {
  border-radius: 16px !important;
  overflow: hidden !important;
}
.elementor-column .elementor-widget-image .elementor-image {
  border-radius: 16px !important;
  overflow: hidden !important;
}

/* =====================================================
   10. GALERÍA
   ===================================================== */

.elementor-gallery-item {
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  transition: transform var(--trans), box-shadow var(--trans) !important;
}
.elementor-gallery-item:hover {
  transform: translateY(-4px) scale(1.01) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* =====================================================
   11. FORMULARIO CF7
   ===================================================== */

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea {
  font-family: "Inter", sans-serif !important;
  font-size: 0.95rem !important;
  border: 1.5px solid #d1d5db !important;
  border-radius: var(--radius) !important;
  padding: 12px 16px !important;
  width: 100% !important;
  color: var(--gray-900) !important;
  background: var(--white) !important;
  transition: border-color var(--trans), box-shadow var(--trans) !important;
  box-shadow: var(--shadow-sm) !important;
}
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
  border-color: var(--navy-mid) !important;
  box-shadow: 0 0 0 3px rgba(26,61,126,0.15) !important;
  outline: none !important;
}
.wpcf7-submit {
  font-family: "Inter", sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.8rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  background: var(--navy-mid) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: var(--radius) !important;
  padding: 14px 36px !important;
  cursor: pointer !important;
  transition: background var(--trans), transform var(--trans), box-shadow var(--trans) !important;
  box-shadow: var(--shadow-md) !important;
}
.wpcf7-submit:hover {
  background: var(--navy) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* =====================================================
   12. SCROLL SUAVE GLOBAL
   ===================================================== */

html {
  scroll-behavior: smooth !important;
}

/* =====================================================
   13. RESPONSIVE — TABLET (≤ 1024px)
   ===================================================== */

@media (max-width: 1024px) {
  .elementor-element-4c07a74b h4,
  .elementor-element-4c07a74b h4 span {
    font-size: 0.82rem !important;
  }
  .elementor-page-11 .e-con.e-parent,
  .elementor-page-30 .e-con.e-parent,
  .elementor-page-24 .e-con.e-parent {
    padding-top: 52px !important;
    padding-bottom: 52px !important;
  }
}

/* =====================================================
   14. RESPONSIVE — MÓVIL (≤ 767px)
   ===================================================== */

@media (max-width: 767px) {
  /* Header compacto */
  .elementor-element-e88b477 {
    padding: 8px 12px !important;
  }
  .elementor-element-be83560 img {
    max-width: 65px !important;
  }
  .elementor-element-4c07a74b h4,
  .elementor-element-4c07a74b h4 span {
    font-size: 0.76rem !important;
    line-height: 1.45 !important;
  }

  /* Nav links más compactos */
  .elementor-element-e877121 .elementor-item {
    padding: 9px 8px !important;
    font-size: 0.68rem !important;
    letter-spacing: 0.05em !important;
  }

  /* Espaciado secciones reducido */
  .elementor-page-11 .e-con.e-parent,
  .elementor-page-30 .e-con.e-parent,
  .elementor-page-24 .e-con.e-parent {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  /* Texto legible */
  .elementor-widget-text-editor p,
  .elementor-widget-text-editor div {
    font-size: 0.97rem !important;
    line-height: 1.7 !important;
  }

  /* Botones full-width */
  .elementor-widget-button .elementor-button {
    padding: 13px 20px !important;
    font-size: 0.76rem !important;
  }

  /* Tarjetas sin hover elevado (táctil) */
  .elementor-column .elementor-widget-wrap.elementor-element-populated:hover {
    transform: none !important;
    box-shadow: none !important;
  }

  /* Imágenes sin hover scale (táctil) */
  .elementor-widget-image img:hover {
    transform: none !important;
    box-shadow: none !important;
  }
}

/* =====================================================
   15. RESPONSIVE — MÓVIL PEQUEÑO (≤ 479px)
   ===================================================== */

@media (max-width: 479px) {
  .elementor-widget-heading h2 {
    font-size: 1.35rem !important;
  }
  .elementor-widget-heading h3 {
    font-size: 1.1rem !important;
  }
  .elementor-element-e877121 .elementor-item {
    padding: 9px 6px !important;
    font-size: 0.62rem !important;
  }
}

/* =====================================================
   16. NAV GLOBAL — todas las páginas (PHP-injected)
   ===================================================== */

#asertiva-site-header {
  background-color: #0d1f3c !important;
  background: #0d1f3c !important;
  width: 100% !important;
  display: block !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 9990 !important;
  box-shadow: 0 2px 16px rgba(0,0,0,0.45) !important;
  border-bottom: 3px solid #f0ad14 !important;
}

.asertiva-header-inner {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 6px 24px !important;
  gap: 24px !important;
  background: transparent !important;
}

.asertiva-logo {
  max-width: 56px !important;
  height: auto !important;
  display: block !important;
  filter: brightness(0) invert(1) !important;
  transition: transform 0.22s ease !important;
}
.asertiva-logo-link:hover .asertiva-logo {
  transform: scale(1.06) !important;
}

#asertiva-global-nav ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  gap: 4px !important;
  align-items: center !important;
}

#asertiva-global-nav ul li {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

#asertiva-global-nav ul li a {
  font-family: "Inter", sans-serif !important;
  font-size: 0.73rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #c5d4ee !important;
  text-decoration: none !important;
  padding: 10px 16px !important;
  display: block !important;
  border-radius: 4px !important;
  position: relative !important;
  background: transparent !important;
  transition: color 0.22s ease !important;
}

#asertiva-global-nav ul li a::after {
  content: "" !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 50% !important;
  transform: translateX(-50%) scaleX(0) !important;
  width: 70% !important;
  height: 2px !important;
  background: #f0ad14 !important;
  border-radius: 2px !important;
  transition: transform 0.22s ease !important;
}

#asertiva-global-nav ul li a:hover,
#asertiva-global-nav ul li a.active {
  color: #f0ad14 !important;
}

#asertiva-global-nav ul li a:hover::after,
#asertiva-global-nav ul li a.active::after {
  transform: translateX(-50%) scaleX(1) !important;
}

@media (max-width: 767px) {
  .asertiva-header-inner {
    padding: 5px 14px !important;
    gap: 12px !important;
  }
  .asertiva-logo {
    max-width: 44px !important;
  }
  #asertiva-global-nav ul li a {
    padding: 8px 10px !important;
    font-size: 0.65rem !important;
  }
}

@media (max-width: 479px) {
  #asertiva-global-nav ul {
    gap: 0 !important;
  }
  #asertiva-global-nav ul li a {
    padding: 8px 6px !important;
    font-size: 0.6rem !important;
  }
}

/* =====================================================
   17. PÁGINAS INTERNAS — Portafolio (page-30) y Contacto (page-24)
   ===================================================== */

/* Fondo de página igual que inicio */
.elementor-page-30,
.elementor-page-24 {
  background: var(--gray-50) !important;
}

/* Espaciado vertical entre secciones */
.elementor-page-30 .e-con.e-parent,
.elementor-page-24 .e-con.e-parent {
  padding-top: 64px !important;
  padding-bottom: 64px !important;
}

/* Secciones impares — fondo blanco */
.elementor-page-30 .e-con.e-parent:nth-child(odd),
.elementor-page-24 .e-con.e-parent:nth-child(odd) {
  background: var(--white) !important;
}

/* Secciones pares — fondo gris muy claro */
.elementor-page-30 .e-con.e-parent:nth-child(even),
.elementor-page-24 .e-con.e-parent:nth-child(even) {
  background: var(--gray-100) !important;
}

/* Títulos de página — acento dorado antes del h1/h2 */
.elementor-page-11 .elementor-widget-heading h1:first-of-type,
.elementor-page-30 .elementor-widget-heading h1:first-of-type,
.elementor-page-24 .elementor-widget-heading h1:first-of-type,
.elementor-page-11 .elementor-widget-heading h2:first-of-type,
.elementor-page-30 .elementor-widget-heading h2:first-of-type,
.elementor-page-24 .elementor-widget-heading h2:first-of-type {
  border-top: 4px solid var(--gold) !important;
  padding-top: 18px !important;
  display: inline-block !important;
}

/* Separador dorado decorativo bajo h2 */
.elementor-page-30 .elementor-widget-heading h2::after,
.elementor-page-24 .elementor-widget-heading h2::after {
  content: "" !important;
  display: block !important;
  width: 48px !important;
  height: 3px !important;
  background: var(--gold) !important;
  border-radius: 2px !important;
  margin-top: 10px !important;
}

/* ---- Responsive páginas internas ---- */

@media (max-width: 1024px) {
  .elementor-page-30 .e-con.e-parent,
  .elementor-page-24 .e-con.e-parent {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }
}

@media (max-width: 767px) {
  .elementor-page-30 .e-con.e-parent,
  .elementor-page-24 .e-con.e-parent {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }
}

/* =====================================================
   18. UX/UI PRO — MEJORAS GLOBALES v5.0
   ===================================================== */

/* --------------------------------------------------
   18A. ANIMACIONES DE ENTRADA
   -------------------------------------------------- */

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInLeft {
  from { opacity: 0; transform: translateX(-24px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Aplicar animación a widgets de contenido */
.elementor-widget-heading,
.elementor-widget-text-editor,
.elementor-widget-button,
.elementor-widget-image,
.elementor-widget-video,
.elementor-widget-google_maps {
  animation: fadeInUp 0.55s ease both;
}
.elementor-widget-heading { animation-delay: 0.05s !important; }
.elementor-widget-text-editor { animation-delay: 0.12s !important; }
.elementor-widget-button { animation-delay: 0.20s !important; }

/* --------------------------------------------------
   18B. HERO SLIDER — OVERLAY Y TIPOGRAFÍA
   -------------------------------------------------- */

/* Overlay con degradado diagonal — mejor legibilidad */
.elementor-slides .elementor-background-overlay {
  background: linear-gradient(
    125deg,
    rgba(9,20,40,0.82) 0%,
    rgba(13,31,60,0.58) 55%,
    rgba(13,31,60,0.22) 100%
  ) !important;
}

/* Slide — mejor altura */
.elementor-slides .swiper-slide {
  min-height: 520px !important;
}

/* Contenido del slide — mejor posicionamiento */
.elementor-slides .elementor-slide-content {
  max-width: 680px !important;
  padding: 0 !important;
}

/* Eyebrow label antes del título */
.elementor-slides .elementor-slide-heading {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(1.75rem, 4.5vw, 3.2rem) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.025em !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.45) !important;
  margin-bottom: 18px !important;
  color: #ffffff !important;
}

/* Descripción del slider */
.elementor-slides .elementor-slide-description {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(0.95rem, 2vw, 1.18rem) !important;
  font-weight: 400 !important;
  line-height: 1.7 !important;
  opacity: 0.93 !important;
  max-width: 560px !important;
  text-shadow: 0 1px 8px rgba(0,0,0,0.35) !important;
  margin-bottom: 32px !important;
  color: rgba(220,232,255,0.95) !important;
}

/* Botón CTA del slider — pill dorado */
.elementor-slides .elementor-slide-button {
  font-family: "Inter", sans-serif !important;
  font-weight: 700 !important;
  font-size: 0.82rem !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  border-radius: 50px !important;
  padding: 16px 40px !important;
  background: linear-gradient(135deg, #f0ad14 0%, #c48200 100%) !important;
  color: #0d1f3c !important;
  border: none !important;
  box-shadow: 0 6px 24px rgba(240,173,20,0.50) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
  display: inline-block !important;
}
.elementor-slides .elementor-slide-button:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 12px 36px rgba(240,173,20,0.62) !important;
}

/* Flechas del slider */
.elementor-slides .swiper-button-prev,
.elementor-slides .swiper-button-next {
  background: rgba(13,31,60,0.55) !important;
  border-radius: 50% !important;
  width: 48px !important;
  height: 48px !important;
  transition: background 0.22s ease !important;
}
.elementor-slides .swiper-button-prev:hover,
.elementor-slides .swiper-button-next:hover {
  background: rgba(240,173,20,0.85) !important;
}

/* Paginación del slider */
.elementor-slides .swiper-pagination-bullet {
  background: rgba(255,255,255,0.5) !important;
  transition: background 0.22s ease, transform 0.22s ease !important;
}
.elementor-slides .swiper-pagination-bullet-active {
  background: #f0ad14 !important;
  transform: scale(1.3) !important;
}

/* --------------------------------------------------
   18C. PORTAFOLIO — TARJETAS DE SERVICIOS
   -------------------------------------------------- */

/* Headings de servicios — Portafolio e Inicio */
.elementor-page-30 .elementor-widget-heading h2,
.elementor-page-11 .elementor-widget-heading h2 {
  font-family: "Inter", sans-serif !important;
  font-size: clamp(1.25rem, 2.5vw, 1.75rem) !important;
  font-weight: 700 !important;
  color: #0d1f3c !important;
  line-height: 1.25 !important;
  letter-spacing: -0.01em !important;
  padding-bottom: 12px !important;
  border-bottom: 3px solid #f0ad14 !important;
  display: inline-block !important;
  margin-bottom: 20px !important;
}

/* Texto de descripción de servicios */
.elementor-page-30 .elementor-widget-text-editor p,
.elementor-page-11 .elementor-widget-text-editor p {
  font-size: 1rem !important;
  line-height: 1.85 !important;
  color: #374151 !important;
  max-width: 72ch !important;
}

/* Video embeds en portafolio */
.elementor-page-30 .elementor-widget-video .elementor-video-container,
.elementor-page-30 .elementor-widget-video iframe,
.elementor-page-30 .elementor-widget-video video {
  border-radius: 14px !important;
  overflow: hidden !important;
  box-shadow: 0 10px 40px rgba(13,31,60,0.20) !important;
}
.elementor-page-30 .elementor-widget-video {
  border-radius: 14px !important;
  overflow: hidden !important;
  box-shadow: 0 10px 40px rgba(13,31,60,0.20) !important;
  transition: transform 0.35s ease, box-shadow 0.35s ease !important;
}
.elementor-page-30 .elementor-widget-video:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 18px 50px rgba(13,31,60,0.28) !important;
}

/* Secciones de servicio — borde izquierdo dorado en texto */
.elementor-page-30 .e-con.e-parent:not(:first-child) > .e-con-inner > .elementor-widget-wrap {
  border-left: 4px solid #f0ad14 !important;
  padding-left: 28px !important;
}

/* --------------------------------------------------
   18D. CONTACTO — GOOGLE MAPS + INFO
   -------------------------------------------------- */

.elementor-page-24 .elementor-widget-google_maps iframe {
  border-radius: 14px !important;
  box-shadow: 0 10px 40px rgba(13,31,60,0.20) !important;
  min-height: 380px !important;
  width: 100% !important;
}
.elementor-page-24 .elementor-widget-google_maps .elementor-custom-embed {
  border-radius: 14px !important;
  overflow: hidden !important;
}

/* Info de contacto e Inicio — cards con borde dorado */
.elementor-page-24 .elementor-widget-text-editor,
.elementor-page-11 .elementor-widget-text-editor {
  background: #ffffff !important;
  border-radius: 16px !important;
  padding: 32px 36px !important;
  box-shadow: 0 4px 24px rgba(13,31,60,0.09) !important;
  border-left: 5px solid #f0ad14 !important;
  transition: box-shadow 0.28s ease, transform 0.28s ease !important;
  margin-bottom: 0 !important;
}
.elementor-page-24 .elementor-widget-text-editor:hover,
.elementor-page-11 .elementor-widget-text-editor:hover {
  box-shadow: 0 12px 40px rgba(13,31,60,0.16) !important;
  transform: translateY(-3px) !important;
}

/* --------------------------------------------------
   18E. GALERÍA — OVERLAY EN HOVER
   -------------------------------------------------- */

.elementor-gallery-item__overlay {
  background: linear-gradient(
    to top,
    rgba(13,31,60,0.82) 0%,
    rgba(13,31,60,0.20) 60%,
    transparent 100%
  ) !important;
  transition: opacity 0.28s ease !important;
}
.elementor-gallery-item:hover .elementor-gallery-item__overlay {
  opacity: 1 !important;
}

/* --------------------------------------------------
   18F. BREADCRUMB / CONTEXTO DE PÁGINA INTERNA
   -------------------------------------------------- */

/* Primera sección de páginas internas — tratamiento de hero */
.elementor-page-30 .e-con.e-parent:first-child,
.elementor-page-24 .e-con.e-parent:first-child {
  background: linear-gradient(135deg, #0d1f3c 0%, #1a3d7e 100%) !important;
  padding-top: 56px !important;
  padding-bottom: 56px !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Acento decorativo en el hero interno */
.elementor-page-30 .e-con.e-parent:first-child::after,
.elementor-page-24 .e-con.e-parent:first-child::after {
  content: "" !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: linear-gradient(90deg, #f0ad14, #c48200) !important;
}

/* Textos en el hero interno — color blanco */
.elementor-page-30 .e-con.e-parent:first-child .elementor-widget-heading h1,
.elementor-page-30 .e-con.e-parent:first-child .elementor-widget-heading h2,
.elementor-page-30 .e-con.e-parent:first-child .elementor-widget-heading h3,
.elementor-page-24 .e-con.e-parent:first-child .elementor-widget-heading h1,
.elementor-page-24 .e-con.e-parent:first-child .elementor-widget-heading h2,
.elementor-page-24 .e-con.e-parent:first-child .elementor-widget-heading h3 {
  color: #ffffff !important;
  text-shadow: 0 2px 12px rgba(0,0,0,0.3) !important;
}
.elementor-page-30 .e-con.e-parent:first-child .elementor-widget-text-editor p,
.elementor-page-30 .e-con.e-parent:first-child .elementor-widget-text-editor div,
.elementor-page-24 .e-con.e-parent:first-child .elementor-widget-text-editor p,
.elementor-page-24 .e-con.e-parent:first-child .elementor-widget-text-editor div {
  color: rgba(210,224,245,0.92) !important;
  font-size: 1.05rem !important;
}

/* --------------------------------------------------
   18G. TEXTO — LEGIBILIDAD Y JERARQUÍA
   -------------------------------------------------- */

/* Máximo ancho de línea para párrafos */
.elementor-widget-text-editor p {
  max-width: 72ch !important;
}

/* Mejorar color de párrafos en fondo claro */
.elementor-page-11 .e-con.e-parent:nth-child(odd) .elementor-widget-text-editor p,
.elementor-page-30 .e-con.e-parent .elementor-widget-text-editor p,
.elementor-page-24 .e-con.e-parent .elementor-widget-text-editor p {
  color: #374151 !important;
}

/* Separador decorativo bajo h2 en homepage */
.elementor-page-11 .elementor-widget-heading h2::after,
.elementor-page-30 .elementor-widget-heading h2::after,
.elementor-page-24 .elementor-widget-heading h2::after {
  content: "" !important;
  display: block !important;
  width: 44px !important;
  height: 3px !important;
  background: #f0ad14 !important;
  border-radius: 2px !important;
  margin-top: 12px !important;
}

/* --------------------------------------------------
   18H. IMÁGENES EN PORTAFOLIO Y CONTACTO — POLISH
   -------------------------------------------------- */

.elementor-page-11 .elementor-widget-image img,
.elementor-page-30 .elementor-widget-image img,
.elementor-page-24 .elementor-widget-image img {
  border-radius: 12px !important;
  box-shadow: 0 4px 24px rgba(13,31,60,0.14) !important;
  transition: transform 0.35s ease, box-shadow 0.35s ease !important;
}
.elementor-page-11 .elementor-widget-image img:hover,
.elementor-page-30 .elementor-widget-image img:hover,
.elementor-page-24 .elementor-widget-image img:hover {
  transform: scale(1.025) !important;
  box-shadow: 0 12px 40px rgba(13,31,60,0.22) !important;
}

/* --------------------------------------------------
   18I. RESPONSIVE — AJUSTES MÓVIL PÁGINAS INTERNAS
   -------------------------------------------------- */

@media (max-width: 767px) {
  /* Hero interno más compacto */
  .elementor-page-30 .e-con.e-parent:first-child,
  .elementor-page-24 .e-con.e-parent:first-child {
    padding-top: 36px !important;
    padding-bottom: 36px !important;
  }

  /* Quitar border-left en móvil (rompe layout) */
  .elementor-page-30 .e-con.e-parent:not(:first-child) > .e-con-inner > .elementor-widget-wrap {
    border-left: none !important;
    padding-left: 0 !important;
    border-top: 3px solid #f0ad14 !important;
    padding-top: 20px !important;
  }

  /* Slider headings más legibles en móvil */
  .elementor-slides .elementor-slide-heading {
    font-size: 1.4rem !important;
    margin-bottom: 10px !important;
  }
  .elementor-slides .elementor-slide-description {
    font-size: 0.88rem !important;
    margin-bottom: 16px !important;
  }

  /* Contacto — quitar padding extra en cards */
  .elementor-page-24 .elementor-widget-text-editor {
    padding: 20px 20px !important;
  }

  /* Maps tamaño mínimo */
  .elementor-page-24 .elementor-widget-google_maps iframe {
    min-height: 280px !important;
  }
}

/* =====================================================
   19. BOTÓN WHATSAPP FLOTANTE Y ARRASTRABLE
   ===================================================== */

/* Ocultar botón del plugin Qlwapp (reemplazado por el nuestro) */
.qlwapp-container,
.qlwapp-box,
.qlwapp-toggle,
[class*="qlwapp"] {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Ocultar nav duplicado de Elementor en homepage — solo queda el nav global PHP */
.elementor-page-11 .elementor-element-e877121 {
  display: none !important;
}
/* Ocultar banda superior de Elementor en homepage — la reemplaza #asertiva-top-bar */
.elementor-page-11 .elementor-element-e88b477 {
  display: none !important;
}

#asertiva-wa-btn {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 99999;
  cursor: grab;
  user-select: none;
  touch-action: none;
  display: flex;
  align-items: center;
  gap: 0;
  filter: drop-shadow(0 6px 18px rgba(37,211,102,0.45));
  transition: filter 0.22s ease;
}
#asertiva-wa-btn:active {
  cursor: grabbing;
}
#asertiva-wa-btn:hover {
  filter: drop-shadow(0 8px 24px rgba(37,211,102,0.65));
}

/* Círculo principal verde */
#asertiva-wa-btn .wa-circle {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: linear-gradient(135deg, #25d366 0%, #128c50 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: transform 0.22s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 4px 16px rgba(37,211,102,0.40);
  flex-shrink: 0;
}
#asertiva-wa-btn:hover .wa-circle {
  transform: scale(1.10);
}

/* Ícono SVG */
#asertiva-wa-btn .wa-circle svg {
  width: 32px;
  height: 32px;
  fill: #ffffff;
  flex-shrink: 0;
}

/* Pulso de fondo */
#asertiva-wa-btn .wa-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(37,211,102,0.35);
  animation: waPulse 2.2s ease-out infinite;
  pointer-events: none;
}
@keyframes waPulse {
  0%   { transform: scale(1);   opacity: 0.7; }
  70%  { transform: scale(1.65); opacity: 0; }
  100% { transform: scale(1.65); opacity: 0; }
}

/* Tooltip / Label */
#asertiva-wa-btn .wa-label {
  background: #0d1f3c;
  color: #ffffff;
  font-family: "Inter", sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 8px 14px;
  border-radius: 10px 0 0 10px;
  white-space: nowrap;
  opacity: 0;
  transform: translateX(8px);
  transition: opacity 0.25s ease, transform 0.25s ease;
  pointer-events: none;
  position: absolute;
  right: 68px;
  top: 50%;
  translate: 0 -50%;
  box-shadow: 0 2px 12px rgba(13,31,60,0.25);
}
/* Punta del tooltip */
#asertiva-wa-btn .wa-label::after {
  content: "";
  position: absolute;
  right: -7px;
  top: 50%;
  translate: 0 -50%;
  border: 7px solid transparent;
  border-right: none;
  border-left-color: #0d1f3c;
}
#asertiva-wa-btn:hover .wa-label {
  opacity: 1;
  transform: translateX(0);
}

/* Pastilla del número al inicio — aparece y desaparece */
#asertiva-wa-btn.wa-intro .wa-label {
  opacity: 1;
  transform: translateX(0);
}

/* Modo arrastrado — sin pulso ni tooltip */
#asertiva-wa-btn.is-dragging .wa-pulse {
  animation: none !important;
  opacity: 0 !important;
}
#asertiva-wa-btn.is-dragging .wa-label {
  opacity: 0 !important;
}

@media (max-width: 479px) {
  #asertiva-wa-btn {
    bottom: 18px;
    right: 18px;
  }
  #asertiva-wa-btn .wa-circle {
    width: 52px;
    height: 52px;
  }
  #asertiva-wa-btn .wa-circle svg {
    width: 27px;
    height: 27px;
  }
}

/* =====================================================
   23. BANNER INFORMATIVO ESTILO MANUSCRITO VERDE
   ===================================================== */

:root {
  --green: #27ae60;
}

.asertiva-info-bar {
  width: 100%;
  margin: 38px 0 0 0;
  background: #fff;
  color: var(--green);
  border: none;
  border-radius: 0;
  font-size: 1.08rem;
  font-weight: 500;
  text-align: left;
  padding: 18px 0 0 7%;
  box-shadow: none;
  position: relative;
  font-family: inherit;
}
.asertiva-info-bar-text {
  display: block;
  margin: 0;
  line-height: 1.4;
  font-size: 1.08rem;
  font-weight: 500;
  color: var(--green);
  font-family: inherit;
}

@media (max-width: 767px) {
  .asertiva-info-bar {
    padding: 12px 0 0 4%;
    font-size: 0.98rem;
    margin-top: 18px;
  }
}

/* =====================================================
   24. TOP BAR + HEADER PHP GLOBAL — v5
   ===================================================== */

/* --- HEADER NAV (sticky) --- */
#asertiva-site-header {
  background: linear-gradient(135deg, #0d1f3c 0%, #132a52 100%);
  width: 100%;
  display: block;
  position: sticky;
  top: 0;
  z-index: 9995;
  box-shadow: 0 2px 20px rgba(0,0,0,0.40);
  border-bottom: 3px solid var(--gold);
}

.asertiva-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: 0 auto;
  padding: 8px 28px;
  gap: 28px;
}

.asertiva-logo-link {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.asertiva-logo {
  max-width: 52px;
  height: auto;
  display: block;
  filter: brightness(0) invert(1);
  transition: transform 0.22s ease, opacity 0.22s ease;
  border-radius: 6px;
}
.asertiva-logo-link:hover .asertiva-logo {
  transform: scale(1.08);
  opacity: 0.9;
}

#asertiva-global-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 2px;
  align-items: center;
}
#asertiva-global-nav ul li { list-style: none; margin: 0; padding: 0; }
#asertiva-global-nav ul li a {
  font-family: "Inter", sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(197,212,238,0.88);
  text-decoration: none;
  padding: 10px 18px;
  display: block;
  border-radius: 6px;
  position: relative;
  transition: color 0.22s ease, background 0.22s ease;
}
#asertiva-global-nav ul li a:hover,
#asertiva-global-nav ul li a.active {
  color: var(--gold);
  background: rgba(240,173,20,0.10);
}
#asertiva-global-nav ul li a::after {
  content: "";
  position: absolute;
  bottom: 4px; left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: 60%; height: 2px;
  background: var(--gold);
  border-radius: 2px;
  transition: transform 0.22s ease;
}
#asertiva-global-nav ul li a:hover::after,
#asertiva-global-nav ul li a.active::after {
  transform: translateX(-50%) scaleX(1);
}

/* --- BANDA INFORMATIVA (debajo del nav) --- */
#asertiva-info-band {
  display: block !important;
  background: #ffffff !important;
  border-bottom: 4px solid #f0ad14 !important;
  width: 100% !important;
  box-shadow: 0 4px 20px rgba(13,31,60,0.08) !important;
  position: relative !important;
  z-index: 9990 !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.asertiva-info-band-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: 0 auto;
  padding: 22px 28px;
  gap: 28px;
}
.asertiva-info-band-left {
  flex: 1;
  min-width: 0;
}
.asertiva-info-band-title {
  font-family: "Inter", sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 6px 0;
  line-height: 1.3;
}
.asertiva-info-band-sub {
  font-family: "Inter", sans-serif;
  font-size: 0.82rem;
  font-weight: 400;
  color: var(--gray-600);
  margin: 0 0 14px 0;
  line-height: 1.5;
}
.asertiva-info-band-contact {
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}
.info-band-contact-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: "Inter", sans-serif;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--navy-mid);
  text-decoration: none;
  transition: color 0.2s ease;
}
.info-band-contact-link svg {
  width: 15px;
  height: 15px;
  fill: var(--gold);
  flex-shrink: 0;
}
.info-band-contact-link:hover { color: var(--gold-dark); }

.asertiva-info-band-right { flex-shrink: 0; }

.asertiva-info-band-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Inter", sans-serif;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  text-decoration: none;
  background: linear-gradient(135deg, var(--navy-mid) 0%, var(--navy-light) 100%);
  color: #ffffff;
  padding: 14px 36px;
  border-radius: 50px;
  box-shadow: 0 4px 18px rgba(26,61,126,0.30);
  transition: transform 0.22s ease, box-shadow 0.22s ease;
  white-space: nowrap;
}
.asertiva-info-band-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(26,61,126,0.45);
  color: #ffffff;
}

@media (max-width: 767px) {
  .asertiva-header-inner { padding: 6px 14px; gap: 10px; }
  .asertiva-logo { max-width: 40px; }
  #asertiva-global-nav ul li a { padding: 8px 9px; font-size: 0.64rem; letter-spacing: 0.06em; }
  .asertiva-info-band-inner { flex-direction: column; align-items: flex-start; padding: 18px 16px; gap: 16px; }
  .asertiva-info-band-right { width: 100%; }
  .asertiva-info-band-btn { width: 100%; justify-content: center; }
  .asertiva-info-band-contact { gap: 12px; }
}
@media (max-width: 479px) {
  #asertiva-global-nav ul { gap: 0; }
  #asertiva-global-nav ul li a { padding: 8px 6px; font-size: 0.58rem; }
  .asertiva-info-band-title { font-size: 0.95rem; }
  .asertiva-info-band-sub { font-size: 0.77rem; }
}

/* =====================================================
   25. MEJORAS UI GLOBALES ADICIONALES v5
   ===================================================== */

/* Scrollbar personalizado */
::-webkit-scrollbar { width: 7px; }
::-webkit-scrollbar-track { background: var(--gray-100); }
::-webkit-scrollbar-thumb { background: var(--navy-light); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* Focus visible accesible */
a:focus-visible,
button:focus-visible {
  outline: 3px solid var(--gold) !important;
  outline-offset: 3px !important;
}

/* Selección de texto — azul marino */
::selection {
  background: var(--navy-mid);
  color: #fff;
}

/* Links en contenido */
.elementor-widget-text-editor a {
  color: var(--navy-mid) !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
  transition: color var(--trans) !important;
}
.elementor-widget-text-editor a:hover {
  color: var(--gold-dark) !important;
}

/* Formulario CF7 — botón submit redondeado */
.wpcf7-submit {
  border-radius: 50px !important;
  padding: 15px 40px !important;
  background: linear-gradient(135deg, var(--navy-mid) 0%, var(--navy-light) 100%) !important;
  letter-spacing: 0.07em !important;
  box-shadow: 0 4px 18px rgba(26,61,126,0.35) !important;
}
.wpcf7-submit:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(26,61,126,0.45) !important;
}

/* Inputs — borde con radio más pronunciado */
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form textarea {
  border-radius: 10px !important;
}

/* =====================================================
   26. REDISEÑO VISUAL PRO — HOMEPAGE v5.6
   ===================================================== */

/* --------------------------------------------------
   26A. HERO SECTION — primera sección de contenido
   -------------------------------------------------- */

/* Primera sección de contenido (después del slider) */
.elementor-page-11 .e-con.e-parent:nth-child(3) {
  background: #ffffff !important;
  padding-top: 88px !important;
  padding-bottom: 88px !important;
}

/* "Sobre nosotros" — layout texto + imagen mejorado */
.elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-text-editor {
  background: transparent !important;
  border-left: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  transform: none !important;
}

/* Acento tipográfico: primer h2 con gradiente de texto */
.elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-heading h2 {
  font-size: clamp(1.75rem, 4vw, 2.6rem) !important;
  background: linear-gradient(135deg, #0d1f3c 0%, #1a3d7e 70%, #2e5499 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
  display: block !important;
  margin-bottom: 16px !important;
}
.elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-heading h2::after {
  display: block !important;
  width: 56px !important;
  height: 4px !important;
  background: linear-gradient(90deg, #f0ad14, #c48200) !important;
  border-radius: 4px !important;
  margin-top: 14px !important;
}

/* Párrafo intro más grande */
.elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-text-editor p {
  font-size: 1.08rem !important;
  line-height: 1.9 !important;
  color: #374151 !important;
  max-width: 68ch !important;
}

/* --------------------------------------------------
   26B. SECCIÓN "NUESTROS SERVICIOS" — grid de tarjetas
   -------------------------------------------------- */

/* Contenedor de tarjetas de servicios */
.elementor-page-11 .e-con.e-parent .elementor-widget-icon-box .elementor-icon-box-wrapper {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 12px !important;
}

/* Icono de servicio */
.elementor-page-11 .elementor-widget-icon-box .elementor-icon {
  background: linear-gradient(135deg, rgba(13,31,60,0.06) 0%, rgba(26,61,126,0.10) 100%) !important;
  border-radius: 14px !important;
  padding: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.25s ease, transform 0.25s ease !important;
  margin-bottom: 4px !important;
}
.elementor-page-11 .elementor-widget-icon-box:hover .elementor-icon {
  background: linear-gradient(135deg, rgba(240,173,20,0.15) 0%, rgba(196,130,0,0.12) 100%) !important;
  transform: scale(1.08) rotate(-3deg) !important;
}
.elementor-page-11 .elementor-widget-icon-box .elementor-icon i,
.elementor-page-11 .elementor-widget-icon-box .elementor-icon svg {
  color: var(--navy-mid) !important;
  fill: var(--navy-mid) !important;
  transition: color 0.25s ease !important;
}
.elementor-page-11 .elementor-widget-icon-box:hover .elementor-icon i,
.elementor-page-11 .elementor-widget-icon-box:hover .elementor-icon svg {
  color: var(--gold-dark) !important;
  fill: var(--gold-dark) !important;
}

/* Título de servicio */
.elementor-page-11 .elementor-widget-icon-box .elementor-icon-box-title {
  font-family: "Inter", sans-serif !important;
  font-size: 1.02rem !important;
  font-weight: 700 !important;
  color: var(--navy) !important;
  line-height: 1.3 !important;
  letter-spacing: -0.01em !important;
  margin-bottom: 8px !important;
}

/* Descripción de servicio */
.elementor-page-11 .elementor-widget-icon-box .elementor-icon-box-description {
  font-family: "Inter", sans-serif !important;
  font-size: 0.92rem !important;
  line-height: 1.75 !important;
  color: #4b5563 !important;
}

/* --------------------------------------------------
   26C. IMÁGENES CON MARCO Y BADGE DECORATIVO
   -------------------------------------------------- */

/* Contenedor imagen con sombra y marco sutil */
.elementor-page-11 .elementor-widget-image {
  position: relative !important;
}

.elementor-page-11 .elementor-widget-image::before {
  content: "" !important;
  position: absolute !important;
  inset: -6px -6px 6px 6px !important;
  border: 2px solid rgba(240,173,20,0.25) !important;
  border-radius: 20px !important;
  z-index: 0 !important;
  pointer-events: none !important;
  transition: border-color 0.3s ease !important;
}
.elementor-page-11 .elementor-widget-image:hover::before {
  border-color: rgba(240,173,20,0.55) !important;
}
.elementor-page-11 .elementor-widget-image img {
  position: relative !important;
  z-index: 1 !important;
  border-radius: 16px !important;
  aspect-ratio: 4/3 !important;
  object-fit: cover !important;
  width: 100% !important;
}

/* --------------------------------------------------
   26D. SECCIÓN CTA / LLAMADA A ACCIÓN
   -------------------------------------------------- */

/* Última sección antes del footer — estilo CTA */
.elementor-page-11 .e-con.e-parent:last-child {
  background: linear-gradient(135deg, #0d1f3c 0%, #132a52 60%, #1a3d7e 100%) !important;
  padding-top: 80px !important;
  padding-bottom: 80px !important;
  position: relative !important;
  overflow: hidden !important;
}
.elementor-page-11 .e-con.e-parent:last-child::after {
  content: "" !important;
  position: absolute !important;
  top: -80px; right: -80px !important;
  width: 320px; height: 320px !important;
  background: radial-gradient(circle, rgba(240,173,20,0.12) 0%, transparent 70%) !important;
  pointer-events: none !important;
}
.elementor-page-11 .e-con.e-parent:last-child::before {
  content: "" !important;
  position: absolute !important;
  bottom: -60px; left: -60px !important;
  width: 260px; height: 260px !important;
  background: radial-gradient(circle, rgba(46,84,153,0.30) 0%, transparent 70%) !important;
  pointer-events: none !important;
}
/* Textos CTA — color blanco */
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-heading h1,
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-heading h2,
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-heading h3,
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-heading h4 {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-text-editor p {
  color: rgba(210,228,255,0.88) !important;
  background: transparent !important;
  border-left: none !important;
  box-shadow: none !important;
}
/* Botón CTA sobre fondo oscuro — dorado */
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-button .elementor-button {
  background: linear-gradient(135deg, #f0ad14 0%, #c48200 100%) !important;
  color: #0d1f3c !important;
  box-shadow: 0 6px 24px rgba(240,173,20,0.50) !important;
}
.elementor-page-11 .e-con.e-parent:last-child .elementor-widget-button .elementor-button:hover {
  box-shadow: 0 12px 38px rgba(240,173,20,0.65) !important;
}

/* --------------------------------------------------
   26E. ENCABEZADOS DE SECCIÓN — CHIPS / LABELS
   -------------------------------------------------- */

/* h5/h6 como "badge" antes del título principal */
.elementor-page-11 .elementor-widget-heading h5,
.elementor-page-11 .elementor-widget-heading h6,
.elementor-page-30 .elementor-widget-heading h5,
.elementor-page-30 .elementor-widget-heading h6 {
  display: inline-block !important;
  background: rgba(240,173,20,0.12) !important;
  color: #c48200 !important;
  padding: 5px 14px !important;
  border-radius: 50px !important;
  font-size: 0.68rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  margin-bottom: 12px !important;
  border: 1px solid rgba(240,173,20,0.25) !important;
}

/* --------------------------------------------------
   26F. LISTADOS / BULLETS MEJORADOS
   -------------------------------------------------- */

.elementor-page-11 .elementor-widget-text-editor ul,
.elementor-page-30 .elementor-widget-text-editor ul {
  list-style: none !important;
  padding-left: 0 !important;
  margin: 12px 0 !important;
}
.elementor-page-11 .elementor-widget-text-editor ul li,
.elementor-page-30 .elementor-widget-text-editor ul li {
  position: relative !important;
  padding-left: 26px !important;
  margin-bottom: 8px !important;
  font-size: 0.97rem !important;
  line-height: 1.7 !important;
  color: #374151 !important;
}
.elementor-page-11 .elementor-widget-text-editor ul li::before,
.elementor-page-30 .elementor-widget-text-editor ul li::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 9px !important;
  width: 8px !important;
  height: 8px !important;
  background: linear-gradient(135deg, #f0ad14, #c48200) !important;
  border-radius: 50% !important;
}

/* --------------------------------------------------
   26G. SEPARADORES VISUALES ENTRE SECCIONES
   -------------------------------------------------- */

/* Divider global — dorado */
.elementor-widget-divider .elementor-divider-separator {
  border-color: #f0ad14 !important;
  border-width: 3px !important;
  width: 60px !important;
  border-radius: 9999px !important;
  opacity: 0.8 !important;
}

/* --------------------------------------------------
   26H. ANIMACIONES MEJORADAS
   -------------------------------------------------- */

@keyframes slideInUp {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeInScale {
  from { opacity: 0; transform: scale(0.96); }
  to   { opacity: 1; transform: scale(1); }
}

.elementor-widget-text-editor { animation: slideInUp 0.5s ease both; }
.elementor-widget-image { animation: fadeInScale 0.55s ease both; }
.elementor-widget-icon-box { animation: slideInUp 0.5s ease both; }

/* --------------------------------------------------
   26I. FOOTER ELEMENTOR — MEJORAS
   -------------------------------------------------- */

.elementor-location-footer {
  background: #080f1e !important;
  border-top: 3px solid rgba(240,173,20,0.3) !important;
}
.elementor-location-footer .elementor-widget-text-editor p,
.elementor-location-footer .elementor-widget-text-editor div {
  background: transparent !important;
  border-left: none !important;
  box-shadow: none !important;
  color: rgba(190,210,240,0.7) !important;
  font-size: 0.85rem !important;
  padding: 0 !important;
}
.elementor-location-footer .elementor-widget-heading h1,
.elementor-location-footer .elementor-widget-heading h2,
.elementor-location-footer .elementor-widget-heading h3,
.elementor-location-footer .elementor-widget-heading h4 {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  border-bottom: 2px solid rgba(240,173,20,0.35) !important;
  padding-bottom: 10px !important;
  display: inline-block !important;
  margin-bottom: 16px !important;
}
.elementor-location-footer a {
  color: rgba(190,210,240,0.72) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}
.elementor-location-footer a:hover {
  color: #f0ad14 !important;
}

/* --------------------------------------------------
   26J. RESPONSIVE MÓVIL — AJUSTES NUEVOS
   -------------------------------------------------- */

@media (max-width: 767px) {
  .elementor-page-11 .e-con.e-parent:nth-child(3) {
    padding-top: 52px !important;
    padding-bottom: 52px !important;
  }
  .elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-heading h2 {
    font-size: 1.65rem !important;
  }
  .elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-text-editor p {
    font-size: 0.97rem !important;
  }
  .elementor-page-11 .elementor-widget-image::before {
    display: none !important;
  }
  .elementor-page-11 .elementor-widget-image img {
    aspect-ratio: 16/9 !important;
  }
  .elementor-page-11 .e-con.e-parent:last-child {
    padding-top: 52px !important;
    padding-bottom: 52px !important;
  }
  .elementor-page-11 .e-con.e-parent:last-child::after,
  .elementor-page-11 .e-con.e-parent:last-child::before {
    display: none !important;
  }
}
@media (max-width: 479px) {
  .elementor-page-11 .e-con.e-parent {
    padding-top: 48px !important;
    padding-bottom: 48px !important;
  }
  .elementor-page-11 .e-con.e-parent:nth-child(3) .elementor-widget-heading h2 {
    font-size: 1.4rem !important;
  }
}
