/* ================================================================
   fix-todo.css — Corrección GLOBAL unificada · Monitoreo 2001
   Elimina: espacios en blanco, secciones rotas, parpadeo, overflow
   Se carga DESPUÉS de style.css y responsive.css en todas las páginas
   ================================================================ */

/* ── 1. BODY: nunca oculto, nunca con overflow cortado ─────────── */
html, body {
  overflow-x: hidden !important;
  overflow-y: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* ── 2. FORZAR VISIBILIDAD de TODOS los elementos animados ─────── */
/*
   El problema central: muchos elementos inician con opacity:0 + transform
   y esperan que IntersectionObserver les agregue .vis/.revealed.
   Si el script no corre (defer, timing, falla), quedan invisibles → espacios.
   Solución: deshabilitar la animación de entrada completamente.
   Los elementos se muestran de inmediato; las transiciones de hover/hover-out
   siguen funcionando.
*/

/* about.html — stats, timeline, values, process, diff */
.stat-box,
.tl-item,
.val-card,
.step-box,
.diff-item {
  opacity: 1 !important;
  transform: none !important;
  transition: box-shadow 0.3s ease, background 0.3s ease !important;
}

/* animations.css reveal classes — usadas en service_layout_1, tips, about, contacts */
.reveal-up,
.reveal-left,
.reveal-right,
.reveal-up.revealed,
.reveal-left.revealed,
.reveal-right.revealed {
  opacity: 1 !important;
  transform: none !important;
  transition: box-shadow 0.3s ease !important;
}

/* Clases genéricas de animación que pueden dejar elementos ocultos */
.animate-on-scroll,
.animate-on-scroll.in,
.animated-element,
[data-wow-delay],
.wow {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  animation: none !important;
}

/* ── 3. SECCIÓN SERVICIOS-PREMIUM (index.html) ──────────────────── */
#servicios-premium {
  display: block !important;
  visibility: visible !important;
  overflow: visible !important;
}

.serv-col,
.serv-card {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
}

/* ── 4. FEAT HOME / QUIENES SOMOS (index.html) ─────────────────── */
#feat_home {
  display: block !important;
  visibility: visible !important;
  overflow: visible !important;
  padding-top: 60px;
  padding-bottom: 40px;
}

.box_feat {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* ── 5. ABOUT STATS — nunca en 0 ───────────────────────────────── */
#about-stats {
  display: block !important;
  overflow: visible !important;
}

.stats-row {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 767px) {
  .stats-row { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ── 6. ESPACIOS NEGROS entre secciones ─────────────────────────── */
/*
   common_scripts_min.js agrega/quita clases al footer y a secciones.
   Asegurar que el footer no quede flotando ni con z-index roto.
*/
footer {
  position: relative !important;
  z-index: 1 !important;
  width: 100% !important;
  display: block !important;
  background: #222 !important;
}

/* ── 7. VIDEO SECTION — sin colapso ────────────────────────────── */
#local-video-section {
  display: block !important;
  min-height: 200px;
}

/* ── 8. PRELOADER — siempre eliminado visualmente ───────────────── */
#preloader,
#pre2001,
#status {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* ── 9. SECCIONES con background negro inesperado ───────────────── */
/*
   El body no debe tener overflow:hidden que crea espacios negros
   mientras carga el preloader.
*/
body.loading,
body.preloading {
  overflow: visible !important;
  opacity: 1 !important;
}

/* ── 10. ANIMACIONES: deshabilitar las que causan CLS/parpadeo ──── */
/*
   animations.js agrega clases .animated con translate3d que en algunos
   dispositivos provocan repaint al cargar. Neutralizar en elementos clave.
*/
.fadeInDown,
.fadeInUp,
.fadeIn,
.bounceInDown,
.slideDown,
.flipInX {
  animation-duration: 0.01ms !important;
  animation-delay: 0ms !important;
}

/* ── 11. TIPS PAGE — reveal-up boxes ──────────────────────────── */
.box_style_4.reveal-up,
.box_style_4 {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
}

/* ── 12. SRV-CTA-SECTION (service_layout_1) ────────────────────── */
.srv-cta-section {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
  display: block !important;
}

/* ── 13. ABOUT PAGE — contact/reveal block ─────────────────────── */
#about-cta,
#contacto {
  display: block !important;
  visibility: visible !important;
  overflow: visible !important;
}

