/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Nov 03 2025 | 19:14:28 */
/*** Inicia AVSYS - Divi basics ***/

/* ==== ESTRUCTURA PRINCIPAL - Menú BIDA ==== */
/* ===========================
   BIDA - Header personalizado
   =========================== */

/* ===== Desktop (base) ===== */
.av-menu{
  display:flex;
  align-items:center;            /* ok en desktop */
  justify-content:space-between;
  gap:12px;
  position:relative;
}
.av-columna-1,
.av-columna-2,
.av-columna-3{
  display:flex;
  align-items:center;
}
.av-columna-1{ justify-content:flex-start; flex:0 0 auto; }
.av-columna-2{ justify-content:center;   flex:1 1 auto; position:relative; }
.av-columna-3{ justify-content:flex-end; flex:0 0 auto; }

/* Divi: menú desktop visible, móvil oculto */
.av-menu .et_pb_menu__menu{ display:block; }
.av-menu .et_mobile_nav_menu{ display:none; }

/* =========================================
   Tablet + Móvil (≤980px): usar CSS GRID
   ========================================= */
@media (max-width:980px){

  /* Ocultar 3a columna */
  .av-columna-3{ display:none !important; }

  /* Igualar alturas: 2 columnas 50/50 en GRID */
  .av-menu{
    display:grid;
    grid-template-columns: 1fr 1fr; /* 50% / 50% */
    align-items:stretch;            /* columnas llenan el alto */
    justify-content:stretch;
    gap:0;
    min-height:74px;
    padding:8px 16px;
    position:relative;
  }

  .av-columna-1,
  .av-columna-2{
    height:100%;                    /* fondo de cada columna cubre todo */
    display:flex;
    align-items:center;             /* centrar verticalmente contenido */
  }

  .av-columna-1{ justify-content:flex-start; }
  .av-columna-2{ justify-content:flex-end; position:relative; overflow:visible; }

  /* Ocultar divisores/lineas que rompen la altura en col 2 */
  .av-columna-2 .et_pb_divider{ display:none !important; }

  /* Mostrar versión móvil del menú SOLO dentro de col 2 */
  .av-menu .et_pb_menu__menu{ display:none !important; }
  .av-columna-2 .et_mobile_nav_menu{
    display:flex !important;
    width:100%;
    justify-content:flex-end;
    align-items:center;
    position:static !important;
    float:none !important;
    transform:none !important;
    margin:0 !important;
    height:100%;                    /* ocupa toda la altura de la columna */
  }
  .av-columna-2 .mobile_nav{
    display:block !important;
    position:static !important;
    float:none !important;
    margin:0 !important;
  }

  /* Ícono hamburguesa perfectamente centrado vertical */
  .av-columna-2 .mobile_menu_bar{
    position:static !important;
    margin:0 !important;
    line-height:1 !important;
    transform:none !important;
    cursor:pointer;
  }

  /* Dropdown anclado a col 2 (no al header) */
  .av-columna-2 .et_mobile_menu{
    position:absolute !important;
    top:calc(100% + 8px) !important;
    right:0 !important;
    left:auto !important;
    width:min(92vw, 360px) !important;
    background:#fff;
    border-radius:10px;
    box-shadow:0 10px 30px rgba(0,0,0,.18);
    padding:8px 0;
    z-index:9999;
  }

  .av-columna-2 .et_mobile_menu li{ padding:0; }
  .av-columna-2 .et_mobile_menu li a{
    display:block;
    padding:16px 18px;
    font-size:18px;
    font-weight:700;
    line-height:1.2;
  }
}

/* ===========================
   Tablet específico (768–980)
   =========================== */
@media (min-width:768px) and (max-width:980px){
  .av-columna-2{ padding-right:20px; }
  .av-columna-2 .et_mobile_menu{ width:min(86vw, 380px) !important; }
}

/* ===========================
   Móvil específico (≤767)
   =========================== */
@media (max-width:767px){
  .av-menu{
    min-height:68px;
    padding:10px 12px;
  }
  .av-columna-2{ padding-right:10px; }

  /* pequeño ajuste visual del ícono si tu fuente lo “levanta” */
  .av-columna-2 .mobile_menu_bar{ position:relative !important; top:2px !important; }

  .av-columna-2 .et_mobile_menu{ width:min(90vw, 320px) !important; }
}

/* Z-index defensivo */
.av-menu, .av-menu *{ z-index:1000; }

