@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap');


:root{
    --fuente-texto: "Lato", sans-serif;
    font-size: 16px; /* Base para unidades rem */
    --color-primary: #143D60; 
    --color-secondary: #EB5B00;
}


/* Preloader */
.preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #ffffff; /* Fondo blanco */
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 9999;
    font-family: Arial, sans-serif;
    font-size: 1.5rem;
    color: #143D60; /* Color del texto */
}

/* Estilos para el header */
.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap; /* Permite que los elementos se ajusten en pantallas pequeñas */
    background-color: rgba(255, 255, 255, 0.85); /* Color de fondo */
    width: 100%; /* Ocupa todo el ancho */
    padding: 0.625rem 5%;
    position: fixed; /* Fija en la parte superior (fixed) */
    top: 0; /* Pegado al borde superior */
    left: 0; /* Pegado al borde izquierdo */
    z-index: 1000; /* Asegura que esté por encima de otros elementos */
    margin: 0; /* Elimina márgenes por defecto */
    border-bottom: 6px solid #143D60; /* Línea sólida (ajusta color/grosor) */
    min-height: 125px; /* Altura flexible */
}

/* Estilos para el logo */
.logoQYM {
    width: auto;
    height: auto;
    transform: scale(1.5); /* Escala el logo */
    position: relative;  /* Permite ajustar la posición */
    left: 55px;         
    top: 2px;          /* Mueve el logo hacia arriba 7px */
}

/* Estilos para el header */
.titulos-header {
    display: flex;
    flex-direction: column; /* Apila h1 y h2 verticalmente */
    justify-content: center; /* Centra verticalmente si hay altura extra */
    margin-right: 120px; /* Espacio entre el logo y la frase */
    top: 35px; /* Mueve hacia abajo */
}

/* Estilos para el header */
.frase_header {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-style: italic;
    font-size: clamp(0.9rem, 2vw, 1rem); /* Tamaño flexible */
    color: gray; /* Color azul de tu marca */
    position: relative; /* Permite moverla con top/left */
    margin: 0; /* Elimina márgenes por defecto de h1 y h2 */
    line-height: 1.4; /* Controla el espacio entre líneas */
}

/* Estilos para el menú */
.header__menu {
    display: flex;
    gap: 40px;
    position: relative;  /* Permite ajustar la posición */
    left: -190px;
    flex-wrap: wrap;
    justify-content: center;
}
/* Estilos para el header */
.header__menu__link {
    font-family: var(--fuente-texto);
    font-weight: 700;
    font-style: normal;
    font-size: 1.1rem;
    color: #143D60; /* Color naranja de tu marca */
    text-decoration: none;
    position: relative; /* Permite moverlos con top/left */
    top: 45px; /* Mueve hacia abajo */
}

/* Estilos para el header */
.header__menu__link.active {
    color: #EB5B00; /* Color azul de tu marca */
    border-bottom: 2px solid #EB5B00; /* Línea azul en la parte inferior */
}

/* Estilos para el body */
body {
    padding-top: 175px; /* Mismo valor que la altura del header */
    margin: 0; /* Esto elimina los márgenes predeterminados del body */
    padding: 0;
    width: 100%;
    overflow-x: hidden; /* Previene barras de desplazamiento horizontales */
    font-family: var(--fuente-texto);
    line-height: 1.6;
    color: #333;
    background-color: #fff;
    
    
}

/* Contenedor principal */
.contenedor-principal {
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: 150px; /* Ajusta este valor según necesites */
    display: flex;
    align-items: flex-start;
    gap: 20px;
    position: relative;
    overflow: hidden; /* Asegura que el contenido que se desplace no cause scroll */
    display: flex;
    justify-content: center; /* Centra el contenido en pantallas grandes */
    max-width: 1400px; /* Limita el ancho máximo */
    margin: 150px auto 0; /* Centrado horizontal */
    padding: 75px 50px;
    line-height: 1.55;
    margin-top: -155px;
    margin-bottom: -150px;
}

#inicio,
#empresa,
#servicios,
#clientes,
#equipo,
#contacto {
    margin-bottom: 75px; /* Ajusta este valor según necesites */
}

#inicio {
    position: relative; /* Necesario para superponer el contenido */
    
}