/* ── 14. MARCAS / BRANDS-SECTION — sin colapso ─────────────────── */
.brands-section,
.marcas-section {
  display: block !important;
  visibility: visible !important;
}

/* ── 15. SECCION COMODATOS ──────────────────────────────────────── */
#comodatos {
  display: block !important;
  visibility: visible !important;
  overflow: visible !important;
}

/* ── 16. ELIMINAR BRECHAS por margin collapse ───────────────────── */
section + section,
section + div,
div + section {
  /* Prevenir margin collapse entre secciones */
  display: block;
}

/* ── 17. STICKY HEADER: sin parpadeo en scroll ──────────────────── */
/*
   IMPORTANTE: NO usar transform en header.
   Cualquier transform (incluso translateZ(0)) en un ancestro hace que
   position:fixed de los hijos (.main-menu, .layer) se posicione
   relativo al header en vez del viewport → menú móvil roto/blanco.
   will-change:auto ya evita la layer promotion innecesaria.
*/
header {
  will-change: auto !important;
}

/* Cubrir todas las clases que headroom.js puede agregar al header */
header.animated,
header.headroom,
header.headroom--pinned,
header.headroom--unpinned,
header.headroom--top,
header.headroom--not-top {
  transform: none !important;
}

/* ── 19. MENÚ MÓVIL — SOLUCIÓN DEFINITIVA v3 ──────────────────────
   PROBLEMAS ENCONTRADOS:
   1. Texto invisible (blanco sobre blanco) → se resuelve con fondo verde
   2. Solo se ve "Inicio" y faltan las demás opciones → el panel no tiene
      altura completa o overflow correcto → forzar layout del panel
   3. Los items del <ul> podrían estar colapsados por display rules
   ──────────────────────────────────────────────────────────────────── */
@media only screen and (max-width: 991px) {

  /* ====== LAYOUT DEL PANEL ====== */
  /* Panel del menú: fondo verde oscuro, altura completa, scroll habilitado */
  .main-menu {
    background-color: #1a5c2e !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    bottom: 0 !important;
    height: 100% !important;
    min-height: 100vh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    z-index: 999999 !important;
    -webkit-overflow-scrolling: touch;
    display: block !important;
    padding-bottom: 30px !important;
  }

  /* Encabezado del panel (logo) — compacto */
  #header_menu {
    display: block !important;
    background: transparent !important;
    padding: 15px 15px 10px !important;
    text-align: left !important;
  }
  #header_menu img {
    max-width: 160px !important;
    height: auto !important;
  }

  /* Botón cerrar (X) */
  a#close_in {
    display: block !important;
    position: absolute !important;
    right: 15px !important;
    top: 12px !important;
    z-index: 10 !important;
  }
  a#close_in i {
    color: #fff !important;
    font-size: 20px !important;
  }

  /* ====== LISTA DEL MENÚ ====== */
  /* Forzar que el <ul> y todos los <li> sean visibles */
  .main-menu > ul {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    list-style: none !important;
  }

  .main-menu > ul > li {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
    border-bottom: 1px solid rgba(255,255,255,.15) !important;
    padding: 0 !important;
    margin: 0 !important;
    height: auto !important;
    overflow: visible !important;
    float: none !important;
  }

  /* Links principales: blancos, claramente visibles */
  .main-menu > ul > li > a,
  .main-menu > ul > li > a:link,
  .main-menu > ul > li > a:visited,
  .main-menu ul > li > a,
  .main-menu ul > li > a[href],
  .main-menu a,
  .main-menu li {
    color: #fff !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    font-size: 14px !important;
    padding: 12px 15px !important;
    line-height: 1.4 !important;
    text-transform: uppercase !important;
    font-weight: 600 !important;
    text-decoration: none !important;
  }

  .main-menu > ul > li > a:hover,
  .main-menu > ul > li > a:focus,
  a.show-submenu:hover,
  a.show-submenu:focus,
  a.show-submenu-mega:hover,
  a.show-submenu-mega:focus {
    color: #5dde85 !important;
    background-color: rgba(255,255,255,.08) !important;
  }

  /* ====== SUBMENÚS ====== */
  .main-menu ul ul,
  .main-menu ul li.submenu ul {
    background: #0d3a1c !important;
    border-top: 2px solid #5dde85 !important;
    border-left: 1px solid rgba(255,255,255,.1);
  }
  .main-menu ul ul li a {
    color: rgba(255,255,255,.85) !important;
    font-size: 13px !important;
  }
  .main-menu ul ul li a:hover {
    color: #5dde85 !important;
    background: rgba(255,255,255,.06) !important;
  }

  /* Encabezado de sección dentro del menú */
  .main-menu h3 {
    color: rgba(255,255,255,.7) !important;
  }

  /* ====== HEADER SIN TRANSFORM ====== */
  header,
  header.animated,
  header.headroom,
  header.headroom--pinned,
  header.headroom--unpinned,
  header.headroom--top,
  header.headroom--not-top {
    transform: none !important;
    will-change: auto !important;
    filter: none !important;
  }
}

