body {
  font-family: 'Dosis', sans-serif;
  background-color: #ffffff;
}
/*=====================================================================================================================================

Estilos para animaciones de waves

=====================================================================================================================================*/

.welcome-message {
  font-size: 35px;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 30%;
  transform: translate(-50%, -50%);
  color: white;
  z-index: 10;
}


.welcome-message h1 {
  font-family: 'Dosis', sans-serif;
  font-optical-sizing: auto;
  font-weight: 500;  /* Usar 300 para light weight */
  font-size: 70px;
}

.welcome-message h2 {
  font-family: 'Dosis', sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;  /* Usar 300 para light weight */
  font-size: 40px;
}




.waves {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.wave-container {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background: #000; /* Just for visualization purposes */
}


  .wave1, .wave2, .wave3 {
      position: absolute;
      top: 0;
      width: 100vw; /* Usa unidades relativas para que se ajusten dinámicamente */
      height: 100vh; /* Usa unidades relativas para que se ajusten dinámicamente */
      animation: slideLeft .5s ease forwards;
      width: 100%;
      height: auto;
      z-index: 1; /* Asegura que las waves estén detrás del texto y las imágenes */
  }

  .wave1 img, .wave2 img, .wave3 img{
      max-width: 95%;
      max-height: 95%;
      width: 100%;
      height: 100%;
      object-fit: contain;
  }

  .wave1 { left: -105%; animation-delay: 0.1s; }
  .wave2 { left: -110%; animation-delay: 0.2s; }
  .wave3 { left: -115%; animation-delay: 0.3s; }

  @keyframes slideLeft {
      from { transform: translateX(0); }
      to { transform: translateX(100%); }
  }

  @keyframes slideLeftWave4 {
  from {
      right: -90%;
  }
  to {
      right: -15%; /* Punto final de la animación para wave4 */
  }
}

  @keyframes slideLeftWave5 {
      from {
          right: -100%;
      }
      to {
          right: -20%; /* Punto final de la animación para wave5 */
      }
  }

  @keyframes slideLeftWave6 {
      from {
          right: -100%;
      }
      to {
          right: -25%; /* Punto final de la animación para wave6 */
      }
  }

  .divisor {
      width: 100%;
      height: 10px;
      background-color: #000000;
  }



/*!
==============================================================================================================================================

Estilos de pagina Principal Index 

==============================================================================================================================================
*/


/* Estilos para baner de presentacion */
.presentation {
    position: relative;
    width: 100%;
    height: auto; /* Cambia la altura a auto para que mantenga la relación de aspecto */
    padding-top: 40%; /* Usa padding-top para mantener la relación de aspecto. Ajusta el valor según la relación de aspecto de tu imagen */
    overflow: hidden;
    margin-top: 95px; /* Incrementa el margen superior para dejar espacio para la barra de navegación */
    z-index: 1; /* Mantén un z-index inferior para que esté debajo de la barra de navegación */
    background-image: url(../images/backgrounds/background1.jpg);
    background-size: cover; /* Asegura que la imagen cubra todo el contenedor sin distorsionarse */
    background-position: center; /* Centra la imagen en el contenedor */
    background-repeat: no-repeat; /* Evita que la imagen se repita */
  }
  
  
  /* Ajustes responsivos para la imagen de fondo */
  @media (max-width: 768px) {
    .presentation {
      padding-top: 40%; /* Ajusta el padding-top para mantener la relación de aspecto en pantallas más pequeñas */
    }
  }
  
    /* Ajustes responsivos para la imagen de fondo */
  @media (max-width: 768px) {
        .presentation {
            padding-top: 40%;
        }
    }
  /* Estilos para la informacion */
  
  .information {
    display: flex;
    justify-content: space-around;
    align-items: stretch;
    padding: 20px;
    background-color: #f3f3f3;
    border-top: 1px solid #ddd;
    border-bottom: 1px solid #ddd;
    text-align: center;
    flex-wrap: wrap;
  }
  
  .info {
    flex: 1;
    margin: 20px;
    padding: 20px;
    background-color: #ffffff;
    border: 1px solid #ddd;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  
  .icon-container {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 15px; /* Espacio entre el ícono y el título */
  }
  
  .icon-container img {
    max-width: 50px; /* Tamaño máximo del ícono */
    height: auto; /* Mantiene la proporción del ícono */
  }
  
  .icon-container:hover img {
    filter: invert(25%) sepia(93%) saturate(3694%) hue-rotate(186deg) brightness(95%) contrast(88%);
    transition: filter 0.3s;
  }
  
  .info h1 {
    font-family: 'Dosis', sans-serif;
    font-weight: 300;
    font-size: 24px;
    color: #20699f;
    margin-bottom: 15px;
  }
  
  .info p {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 16px;
    color: #333;
    line-height: 1.6;
    flex-grow: 1;
  }
  
  @media (max-width: 768px) {
    .information {
      flex-direction: column;
      padding: 15px;
    }
  
    .info {
      max-width: 100%;
      margin: 10px 0;
    }
  
    .info h1 {
      font-size: 20px;
    }
  
    .info p {
      font-size: 14px;
    }
  }
  

  
  
  /* Estilos para procutos nuevos */
  .newest {
    margin: 0 auto;
  
  }
  
  .newest-title {
    background-color: #ffffff; 
    text-align: center;
    margin-bottom: 20px;
    padding: 20px;
  }
  
  .newest-title h1 {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 45px;
    color: #20699f;
  }
  
  /* Estilos para la sección de productos */
  
  .products-text {
    text-align: center;
    margin-bottom: 20px;
  }
  
  .products-title {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 45px;
    color: #20699f;
  }
  
  
  /* Estilos generales para la sección de productos recientes */
  
  .recent-products {
    padding: 20px;
    background-color:#ffffff; 
  }
  
  /* Estilos generales para la sección de productos destacados */
  .featured-products {
    padding: 20px;
    background-color:#ffffff; 
  }
  
  /* Estilos para la sección de productos en oferta */
  .offer-products {
    padding: 20px;
    background-color:#ffffff; 
  }
  
   
  /* Contenedor de productos */
  
  .products {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; /* Espacio entre productos */
  }

  .products a {
    text-decoration: none;
    color: #000000; /* Color del texto */
  }
  /* Estilos individuales para cada producto */
  .product {
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 5px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    margin-bottom: 20px;
    width: calc(25% - 10px); /* Cuatro productos por fila con espacio */
    box-sizing: border-box;
    padding: 10px;
    transition: transform 0.3s ease;
  }
  
  .product:hover {
    transform: translateY(-5px);
  }
  
  .product-image {
    width: 100%;
    height: 200px;
    overflow: hidden;
  }
  
  .product-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }
  .product-text {
    text-align: center;
  }
  
  .product-title {
    font-size: 1.2em;
    margin-bottom: 10px;
    color: #333;
  }
  
  .product-description {  
    font-size: 0.9em;
    color: #666;
    margin-bottom: 10px;
  }
  
  .product-price {
    font-size: 1em;
    color: #333;
  }
  
  
  /* Media queries para dispositivos móviles */
  @media (max-width: 1200px) {
    .product {
      width: calc(33.33% - 10px); /* Tres productos por fila con espacio */
    }
  }
  
  @media (max-width: 768px) {
    .product {
      width: calc(50% - 10px); /* Dos productos por fila con espacio */
    }
  }
  
  @media (max-width: 480px) {
    .product {
      width: 100%; /* Un producto por fila */
    }
  }
  
  
  /* Estilos generales para la sección de contacto */
  .contact-tilte {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 45px;
    color: #20699f;
    padding: 40px;
    text-align: center;
    background-color: #f3f3f3;
    display: flex;
    justify-content: space-around;
  }
  
  .contact-info-container {
    text-align: center;
    background-color: #f3f3f3;
    display: flex;
    justify-content: space-around;
  }
  
  
  .contact-options {
    display: flex;
    justify-content: center;
    gap: 40px; /* Espacio entre las columnas */
    margin-top: 20px;
  }
  
  .contact-info {
    flex: 1;
    margin: 20px;
    padding: 50px;
    background-color: #ffffff;
    border: 1px solid #ddd;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  
  }
  
  .contact-icon-container img {
    max-width: 60px; /* Tamaño máximo del ícono */
    height: auto; /* Mantiene la proporción del ícono */
  }
  
  .contact-icon-container:hover img {
    filter: invert(25%) sepia(93%) saturate(3694%) hue-rotate(186deg) brightness(95%) contrast(88%);
    transition: filter 0.3s;
  }
  
  .contact-info h1 {
    font-family: 'Dosis', sans-serif;
    font-weight: 300;
    font-size: 35px;
    color: #20699f;
    margin-bottom: 15px;
  }
  
  .contact-info p {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 23px;
    color: #333;
    line-height: 1.6;
    flex-grow: 1;
  }
  
  .social-links {
    display: flex;
    flex-direction: column; /* Asegurar que los enlaces de redes sociales se dispongan en columna */
    gap: 10px; /* Espacio entre los enlaces */
  }
  
  
  .social-links a {
    text-decoration: none;
    color: #000000; /* Color de los enlaces */
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 20px;
  }
  
  .social-links a:hover {
    color: #20699f;
  }
  
  .social-icons {
    gap: 10px; /* Espacio entre los enlaces */
  }
  
  .social-icons img {
    max-width: 15px; /* Tamaño máximo del ícono */
    height: auto; /* Mantiene la proporción del ícono */
  }
  
  .social-icons a:hover {
    color: #20699f;
  }
  
  
  
  /* Estilos para el contenedor del mapa */
  .map-container {
    flex: 1;
    margin: 20px;
    height: 500px;
    width: 500px;
    padding: 50px;
    background-color: #ffffff;
    border: 1px solid #ddd;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  
  }
  
  .map-container iframe {
    width: 100%;
    height: 100%;
    border: 0;
  }
  
  
  .location-container {
    text-align: center;
    background-color: #f3f3f3;
    display: flex;
    justify-content: space-around;
  }
  
  
  .location-icon-container img {
    max-width: 80px; /* Tamaño máximo del ícono */
    height: auto; /* Mantiene la proporción del ícono */
  }
  
  .location-icon-container:hover img {
    filter: invert(25%) sepia(93%) saturate(3694%) hue-rotate(186deg) brightness(95%) contrast(88%);
    transition: filter 0.3s;
  }
  
  
  .map-container h1 {
    font-family: 'Dosis', sans-serif;
    font-weight: 300;
    font-size: 35px;
    color: #20699f;
    margin-bottom: 15px;
  }
  
  .map-container p {
    font-family: 'Dosis', sans-serif;
    font-weight: 200;
    font-size: 23px;
    color: #333;
    line-height: 1.6;
    flex-grow: 1;
  } 
  
  
  
  @media (max-width: 480px) {
    .contact-info-container {
      flex-direction: column;
    }
  
    .contact-info h1 {
      font-size: 25px; /* Ajustamos el tamaño de la fuente para móviles */
    }
  
    .contact-info p {
      font-size: 18px; /* Ajustamos el tamaño de la fuente para móviles */
    }
  
    .map-container {
      height: 600px; /* Ajustamos la altura del mapa para móviles */
      width: 100%; /* Ajustamos el ancho del mapa para móviles */
    
    }
  
  }

  @media (max-width: 1280px) {
    .welcome-message h1 {
      font-size: 5vw;
    }
    .welcome-message h2 {
      font-size: 3vw;
    }
  }
  
  
/* Estilos para el contenedor de categorías */
.categories {
  max-width: 100%;
  margin: 0 auto;
  position: relative;
}

/* Estilos para los slides */
.carousel-slide {
  position: relative;
  text-align: center;
}

.carousel-img img {
  margin-left: 315px;
  max-width: 100%;
  height: auto;
  object-fit: cover;
  z-index: 2; /* Asegura que la imagen esté sobre la forma azul */
}

/* Estilos para el contenido de cada slide */
.carousel-slide .slide-content {
  position: absolute;
  top: 50%; /* Centra verticalmente el contenido */
  left: 100px; /* Ajusta el espacio a la izquierda */
  transform: translateY(-50%); /* Centra verticalmente el contenido */
  color: white;
  width: 300px; /* Fija el ancho del contenedor para mantener tamaño uniforme */
  height: 200px; /* Fija la altura del contenedor para mantener tamaño uniforme */
  padding: 20px; /* Ajusta el padding para un mejor espaciado */
  border-radius: 15px;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}

/* Estilos para el título */
.carousel-slide h2 {
  font-family: 'Dosis', sans-serif;
  font-weight: 200;
  font-size: 45px; /* Ajusta el tamaño de la fuente para mejor visibilidad */
  margin-bottom: 15px; /* Aumenta el espacio inferior */
}

/* Estilos para el botón */
.carousel-slide .btn-more {
  font-family: 'Dosis', sans-serif;
  font-weight: 300;
  font-size: 30px; /* Ajusta el tamaño de la fuente */
  color: white;
  background-color: #20699f;
  border: none;
  padding: 10px 20px; /* Ajusta el padding para un botón más grande */
  cursor: pointer;
  border-radius: 5px;
  transition: background-color 0.3s ease;
}

.carousel-slide .btn-more:hover {
  background-color: #268cb5;
}


.blue-shape {
  position: absolute;
  left: 0; /* Mueve la forma a la derecha */
  width: 60.33%; /* Un tercio del ancho del contenedor */
  height: 100%;
  background-color: #8AC1DD; /* Color de la forma */
  background: linear-gradient(to right, #8AC1DD 70%, transparent 100%);
  /* Puedes ajustar el color y el grado de desvanecimiento según tus necesidades */
}


/* Estilos generales para las flechas */
.carousel .slick-prev,
.carousel .slick-next {
 /* Color de fondo de las flechas */
    border-radius: 50%; /* Forma circular */
    width: 40px; /* Ancho de la flecha */
    height: 40px; /* Alto de la flecha */
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer; /* Puntero de mano */
    z-index: 10; /* Asegura que las flechas estén por encima del contenido */
    position: absolute; /* Posicionamiento absoluto para centrar verticalmente */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Sombra para dar profundidad */
    transition: background-color 0.3s, transform 0.3s; /* Transición suave para hover y animaciones */
}

/* Estilo para la flecha izquierda */
.carousel .slick-prev {
  left: 20px; /* Margen izquierdo */
  top: 50%; /* Centrado verticalmente */
  transform: translateY(-50%) scale(1.5); /* Agranda la flecha horizontal y verticalmente */
}

/* Estilo para la flecha derecha */
.carousel .slick-next {
  right: 20px; /* Margen derecho */
  top: 50%; /* Centrado verticalmente */
  transform: translateY(-50%) scale(1.5); /* Agranda la flecha horizontal y verticalmente */
}

/* Hover para las flechas */
.carousel .slick-prev:hover,
.carousel .slick-next:hover {
  background-color: #0056b3; /* Color de fondo al hacer hover */
  transform: translateY(-50%) scale(1.8); /* Agranda la flecha al hacer hover */
}


/* Responsivo: ajustar el tamaño de las flechas en dispositivos más pequeños */
@media (max-width: 768px) {
  .carousel .slick-prev,
  .carousel .slick-next {
      width: 30px; /* Tamaño base reducido horizontalmente */
      height: 30px; /* Tamaño base reducido verticalmente */
  }
}



/* Estilos para dispositivos móviles */
@media (max-width: 768px) {
  .carousel-slide {
    height: auto; /* Ajusta la altura automáticamente */
    display: flex;
    flex-direction: column; /* Asegura que el contenido esté en columna */
    justify-content: center; /* Centra verticalmente el contenido */
  }

  /* Estilos para el título */
  .carousel-slide h2 {
    font-size: 35px; /* Ajusta el tamaño de la fuente para mejor visibilidad */
  }

  /* Estilos para el botón */
  .carousel-slide .btn-more {
    font-size: 20px; /* Ajusta el tamaño de la fuente */
  }


  .carousel-slide {
    height: 300px !important; /* Ajusta según sea necesario */
}

  .carousel-img img {
    width: 100%; /* Asegura que la imagen tome el ancho completo del contenedor */
    height: auto; /* Mantiene la proporción de la imagen */
    object-fit: contain; /* Asegura que toda la imagen sea visible */
    margin-left: 0; /* Centra la imagen en móviles */
  }

  .blue-shape {
    position: absolute;
    bottom: 0; /* Mueve la forma a la parte inferior */
    left: 0;
    width: 100%;
    height: 200px; /* Ajusta la altura según sea necesario */
    background-color: #8AC1DD;
    background: linear-gradient(to top, #8AC1DD 70%, transparent 100%);
    z-index: 1; /* Asegura que esté debajo de la imagen */
  }


  .carousel-slide .slide-content {
    top: 70%; /* Ajusta la posición del texto para que esté en la parte sólida de la forma */
    width: 90%; /* Ajusta el ancho para dispositivos móviles */
    height: auto; /* Ajusta la altura automáticamente */
    padding: 10px; /* Ajusta el padding para un mejor espaciado en móviles */
    z-index: 4; /* Asegura que el contenido esté encima de todo */
    left: 5%;
  }
}


/* Estilos para dispositivos móviles */

/* Estilos específicos para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
  .carousel-slide {
    height: 800px; /* Ajusta la altura para tablets */
  }

  .carousel-slide .slide-content {
    left: 5%;
  }
}