/* Estilo para el enlace (elemento clickeable) */
.video-link {
    display: block; /* Necesario para que el cursor y hover funcionen bien */
    cursor: pointer;
    position: absolute;
    top: 770px;   /* Ajusta según necesites */
    right: 205px; /* Alinea con el icono */
    z-index: 999;
     transition: transform 0.3s ease;
}

.video-link:hover {
    transform: scale(1.05);
}

.icono_video {
    position: absolute;
    top: -20px; /* Ajusta según necesites */
    right: 307px; /* Ajusta según necesites */
    width: 60px; /* Define un tamaño fijo o máximo */
    height: auto;
    transition: transform 0.3s ease;
    cursor: pointer; /* Cambia el cursor al pasar sobre el icono */
    border: #EB5B00 4px solid; /* Borde del icono */
}

.icono_video:hover {
    transform: scale(1.1);
}

.leyenda_video {
    position: absolute;
    top: 782px;     /* Debajo del icono */
    right: 200px;   /* Ajusta para centrar con el icono */
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-primary);
    text-align: center;
    white-space: nowrap; /* Evita salto de línea */
    pointer-events: none; /* Permite que el click pase al enlace, no interfiera */
    z-index: 10;
}

.icono_video{
    cursor: pointer;
    transition: transform 0.3s ease; /* Opcional: efecto suave al pasar el mouse */
  }

  .icono_video:hover {
    transform: scale(1.1); /* Hace que el icono crezca un poco al pasar el mouse */
  }

/* Estilo Index */
 .fotoindex {
    filter: grayscale(100%);
    transition: filter 0.5s;
    position: relative; /* Necesario para la animación */
    right: -22px;
    bottom: -55px; /* Mueve la imagen hacia abajo 75px */
    transform: scale(0.8); /* Escala la imagen % */
    border-radius: 10px;
}   
    
.fotoindex:hover {
    filter: grayscale(0%);
}

/* Contenedor del contenido */
.contenido {
    flex: 1;
    display: flex;
    flex-direction: column;
    position: relative; /* Necesario para la animación */
    max-width: 1600px; /* Cambia este valor (ej: 600px para más estrecho) */
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-style: normal;
    line-height: 1.55;
    margin-top: 70px;
    margin-bottom: 15px;
    font-size: 1.2rem;
    color: #333;
    line-height: 1.55;
    word-break: break-word; /* Evita desbordamiento horizontal */
    white-space: normal; /* Asegura comportamiento normal */
    word-wrap: normal; /* Permite que las palabras largas no se dividan */
    overflow-wrap: normal; /* Similar a word-wrap pero más moderno */
    position: relative;
    /* left: -60px; */ /* Comentada para evitar conflicto */
    width: 100%;
}

.resaltar {
    color: #EB5B00;
    font-weight: bold;
}

.contenido-index {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-style: normal; 
}

.texto-index {
    line-height: 1.55;
    margin-top: 70px;  
}

#inicio .contenido {
    padding: 25px; /* Espacio interno */
    border-radius: 10px; /* Esquinas redondeadas */
    position: relative; /* Permite superponerlo */
    z-index: 1; /* Asegura que esté sobre la imagen */
    max-width: 800px; /* Ancho controlado */
    margin-top: 170px; /* Ajusta según necesidad */
    left: 5px; /* Mueve el texto hacia la izquierda */
}

#inicio .contenido p {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-style: normal;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 50px;
    line-height: 1.55;
    word-break: break-word; /* Evita desbordamiento horizontal */
    white-space: normal; /* Asegura comportamiento normal */
    word-wrap: normal; /* Permite que las palabras largas no se dividan */
    overflow-wrap: normal; /* Similar a word-wrap pero más moderno */
    position: relative;
    left: -5px; /* Mueve el texto hacia la izquierda 20px */
}

#inicio .contenido ul {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 10px;
    line-height: 1.55;
    position: relative;
    top: -50px; /* Mueve el texto hacia abajo 20px */
    left: 220px; /* Mueve el texto hacia la izquierda 20px */
}