/* Ajuste posicion - menu hamburgesa */
@media (max-width: 767px) {
  .av-columna-2 .mobile_menu_bar {
    margin-top: 50px !important; /* Ajusta el valor hasta que se vea centrado */
  }
}

/* ===== 1. Ajuste del menú desplegable (dropdown) ===== */
@media (max-width: 980px) {
  .av-columna-2 .et_mobile_menu {
    top: calc(100% + 60px) !important; /* Baja el menú para evitar que se superponga con el logo */
    left: auto !important;             /* Elimina cualquier anclaje izquierdo heredado */
    right: -14px !important;           /* Desplaza el menú hacia la derecha para alinearlo con el ícono */
  }
}

/* ===== 2. Ajuste adicional para tablet (dropdown)  ===== */
@media (min-width: 768px) and (max-width: 980px) {
  .av-columna-2 .et_mobile_menu {
    top: calc(100% + 60px) !important; /* Baja un poco más el menú en tablet */
  }
}

/* Menu Movil */
/* Menu Hamburger Movil */
@media only screen and (max-width: 980px)  {
	#et-top-navigation span.mobile_menu_bar:before, 
	#et-top-navigation span.mobile_menu_bar:after {
		color: #ed1c24 !important;
	}
  
   .mobile_nav.opened .mobile_menu_bar:before {
        content: '\4d';  /* Cambia el menu a X cuando está abierto */
    }
}

/* =========================================================
   BIDA - Efecto de subrayado animado en menú personalizado
   Adaptado por AVSYS para Divi Builder
   ========================================================= */

/* ===== 1. Estilo base del menú en escritorio ===== */
@media (min-width: 981px) {
  /* Asegura que los enlaces del menú sean posicionados correctamente */
  .av-menu-bida a {
    position: relative;             /* Necesario para el pseudo-elemento ::before */
    display: inline-block;
    padding-bottom: 4px;            /* Espacio para la línea */
    text-decoration: none !important;
    transition: color 0.3s ease;    /* Suaviza el cambio de color */
  }

  /* Línea base invisible antes del hover */
  .av-menu-bida a::before {
    content: "";
    position: absolute;
    left: 0;
    right: 100%;
    bottom: 0;
    height: 2px;                    /* Grosor de la línea */
    background: #4a8b71;            /* Color verde corporativo */
    transition: right 0.3s ease-out;
  }

  /* Animación al pasar el cursor */
  .av-menu-bida a:hover::before {
    right: 0;
  }

  /* Estado activo (si quieres marcar una página actual manualmente con .activo) */
  .av-menu-bida a.activo::before {
    right: 0;
  }

  /* Cambio de color al hacer hover */
  .av-menu-bida a:hover {
    color: #4a8b71 !important;
  }
}

/* ===== 2. Desactivación del efecto en tablet y móvil ===== */
@media (max-width: 980px) {
  .av-menu-bida a::before {
    display: none !important; /* Oculta la línea decorativa */
  }
}




/* Forzar menu movil */
/* @media only screen and ( max-width: 1280px ) {
#top-menu-nav, #top-menu {display: none;}
#et_top_search {display: none;}
#et_mobile_nav_menu {display: block;}
} */

/* Esconde carrito woocommerce en menú de Divi */
/*.et-cart-info { 
	display:none; 
}*/

/* Elimina la linea debajo del header */
/* header#main-header.et-fixed-header, #main-header {
	-webkit-box-shadow:none !important;
	-moz-box-shadow:none !important;
	box-shadow:none !important;
} */
/* CSS para Submenu colapsado en Divi */
/* Ajustar el nuevo toggle del submenu */
ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,
ul.et_mobile_menu li.page_item_has_children .mobile-toggle,
.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,
.et-db #et-boc .et-l ul.et_mobile_menu li.page_item_has_children .mobile-toggle {
    width: 44px;
    height: 100%;
    padding: 0px !important;
    max-height: 44px;
    border: none;
    position: absolute;
    right: 0px;
    top: 0px;
    z-index: 999;
    background-color: transparent;
}

/* CSS para tener todo acomodado */
ul.et_mobile_menu > li.menu-item-has-children,
ul.et_mobile_menu > li.page_item_has_children,
ul.et_mobile_menu > li.menu-item-has-children .sub-menu li.menu-item-has-children,
.et-db #et-boc .et-l ul.et_mobile_menu > li.menu-item-has-children,
.et-db #et-boc .et-l ul.et_mobile_menu > li.page_item_has_children,
.et-db #et-boc .et-l ul.et_mobile_menu > li.menu-item-has-children .sub-menu li.menu-item-has-children {
    position: relative;
}