/* ── 18. CONTACTS PAGE ──────────────────────────────────────────── */
.contacts-hero,
#contacts-map,
.contact-form-section {
  opacity: 1 !important;
  transform: none !important;
  visibility: visible !important;
}

/* ================================================================
   CORRECCIÓN DEFINITIVA — PARALLAX WHITE SPACE
   El parallax.js dentro de common_scripts_min.js carga con defer,
   por lo que .parallax_window_in queda como un rectángulo blanco 
   de 350px visible mientras carga. Solución: forzar background-image
   desde CSS usando el data-image-src declarado en el HTML.
   ================================================================ */

/* Fallback inmediato para TODOS los headers de páginas internas */
.parallax_window_in,
.parallax_window_in.short {
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-color: #1a5c2e !important; /* verde de marca como fallback de color */
  /* Sobreescribir height para que el contenido determine el tamaño */
  min-height: 200px !important;
  height: auto !important;
  display: flex !important;
  align-items: flex-end !important;
}

/* Fallback por imagen específica usando atributo data */
/* Subheader 1 */
.parallax_window_in[data-image-src="img/subheader_in_1.webp"] {
  background-image: url('../img/subheader_in_1.webp') !important;
}
/* Subheader 2 */
.parallax_window_in[data-image-src="img/subheader_in_2.webp"] {
  background-image: url('../img/subheader_in_2.webp') !important;
}
/* Subheader 3 */
.parallax_window_in[data-image-src="img/subheader_in_3.webp"] {
  background-image: url('../img/subheader_in_3.webp') !important;
}

/* Overlay oscuro para legibilidad del texto */
.parallax_window_in::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 0;
}

/* El contenido del subheader por encima del overlay */
.parallax_window_in > *,
#sub_content_in {
  position: relative;
  z-index: 1;
}

/* Altura mínima decente para el banner */
.parallax_window_in.short {
  min-height: 220px !important;
  padding: 60px 0 40px !important;
}

/* ================================================================
   CORRECCIÓN DEFINITIVA — footerReveal
   common_scripts_min.js pone footer en position:fixed y agrega
   padding-bottom al main igual a la altura del footer.
   Cuando el scroll no está al fondo, main tiene padding enorme
   pero el footer no es visible → espacio en blanco/negro.
   ================================================================ */
footer {
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  width: 100% !important;
  z-index: 1 !important;
}

main {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* footerReveal de common_scripts_min.js agrega margin-bottom INLINE al elemento
   anterior al footer (footer.prev()). En service_layout_1.html ese elemento es
   .srv-cta-section. En index.html es <main>. El JS de fix-todo intercepta esto,
   pero como defensa adicional forzamos margin-bottom:0 via CSS. */
.srv-cta-section {
  margin-bottom: 0 !important;
}

/* footerReveal puede agregar padding-bottom al BODY como fallback */
body {
  padding-bottom: 0 !important;
}

/* Por si footerReveal agrega estilo inline al main o al wrapper */
#wrapper, .wrapper, #page-wrap {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}