#inicio .contenido h1 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-style: normal;
    font-size: 1.75rem;
    color: #143D60;
    text-align: center;
    margin-bottom: 20px;
    margin-top: -35px;
    position: relative;
    left: -5px; /* Mueve el texto hacia la izquierda */
    white-space: pre-line; /* Salto automático de línea */
    max-width: 800px; /* Ajusta este valor hasta que quede en 2 líneas */
    /* Propiedades clave para controlar el salto de línea */
    white-space: pre-line; /* Salto automático según espacio */
    max-width: 100%; /* Usa el ancho del contenedor padre */
    word-break: break-word; /* Evita desbordamiento horizontal */   
}

.vineta-container {
  position: relative;
  width: 100%;
  margin-bottom: 30px; /* Espacio entre párrafo y viñeta */
}

.vineta {
  display: block;
  width: fit-content;
  margin: 0 auto 10px auto; /* Centra la viñeta horizontalmente */
  font-size: 1.5rem;
  color: #143D60; /* Cambia al color deseado */
}

/* Estilos específicos para empresa.html */
.infografia{
    scale: 1.25; /* Escala la imagen */
    position: relative;
    left: -65px; /* Mueve el texto hacia la izquierda 20px */ 
    top: 237px;    
}

#empresa .contenido {
    padding: 25px; /* Espacio interno */
    position: relative; /* Permite superponerlo */
    z-index: 1; /* Asegura que esté sobre la imagen */
    max-width: 800px; /* Ancho controlado */
    margin-top: 170px; /* Ajusta según necesidad */
    margin-left: 120px;;
}

#empresa .contenido h1{
    font-size: 1.75rem !important;
    color: #143D60;
    margin-bottom: 300px;
    font-family: var(--fuente-texto);
    font-weight: 600;
    position: relative;
    left: 200px; /* Mueve el texto hacia la izquierda 20px */
}

.parrvym {
    position: relative;
    margin-left: -126px;
    margin-top: -40px;
    display: block;
    width: 100%;
    box-sizing: border-box;
    width: calc(100% + 60px); /* Opcional: compensa el margen */
}

#empresa .contenido h2 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.5rem;
    color: #143D60;
    margin-bottom: 245px;
    position: relative;
    left: 325px; /* Mueve el texto hacia la izquierda 20px */
}

#empresa .contenido .vym {
    margin-top: -10px;
    font-size: 1.2rem;
    position: relative;
    left: -5px; /* Mueve el texto hacia la izquierda 20px */
    word-break: break-word; /* Rompe palabras largas */
    white-space: normal; /* Permite saltos de línea normales */
    overflow-wrap: break-word; /* Refuerza el comportamiento */    
}

#empresa .contenido p {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 120px;
    line-height: 1.55;
    left: 0px; /* Mueve el texto hacia la izquierda 20px */
    max-width: 730px; /* Ancho controlado */
    word-break: break-word; /* Rompe palabras largas */
    white-space: normal; /* Permite saltos de línea normales */
    overflow-wrap: break-word; /* Refuerza el comportamiento */
    text-align: justify;
}

/* Reduce el espacio debajo del primer párrafo */
#empresa .contenido .vym + h2 {
  margin-top: -50px;
}

/* Reduce el espacio antes de los párrafos de Visión y Misión */
#empresa .contenido h2 + .vym {
  margin-top: -225px;
}

.recuadro {
  border: 1px solid #143D60; /* Borde azul oscuro */
  border-radius: 10px; /* Esquinas redondeadas (opcional) */
  padding: 10px 15px; /* Espacio interno */
  max-width: 730px; /* Ajusta este valor según sea necesario */
  max-height: 210px; /* Ajusta este valor según sea necesario */
  margin: 0 auto 55px; /* Centrado horizontal + espacio debajo */
  position: relative;
  left: -146px;
  top: -35px;
}

/* Elimina márgenes extra entre h2 y p dentro del recuadro */
.recuadro h2,
.recuadro .vym {
  margin-top: 0;
  margin-bottom: 6px;
}

.recuadro:last-child {
  margin-bottom: 0px; /* Espacio debajo del último recuadro */
}

.recuadro p.vym {
  margin-top: 8px;
}

/* Opcional: efecto hover */
.recuadro:hover {
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1);
  transform: translateY(-5px);
  transition: all 0.3s ease;
}

/* Estilos específicos para servicios.html */
.fotoservicios {
    filter: grayscale(100%);
    transition: filter 0.5s;
    position: relative; /* Necesario para la animación */
    right: -72px;
    bottom: -115px; /* Mueve la imagen hacia abajo 75px */
    transform: scale(0.8); /* Escala la imagen % */
    border-radius: 10px;
}   
    