/* Remover el background color de los items del submenu */
.et_mobile_menu .menu-item-has-children > a,
.et-db #et-boc .et-l .et_mobile_menu .menu-item-has-children > a {
    background-color: transparent;
}

/* Colapsar submenu por defecto */
ul.et_mobile_menu .menu-item-has-children .sub-menu,
#main-header ul.et_mobile_menu .menu-item-has-children .sub-menu,
.et-db #et-boc .et-l ul.et_mobile_menu .menu-item-has-children .sub-menu,
.et-db #main-header ul.et_mobile_menu .menu-item-has-children .sub-menu {
    display: none !important;
    visibility: hidden !important;
}

/* Mostrar el submenu cuando el toggle esté abierto */
ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,
#main-header ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,
.et-db #et-boc .et-l ul.et_mobile_menu .menu-item-has-children .sub-menu.visible,
.et-db #main-header ul.et_mobile_menu .menu-item-has-children .sub-menu.visible {
    display: block !important;
    visibility: visible !important;
}

/* Ajuste de los estilos del toggle */
ul.et_mobile_menu li.menu-item-has-children .mobile-toggle,
.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle {
    text-align: center;
    opacity: 1;
}

/* Icono del toggle del submenu cuando está cerrado */
ul.et_mobile_menu li.menu-item-has-children .mobile-toggle::after,
.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children .mobile-toggle::after {
    top: 10px;
    position: relative;
    font-family: "ETModules";
    content: '3';
    color: #3665db;
    background: #f0f3f6;
    border-radius: 50%;
    padding: 3px;
}

/* Icono del toggle del submenu cuando está abierto */
ul.et_mobile_menu li.menu-item-has-children.dt-open > .mobile-toggle::after,
.et-db #et-boc .et-l ul.et_mobile_menu li.menu-item-has-children.dt-open > .mobile-toggle::after {
    content: '2';
}

/* Agregar forma de punta cuando el submenu está abierto */
.et_pb_menu_0.et_pb_menu .et_mobile_menu:after {
    position: absolute;
    right: 5%;
    margin-left: -20px;
    top: -14px;
    width: 0;
    height: 0;
    content: '';
    border-left: 20px solid transparent;
    border-right: 20px solid transparent;
    border-bottom: 20px solid #ffffff;
}

/* CSS de caja de menú y color del background */
.et_pb_menu_0.et_pb_menu .et_mobile_menu,
.et_pb_menu_0.et_pb_menu .et_mobile_menu ul {
    background-color: #ffffff !important;
    border-radius: 10px;
}


.sub-menu li a {
    display: block !important;
    line-height: 1.2em !important; /* Ajusta el valor según necesites */
}

/* Esconder reCaptcha - Divi */
body.et_pb_recaptcha_enabled .grecaptcha-badge {
    visibility: hidden !important;
}

/* Fix Logo on Movil */
@media only screen and (max-width: 767px) {
    body header img#logo {
        max-width: 80% !important;
        max-height: 80% !important;
        height: auto !important;
        width: auto !important;
    }
}

/* Top Menu Hover */
#top-menu-nav #top-menu a:hover,
#mobile_menu_slide a:hover,
.et-fixed-header #top-menu a:hover {
	color: #009ddc !important;
    opacity: 1;
}

.et_mobile_menu li a:hover,
.nav ul li a:hover {
    color: #009ddc; 
    opacity:1;
}

/* Fix Preguntas Frecuentes - Acordeon - Activar JS */
/* .et_pb_toggle_open .et_pb_toggle_title:before {
	display: block !important;
	content: "\e04f";
} */


/* Centrar Footer */
#footer-info {
	font-size: 12px;
	text-align: center;
	line-height: 1.2em;
	width: 100%;
}

/* Ajuste Top Arrow - Botones Whats y Tel */
.et_pb_scroll_top.et-pb-icon {
    bottom: 15px;
}

@media (max-width:700px) {
    .et_pb_scroll_top.et-pb-icon {
        bottom: 145px;
    }
}

/* Fix botones de Celular - Botones Whats y Tel */
@media (max-width:700px) {
    #footer-info {
	    padding-bottom: 15px;
    }
}

/* Color link e-mail footer */
#footer-info a {
	color: #ffffff;
}

#footer-info a:hover {
	color: #b0c295;
    opacity: 1;
}