.fotoservicios:hover {
    filter: grayscale(0%);
}

#servicios .contenido {
    padding: 25px; /* Espacio interno */
    border-radius: 10px; /* Esquinas redondeadas */
    position: relative; /* Permite superponerlo */
    z-index: 1; /* Asegura que esté sobre la imagen */
    max-width: 730px; /* Ancho controlado */
    margin-top: 125px; /* Ajusta según necesidad */
    left: 0px; /* Mueve el texto hacia la izquierda 20px */
    text-align: justify;
}

.pagina-servicios .contenido h1 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.75rem;
    color: #143D60;
    margin-bottom: 0px;
    margin-top: 0px;
    position: relative;
    left: -12px; /* Mueve el texto hacia la izquierda 20px */
    margin-bottom: 20px;
}

.pagina-servicios .contenido p,
.pagina-servicios .contenido ul {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 20px;
    line-height: 1.55;
    position: relative;
    left: -12px; /* Mueve el texto hacia la izquierda 20px */
}

.pagina-servicios .contenido ul {
    padding-left: 20px;
    list-style-type: disc;
}

.pagina-servicios .contenido ul li {
    margin-bottom: 10px;
    font-size: 1.2rem;
    color: #333;
    font-family: var(--fuente-texto);
}

/* Reset de estilos conflictivos -  estilo CLIENTES */
.clientes-container * {
    box-sizing: border-box;
    min-width: 0;
}

/* Contenedor principal - FORZAR 3 columnas */
.clientes-container {
    width: 100%;
    min-width: 1000px; /* Mínimo para 3 columnas */
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
    background-color: white;
    overflow: visible !important;
    position: relative;
    right: -75px;
}

/* Lista de clientes - IMPOSICIÓN de 3 columnas */

#clientes .contenido h1 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-style: normal;
    font-size: 2.25rem; /* Changed from 1.75rem to 2.25rem */
    color: #143D60;
    margin: 40px 40px; /* Added margin-top and margin-bottom */
}

#clientes .contenido{
  justify-content: center; /* Added to center the h1 */
  align-items: center; /* Added to center the h1 */
  margin-top: 120px;
}

.lista-clientes {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(300px, 1fr)) !important;
    gap: 15px;
    width: 100% !important;
    padding: 0 !important;
}

/* Items de cliente - Aseguramos comportamiento */
.cliente {
    width: 100% !important;
    min-width: 300px !important;
    max-width: 100% !important;
    padding: 10px 15px;
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1rem;
    color: #333;
    border-left: 3px solid #EB5B00;
    background-color: white;
}

.cliente:hover {
    transform: translateY(-3px);
    box-shadow: 0 4px 8px rgba(0,25,101, 0.1);
    background-color: #fff;
}

/* Estilos de Equipo */
.fotoequipo {
    filter: grayscale(100%);
    transition: filter 0.5s;
    position: relative; /* Necesario para la animación */
    right: -12px;
    bottom: -90px; /* Mueve la imagen hacia abajo 75px */
    transform: scale(0.7); /* Escala la imagen % */
    border-radius: 10px;
}   
    
.fotoequipo:hover {
    filter: grayscale(0%);
}

#equipo .contenido {
    padding: 25px; /* Espacio interno */
    position: relative; /* Permite superponerlo */
    z-index: 1; /* Asegura que esté sobre la imagen */
    max-width: 730px; /* Ancho controlado */
    margin-top: 120px; /* Ajusta según necesidad */
    left: 0px; /* Mueve el texto hacia la izquierda 20px */
    text-align: justify;
}

.pagina-equipo .contenido h1 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.75rem;
    color: #143D60;
    margin-bottom: 0px;
    margin-top: 0px;
    position: relative;
    right: 13px;
}

.pagina-equipo .contenido h2 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.5rem;
    color: #143D60;
    position: relative;
    right: 13px;
}

.pagina-equipo .contenido h3 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.5rem;
    color: #143D60;
    margin-bottom: -10px;
    position: relative;
    right: 13px;
}

.pagina-equipo .contenido p {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 20px;
    line-height: 1.55;
    position: relative;
    right: 13px;
}

/* Estilo Contacto */
.fotocontacto {
    filter: grayscale(100%);
    transition: filter 0.5s;
    position: relative; /* Necesario para la animación */
    right: -22px;
    bottom: -15px; /* Mueve la imagen hacia abajo 75px */
    transform: scale(0.8); /* Escala la imagen % */
}   
    
.fotocontacto:hover {
    filter: grayscale(0%);
}

/*#contacto .redes_contacto {
    text-align: left;
    margin-left: 0;
    padding-left: 0;
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.75rem;
    position: relative;
    left: 850px; 
    margin-top: 147px;
    text-decoration: underline;
    color: #143D60;
}*/

#contacto .contenido p {
    font-family: var(--fuente-texto);
    font-weight: 400;
    font-size: 1.2rem;
    color: #333;
    margin-bottom: 5px;
    line-height: 1.55;
    position: relative;
    left: 100px; 
}

/*.logoyoutube_contacto {
    position: relative;
    top: 225px; 
    left: -350px; 
    transform: scale(0.8); 
    display: inline-block;
    transition: transform 0.3s ease;
}*/

.logoyoutube_contacto:hover {
    transform: scale(1.05); /* Agranda un 10% al pasar el mouse */
}

/*.logoinstagram_contacto {
    position: relative;
    top: 297px; 
    left: -430px; 
    transform: scale(0.8); 
    display: inline-block;
    transition: transform 0.3s ease; 
}*/

.logoinstagram_contacto:hover {
    transform: scale(1.08); /* Agranda un 10% al pasar el mouse */
}
.icono1_contacto {
    position: relative;
    top: 160px; /* Ajusta según necesidad */
    left: -1000px; /* Ajusta según necesidad */
    scale: 1; /* Escala la imagen */
}

.icono2_contacto {
    position: relative;
    top: 255px; /* Ajusta según necesidad */
    left: -1070px; /* Ajusta según necesidad */
    scale: 0.8; /* Escala la imagen */
}

.icono3_contacto {
    position: relative;
    top: 450; /* Ajusta según necesidad */
    left: -1100px; /* Ajusta según necesidad */
    scale: 0.8; /* Escala la imagen */
}

.iconos_contacto {
    position: relative;
    top: 230px; /* Ajusta según necesidad */
    left: -605px; /* Ajusta según necesidad */
    scale: 1; /* Escala la imagen */
}

#contacto .correo{
    position: relative;
    top: 215px; /* Ajusta según necesidad */
    right: 140px; /* Ajusta según necesidad */
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.2rem;
    color: #143D60;
}

#contacto .contenido h1 {
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.75rem;
    color: #143D60;
    position: relative;
    left: 395px; 
    margin-bottom: 0px;
    margin-top: -25px;
}

#contacto .cel{
    position: relative;
    top: 300px; /* Ajusta según necesidad */
    right: 350px; /* Ajusta según necesidad */
    font-family: var(--fuente-texto);
    font-weight: 600;
    font-size: 1.2rem;
    color: #143D60;
}

#contacto .contenido {
    position: relative; /* Permite superponerlo */
    z-index: 1; /* Asegura que esté sobre la imagen */
    max-width: 600px; /* Ancho controlado */
    margin-top: 170px; /* Ajusta según necesidad */
    margin-bottom: 240px; /* Ajusta este valor según necesites */
}

/* Estilos para el footer centrado */
.footer {
    background-color: white;
    width: 100%;
    padding: 2rem 0;
    margin-top: 3rem;
    border-top: 3px solid var(--color-secondary);
}

.footer__contenedor {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
    text-align: center;
}

.footer__info p {
    margin: 0;
    font-size: 0.9rem;
    color: var(--color-primary);
    --fuente-texto: "Lato", sans-serif; 
}
/* Animación para mover el contenido */
/* Tablets y dispositivos medianos */
@media (max-width: 992px) {
    .header__menu {
        gap: 1rem;
    }

    #inicio .contenido h1 {
        font-size: 1.75rem;
    }
}

/* Móviles - Pantallas pequeñas */
@media (max-width: 768px) {
    .header__menu {
        flex-direction: column;
        align-items: center;
    }

    #inicio .contenido h1 {
        font-size: 1.5rem;
    }

    .cliente {
        min-width: 100% !important;
    }
}