:root{
    /** Tipo de letra **/
    --FuenteHeading: 'Krub', sans-serif;
    --fuenteSecundaria: 'Open Sans', sans-serif;
    --fuentePrincipal: 'PT Sans', sans-serif;

    /** Colores **/
    --Borgoña: #8B0000;
    --amarillo:#F39C12;
    --negro: #1B1B1B;
    --blanco: #ffffff;
    --cloud:#ecf0f1;
    --colorTexto: #333; /* Color para texto */
    --mainBlue:hsl(208, 92%, 54%);

}

html{
    box-sizing: border-box;
    font-size: 62.5%; /* 1 rem = 10px */

}

*, *:before, *:after{
    box-sizing: inherit;
}

body{
    font-family: var(--fuentePrincipal);
    font-size: 1.6rem;
    line-height: 2;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

/** Globales **/

.contenedor{
    max-width: 120rem;
    width: 90%;
    margin: 0 auto;
}

a{
    text-decoration: none;
}

h1, h2, h3, h4{
    font-family: var(--fuentePrincipal);
}

h1{
    font-size: 4.8rem;
}

h2{
    font-size: 3rem;
    line-height: 1.1;
}

@media (min-width: 480px) { 
    h2{
        font-size: 4rem;
    }
}

h3{
    font-size: 3.2rem;
}

h4{
    font-size: 2.8rem;
}

img{
    max-width: 100%;
}


/** Utilidades **/

.no-margin{
    margin: 0;
}

.no-padding{
    padding: 0;
}

.centrar-texto{
    text-align: center;
}

/** Header **/

.webp .header {
    background-image: url(img/header.webp);
}
.no-webp .header {
    background-image: url(img/header.JPG);
}

.header{
    height: 60rem;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
    position: relative;
    margin-bottom: 2rem;
}

.header__contenedor{
    position: absolute;
    background-color: rgba(0, 0, 0, .8);
    width: 100%;
    height: 100%;
}


.header__texto{
    text-align: center;
    color: var(--cloud);
    margin: 9rem 1rem 0 1rem;
    line-height: 1.5;
}

.header__texto > p{
    margin-top: 1.5rem;
}

@media (min-width: 768px) { 
    .header__texto{
        font-family: var(--fuentePrincipal);
        margin-top: 9rem;
    }
}

.logo {
    position: relative; /* Contenedor relativo para controlar los elementos internos */
    display: inline-block; /* Asegura que el tamaño sea ajustado a los elementos internos */
    text-align: center; /* Centra todo horizontalmente */
}

.logo__subtitulo {
    font-size: 1.5rem; /* Ajusta el tamaño según lo necesario */
    font-weight: 400; /* Si prefieres un estilo más ligero */
    color: var(--amarillo); /* Cambia el color si es necesario */
    margin-top: -3rem;
}


@media (min-width: 840px) { 
    .barra{
        display: flex;
        justify-content: space-between;
        align-items: center;
    } 

    .logo__subtitulo {
        font-size: 1.5rem; /* Ajusta el tamaño según lo necesario */
        font-weight: 400; /* Si prefieres un estilo más ligero */
        color: var(--amarillo); /* Cambia el color si es necesario */
        margin-top: -3rem;
    }
}



.logo__nombre{
    color: var(--Borgoña);
}

.logo__span{
    color: var(--amarillo);
}

.logo__nombre,
.logo__span{
    text-align: left;
}



/** Menu desplegable **/

@media (min-width: 840px) {
    .nav-responsive {
        display: none;
    }

    .navegacion {
        display: flex;
        gap: 2rem;
    }
}

@media (max-width: 840px) { 
    .navegacion {
        display: none; /* Oculta el menú de navegación en pantallas pequeñas */
    }

    .nav-responsive{
        background-color: var(--amarillo);
        color: var(--cloud);
        padding: .5rem 1.5rem;
        border-radius: .5rem;
        cursor: pointer;
        display: block;
        position: absolute;
        right: 3rem;
        top: 2rem;
        background-color: var(--amarillo);
    
    }

    .navegacion.responsive {
        display: contents;
        position: absolute;
        right: 2rem;
        top: 8rem;
        background-color: var(--amarillo);

    }

    .navegacion.responsive a {
        display: block;
        text-align: left;
        border-bottom: 1px solid var(--cloud);
        padding: .2rem;
        font-size: 1.4rem;
        font-family: var(--fuentePrincipal);
        color: var(--cloud);
    }

    .navegacion.responsive a:last-of-type {
        border: none;
    }

    .navegacion.responsive a:hover {
        background-color: var(--amarillo);
    }
    
}

.navegacion__enlace.active{
    color: #555;

}


.navegacion__enlace{
    display: block;
    text-align: center;
    font-size: 1.8rem;
    color: var(--cloud);
}

.navegacion__enlace:hover{
    color: var(--amarillo);
}

.btn{
    margin-top: 3rem;
}
.boton{
    background-color: var(--amarillo);
    color: var(--cloud);
    padding: 1rem 3rem;
    text-decoration: none;
    font-size: 2rem;
    text-transform: uppercase;
    font-family: var(--fuentePrincipal);
    font-weight: 700;
    border-radius: .5rem;
    width: 90%;
    text-align: center;
    border: none;
    display: inline-block;
}

.boton i{
    font-size: 2rem;
    margin-left: .8rem;
}

@media (min-width: 768px) {
    .btn .boton, .btn-nosotros .boton {
        display: inline-block;
        width: auto; /* Ajuste en pantallas grandes */
    }
}

@media (max-width: 767px) { 
    .btn .boton, .btn-nosotros .boton {
        width: 90%; /* Asegura que ambos usen el mismo ancho en móviles */
        margin: 0 auto; /* Centra el botón */
        display: block; /* Para evitar problemas con display inline */
    }
}

.btn-nosotros{
    margin: 1rem 0;
}

.boton:hover{
    cursor: pointer;
    background-color: var(--Borgoña);

}

/** Nosotros **/

.nosotros{
    margin-bottom: 2.5rem;
}

@media (max-width: 767px) { 
    .contenido > h3{
        text-align: center;
    }
}


.contenido > h3{
    margin-top: 3rem;
    margin-bottom: 2rem;
}

@media (min-width: 768px) { 
    .contenido-principal{
        display: grid;
        grid-template-columns: 2fr 2fr;
        column-gap: 3rem;
    }

    .nosotros__informacion{
        grid-row: 1/2;
    }

    .nosotros__informacion p{
        margin-top:0;
    }

}

.nosotros__imagen{
    max-width: 70%;
    margin: 0 auto;
}

.nosotros__informacion--redes{
    margin-top: .5rem;
    display: flex;
    gap: 3rem;

}


@media (max-width: 767px) { 
    .nosotros__informacion--redes{
        justify-content: center;
        margin-bottom: 1rem;
    }
    
}


@media (max-width: 767px) { 
    .nosotros__informacion > h4 {
        margin: 2rem 0;
        font-size: 2.3rem;
        text-align: center;
    }
}

@media (min-width: 768px) { 
    .nosotros__informacion > h4 {
        margin-top: 1.5rem;
        margin-bottom: 1rem;
        font-size: 2.3rem;
    }
}

.nosotros__informacion > p{
    text-align: justify;
}

/** productos **/

.productos{
        background-color: #1B1B1B;
        margin: 0; /* Elimina márgenes */
        padding: 2rem; /* Agrega espacio interior */
        width: 100vw; /* Extiende el fondo al ancho completo */
        position: relative;
        left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
        margin-bottom: 2.5rem;
}

.contenido-producto > h3{
    color: var(--cloud);
}

@media (min-width: 768px) { 
    .servicios{
        display: grid;
        grid-template-columns: 50% 50%;
        gap: 3rem;
    }

    .servicios__imagenes{
        display: flex;
        width: 100%;
        gap: 1.5rem;
    }

    .servicios__imagenes--foto{
        width: 28rem;
        height: 47rem;
        overflow: hidden;
    }

    .servicios__imagenes--foto img{
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: all 600ms;
    }

    .servicios__imagenes--foto:hover img{
        transform: scale(1.2);
    }

    .servicios__imagenes--foto:last-child{
        margin-top: 10rem;
    }
}

.servicios__informacion{
    color: var(--cloud);
    background-color: #2A2A2A;
    padding: 2rem;
    border-radius: 1rem;
    box-shadow: 0 .4rem .6rem rgba(255, 255, 255, 0.2);
    max-width: 80rem;
    margin: 0 auto;
}

.servicios__informacion--titulo{
    font-family: var(--fuentePrincipal);
    font-weight: 700;
    color: var(--cloud);
    text-transform: capitalize;
    position: relative;
    text-align: center;
    margin: 0;
}

.servicios__informacion--subtitulo{
    margin: 0 auto;
    margin-top: 2rem;
    margin-bottom: 4.5rem;
    font-size: 2rem;
    font-style: italic;
    text-align: center;
    line-height: 1.6;
    font-family: var(--fuenteSecundaria);
    font-weight: 400;
}

.servicios__informacion--parrafo{
    margin-top: 2rem;
    text-align: justify;
    font-size: 1.5rem;
    line-height: 1.8;
}

.servicios__informacion--foto{
    color: var(--Borgoña);
}

.servicios__informacion--flores{
    color: var(--amarillo);
}

.servicios__informacion--bn{
    font-weight: 800;
    text-transform: uppercase;
}

.servicios__informacion--foto,
.servicios__informacion--flores{
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.7rem;
}

.btn-servicios{
    margin-top: 2rem;
}

@media (max-width: 767px) { 
    .servicios{
        display: grid;
        justify-content: center;
        grid-template-columns: 50% 50%;
        gap: 3rem;
    }

    .servicios__imagenes{
        margin-top: 2rem;
        grid-row: 2/3;
        grid-column: 1/3;
    }
    
    .servicios__informacion{
        margin-top: 2rem;
        grid-column: 1/3;
        grid-row: 1/2;
    }  

    .servicios__imagenes{
        display: flex;
        width: 100%;
        gap: 1.5rem;
    }

    .servicios__imagenes--foto{
        width: 28rem;
        height: 47rem;
        overflow: hidden;
    }

    .servicios__imagenes--foto img{
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: all 600ms;
    }

    .servicios__imagenes--foto:hover img{
        transform: scale(1.2);
    }

    .servicios__imagenes--foto:last-child{
        margin-top: 10rem;
    }

    
}

/** Testimonios **/

.testimonio{
    background-color: #fff;
    margin: 0; /* Elimina márgenes */
    padding: 5rem 2rem; /* Agrega espacio interior */
    padding-top: 0;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    text-align: center;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.testimonio__lista{
    display: flex;
    flex-wrap: wrap;
    gap: 2rem;
}


.testimonio__titulo h3{
    color: #1B1B1B;
    text-align: center;
    font-family: var(--fuentePrincipal);
    margin-bottom: 2rem;
}

.testimonio__titulo p{
    color: #1B1B1B;
    font-size: 2.2rem;
    font-weight: 400;
    text-align: center;
    margin-bottom: 4rem;
}


.testimonio__lista--box{
    background-color: #fff;
    border: .1rem solid #ddd;
    border-radius: 1rem;
    box-shadow: 0 .4rem .6rem rgba(0, 0, 0, .3);
    padding: 2rem;  
    width: 100%;
    text-align: left;
    transition: background-color .7s ease, color 0.7s ease;
    
}

.testimonio__lista--box:hover{
    background-color: #1B1B1B;
    border: .1rem solid #ddd;
    border-radius: 1rem;
    box-shadow: 0 .4rem .6rem rgba(139, 0, 0, 0.5);
    padding: 2rem;  
    width: 100%;
    text-align: left; 
    transform: translateY(-1rem);
    transition: all ease .3s;
}

.testimonio__lista--box:hover h3,
.testimonio__lista--box:hover p {
    color: white; /* Especifica que los textos de h3 y p se cambien a blanco */
}


.testimonio__lista--box h3{
    font-size: 2.5rem;
    color: var(--Borgoña);
    margin-top: 1.5rem;
    margin-bottom: 1rem;
}


.testimonio__lista--box  p{
    font-size: 2rem;
    color: #555;
    line-height: 1.5;
}

.testimonio__lista--rating{
    color: var(--amarillo);
    margin-top: 1rem;
}

.testimonio__lista--box{
    display: grid;
    grid-template-rows: 80% 20%;
}


@media (min-width: 768px) { 
    .testimonio__lista{
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 2rem;
    }

    .testimonio__lista--box:last-child{
        grid-column: 1/2;
        grid-row: 2/3;
    }
    
    .testimonio__lista--box:nth-child(4){
        grid-row: 3/4;
        grid-column: 2/4;
    }    
    
}

@media (min-width: 768px) and (max-width: 868px) {
    .testimonio__lista {
        display: grid;
        grid-template-columns: repeat(2, 1fr); /* Cambiar a 2 columnas */
        gap: 2rem;
    }

    .testimonio__lista--box:last-child {
        grid-column: auto; /* Restablece la posición para evitar conflictos */
        grid-row: auto;
    }

    .testimonio__lista--box:nth-child(4) {
        grid-column: auto; /* Asegura que ocupe espacio como los demás */
        grid-row: auto;
    }
}


/** Contacto **/

.contacto{
    background-color: #2A2A2A;
    margin: 0; /* Elimina márgenes */
    padding: 5rem 2rem; /* Agrega espacio interior */
    padding-top: 0;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    padding-top: 5rem;
    text-align: center;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.contenedor__contacto{
    max-width: 85rem;
    width: 100%;
    margin: 0 auto;
}

/** Contáctanos **/

.contactar{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3rem;
}


@media (min-width: 768px) { 
    .contactar{
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 4rem;
        align-items: baseline;
    }
}

.contactar__info > h3{
    color: var(--cloud);
    font-family: var(--fuentePrincipal);
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.4rem;
    margin-bottom: 2rem;
}

.contactar__info div{
    color: var(--cloud);
    display: flex;
    align-items: center;
    margin-bottom: .5rem;

}

.contactar__info i{
    font-size: 1.6rem;
    margin-right: 1.8rem;
}

.contactar__info a{
    color: var(--cloud);
    font-size: 1.1rem;
    cursor: pointer;
}

.contactar__info p,
.contactar__info a{
    margin: 0;
    font-size: 1.1rem;
    font-weight: 400;
    text-transform: uppercase;
    text-decoration: none;
}

/** menu **/
    
.contactar__menu div{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.contactar__menu h3{
    color: var(--cloud);
    text-transform: uppercase;
    margin-bottom: 2rem;
    font-size: 1.4rem;
    font-weight: 700;
    font-family: var(--fuentePrincipal);
}

.contactar__menu--enlaces{
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

.contactar__menu--enlaces a{
    text-decoration: none;
    color: var(--cloud);
    text-transform: uppercase;
    font-size: 1.1rem;
    font-weight: 400;
    transition: color .3s ease;
}

.contactar__menu--enlaces a.active{
    color: #555;
    text-decoration: underline;
}

.contactar__menu--enlaces a:hover{
    text-decoration: underline;
}

/** redes **/

.contactar__redes > h3{
    color: var(--cloud);
    margin-bottom: 2rem;
    font-size: 1.4rem;
    font-family: var(--fuentePrincipal);
    font-weight: 700;
    text-transform: uppercase;
}

.contactar__redes--enlaces{
    display: flex;
    justify-content: center;
    gap: 2rem;
}

.contactar__redes--enlaces a img{
    width: 2rem;
    height: 2rem;
    filter: brightness(0) invert(1);
    transition: transform .3s ease, filter .3s ease ;
}

.contactar__redes--enlaces a img:hover{
    transform: scale(2.1);
}

/** Footer **/

.footer{
    background-color: #1B1B1B;
    margin: 0;
    text-align: center;
    padding: 1rem;
}

.footer__copy{
    color: var(--cloud);
    font-weight: 400;
    font-size: 1rem;
}


/** Pagina de Quienes Somos **/

.historia {
    position: relative;
    padding: 5rem 2rem 0 2rem;
    transition: background-color 0.3s ease;
    text-align: center;
}


.historia__titulo {
    background-color: var(--blanco);
    margin: 0; /* Elimina márgenes */
    padding: 2rem 2rem; /* Agrega espacio interior */
    padding-bottom: 20rem;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    text-align: center;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.historia__titulo > h3{
    font-family: var(--fuentePrincipal);
    margin-bottom: 0;
    font-size: 4rem;
}

.historia__titulo > p{
    font-family: var(--fuenteSecundaria);
    margin-top: 0;
    font-weight: 400;
    font-size: 1.6rem;
}

.historia__fondo {
    background-image: 
        linear-gradient(to bottom, white 0%, transparent 70%), /* Gradiente que va de blanco a transparente */
        linear-gradient(to top, #1B1B1B 0%, rgba(27, 27, 27, 0) 30%),
        url(img/prueba1.JPG); /* Fondo de la imagen */
    background-size: cover;
    background-position: center;
    margin: 0;
    padding: 0 2rem;
    width: 100vw;
    position: relative;
    height: 60rem;
    text-align: center;
    left: calc(-50vw + 50%);
    background-repeat: no-repeat;
    transition: background 1s ease;
}

.contenido-historia{
    background-color: var(--negro);
    color: var(--blanco);
    margin: 0; /* Elimina márgenes */
    padding: 2rem 2rem; /* Agrega espacio interior */
    padding-bottom: 10rem;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.border{
    border-bottom: .1rem solid var(--cloud); /* Línea blanca */
}
.historia__contenido{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
    margin-top: 8rem;
   
}

.historia__contenido--imagen > img{
    width: 100%; /* Imagen ocupa todo el contenedor por defecto */
    height: auto;
}

.historia__contenido--parrafo{
    text-align: justify;
    margin-left: 1.5rem;
    margin-right: 1.5rem;
}

.historia__contenido--parrafo p:first-of-type{
    margin-top: 0;
}

@media (min-width: 1440px) { 
    .historia__contenido--imagen img {
        width: 80%; /* Reduce la imagen al 80% del contenedor */
        margin: 0 auto; /* Centra horizontalmente */
    }
}

@media (max-width: 922px) { 
    .historia__contenido{
        display: flex;
        flex-direction: column;
    }

    .historia__contenido--imagen img {
        width: 60%; /* Reduce la imagen al 80% del contenedor */
        margin: 0 auto; /* Centra horizontalmente */
    }

    .btn-nosotros{
        margin: 4rem 0;
        text-align: center;
    }
}

.contenedor--historia__titulo{
    background-color: var(--negro);
    color: var(--blanco);
    margin: 0; /* Elimina márgenes */
    padding: 2rem 2rem; /* Agrega espacio interior */
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
    margin-bottom: 3rem;
}

.historia__titulo-parrafo p{
    margin: 2.5rem;
    font-size: 2.6rem;
    text-align: center;
    line-height: 1.8;
    font-style: italic;
}

.historia__second{
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.5rem;
    margin-left: 4rem;
    margin-right: 4rem;
}

.historia__second--column {
    display: grid;
    grid-auto-rows: 1fr; /* Asegura que las filas tengan la misma altura proporcional */
    gap: 1.5rem; /* Separación entre filas */
}

.historia__second--column1 {
    grid-template-rows: 40% 40% 20%; /* Proporciones específicas */
}

.historia__second--column2 {
    grid-template-rows: 30% 30% 40%; /* Cambiar el orden de las proporciones */
}

.historia__second--column3 {
    grid-template-rows: 35% 30% 35%; /* Otro orden distinto */
}

.historia__second--column4 {
    grid-template-rows: 20% 30% 50%; /* Otro orden distinto */
}

.historia__second--grid {
    overflow: hidden;
}

.historia__second--grid img {
    width: 100%; /* Asegura que las imágenes ocupen todo el espacio */
    height: 100%; /* Asegura que las imágenes se ajusten al tamaño definido */
    object-fit: cover; /* Recorta la imagen para llenar el espacio */
    border-radius: 1rem; /* Opcional: bordes redondeados para estética */
    filter: grayscale(100%); /* Aplica el blanco y negro */
    transition: transform 0.3s ease, filter 0.3s ease; /* Transición suave para zoom y color */
}

.historia__second--grid img:hover,
.historia__second--grid img:active {
    filter: grayscale(0%); /* Regresa la imagen a color */
    transform: scale(1.1) translateY(-10px);
    animation: bounce 0.5s ease;
}

@keyframes bounce {
    0%, 100% {
        transform: translateY(-10px);
    }
    50% {
        transform: translateY(-15px);
    }
}

.historia__third{
    margin: 7rem;
    display: grid;
    grid-template-columns: 30% 70%;
    gap: 2rem;
}

.historia__third--titulo h3{
    text-align: left;
    font-size: 1.9rem;
    font-family: var(--fuentePrincipal);
    font-weight: 800;
    line-height: 1.5;
}

.historia__third--parrafo > p{
    font-weight: 400;
    text-align: justify;
    font-size: 1.4rem;

}

.historia__fourth{
    margin-bottom: 6rem;
}

.historia__fourth--contenido{
    margin: 3rem 0rem;
    display: grid;
    grid-template-columns: 30% 70%;
    gap: 2rem;
}

.historia__fourth--imagen img{
    border-radius: 1rem;
}

.historia__fifth--imagen img{
    border-radius: 1rem;
}

@media (min-width: 1350px) { 
    .historia__fourth--contenido{
        margin: 3rem 14rem;
    }

    .historia__fourth--imagen img{
        max-width: 120rem;
    }

    .historia__fifth--imagen img{
        width: 120rem;
    }
}
.valores{
    background-color: var(--blanco);
    color: var(--negro);
    margin: 0; /* Elimina márgenes */
    padding: 2rem 2rem; /* Agrega espacio interior */
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */

}

.historia__intro{
    display: grid;
    grid-template-columns: 50% 50%;
    place-items: center;
    margin-inline: 1.5rem;
    padding-block: 5rem;
    margin-bottom: 3rem;
}

.historia__intro--card{
    display: grid;
    gap: 3.5rem;
}

.historia__intro--image{
    position: relative;
    overflow: hidden;
}

.historia__intro--image img{
    width: 32.8rem;
    border-radius: 1.5rem;
}

.historia__intro--data{
    width: 28rem;
    background-color: var(--negro);
    padding: 1.5rem 2rem;
    box-shadow: 0 .8rem 2.4rem hsla(0%, 0%, 0%, .15);
    border-radius: 1rem;
    position: absolute;
    bottom: -2rem;
    left: 0;
    right: 0;
    margin-inline: auto;
    opacity: 0;
    transition: opacity 1s 1s;
}

.historia__intro--data h3{
    display: block;
    font-size: 2rem;
    margin-bottom: .25rem;
    color: var(--blanco);
}

.historia__intro--data p{
    font-size: 1.5rem;
    font-weight: 400;
    text-align: justify;
    margin-bottom: .75rem;
    color: var(--blanco);
}

.historia__intro--image:hover .historia__intro--data{
    animation: show-data 1s forwards;
    opacity: 1;
    transition: opacity .3s;
}

.historia__intro--image:hover{
    animation: remove-overflow 2s forwards;
}

.historia__intro--image:not(:hover){
    animation: show-overflow 2s forwards;
}

.historia__intro--image:not(:hover) .historia__intro--data{
    animation: remove-data 1s forwards;
}

@keyframes show-data {
    50%{
        transform: translateY(-10rem);
    }
    100%{
        transform: translateY(-7rem);
    }
}

@keyframes remove-overflow {
    to{
        overflow: initial;
    }
}

@keyframes remove-data {
    0%{
        transform: translateY(-7rem);
    }
    50%{
        transform: translateY(-10rem);
    }
    100%{
        transform: translateY(.5rem);
    }
}

@keyframes show-overflow {
    0%{
        overflow: initial;
        pointer-events: none;
    }
    50%{
        overflow: hidden;
    }
}

@media (max-width: 767px) { 
    .historia__intro--titulo h3{
        font-size: 3.4rem;
    }

    .historia__intro{
       grid-template-columns: 1fr; /* Una columna por tarjeta */
       gap: 10rem;
       padding-block: 2rem;
    }

    .historia__intro--image {
        width: 100%;
    }

    .historia__titulo-parrafo p{
        font-size: 2.2rem;
    }

    .historia__second {
        grid-template-columns: 50% 50%
    }

    .historia__second--column3,
    .historia__second--column4{
        margin-top: 2.8rem;
    }
    
}


@media (max-width: 899px) { 
    .historia__second {
        margin-left: 0;
        margin-right: 0;
    }

    .historia__third{
        display: flex;
        flex-direction: column;
        margin: 6rem 0 2rem 0;
    }
    
    .historia__third--titulo h3{
        margin-bottom: 0;
    }
    
    .historia__third--parrafo > p{
        margin-top: .6rem;
    
    }

    .historia__fourth{
        margin: 1.5rem 0;
    }
    
    .historia__fourth--contenido{
        display: flex;
        flex-direction: column;
        margin: 1.2rem 0;
    }

    .historia__fifth{
        margin: 4rem 0;
    }
}

@media (max-width: 400px) { 

    .historia__titulo-parrafo{
        margin: 0;
    }
    .historia__titulo-parrafo p{
        font-size: 2rem;
        line-height: 1.6;
        text-align: center;
        margin: 0;
    }
    .historia__third{
        margin: 5rem 0 2rem 0;
    }

    .historia__third--titulo h3{
        font-size: 1.5rem;
        margin-bottom: 0;
    }
    
    .historia__third--parrafo > p{
        font-size: 1.2rem;
        margin-top: .6rem;
    
    }

    .historia__fourth{
        margin: 2.8rem 0;
    }

    .historia__fifth{
        margin: 2.8rem 0;
    }
}


/** Historia**/
.historia__foto--titulo{
    margin-top: 3rem;
    padding: 3rem 2rem;
    margin-bottom: 5rem;
}

.historia__foto--titulo h3{
    font-size: 3.5rem;
    font-family: var(--fuentePrincipal);
    font-weight: 800;
    text-align: center;
    margin-bottom: 0;
}


.historia__foto--titulo p{
    font-size: 2rem;
    font-family: var(--fuentePrincipal);
    font-weight: 400;
    text-align: center;
    margin: 0;
}

.historia__foto--contenedor1{
    display: grid;
    grid-template-columns: 50% 50%;
    gap: 4rem;
}

.historia__foto--imagen{
    grid-column: 2/3;
}

.historia__foto--contenido{
    grid-column: 1/2;
    grid-row: 1/2;
}

.historia__foto--imagen img,
.historia__foto--imagen1 img{
    border-radius: 1rem;
}


.historia__foto--contenido p:first-child{
    margin-top: 0;
}

.historia__foto--contenido p:last-child{
    margin-bottom: 0;
}


.historia__foto--contenido1{
    max-width: 120rem;
}

.historia__foto--contenido p,
.historia__foto--contenido1 p,
.historia__foto--contenido2 p,
.historia__foto--contenido3 p,
.historia__foto--contenido4 p,
.historia__foto--contenido5 p{
    text-align: justify;
    line-height: 1.9;
    color: var(--colorTexto);
}

.historia__foto--contenido5:last-child p{
    text-align: center;
}

.historia__foto--contenedor2,
.historia__foto--contenedor3,
.historia__foto--contenedor4,
.historia__foto--contenedor5,
.historia__foto--contenedor6{
    margin-top: 5rem;
    display: grid;
    grid-template-rows: auto;
    gap: 2.5rem;
    text-align: center;
}

.historia__foto--contenedor6{
    margin-bottom: 4rem;
}

.historia__foto--imagen2{
    display: grid;
    grid-template-columns: 50% 50%;
    gap: 4rem;
}

.historia__foto--foto3{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 2rem;
}

.historia__foto--imagen img,
.historia__foto--imagen1 img,
.historia__foto--imagen2 img,
.historia__foto--foto3 img,
.historia__foto--imagen4 img,
.historia__foto--imagen5 img {
    width: 100%;
    object-fit: cover;
    border-radius: 1rem;
}

.historia__foto--imagen,
.historia__foto--imagen1,
.historia__foto--imagen2,
.historia__foto--foto3,
.historia__foto--imagen4,
.historia__foto--imagen5 {
    overflow: hidden;
}

.historia__foto--foto3 img {
    border-radius: 1rem;
    transition: transform 0.8s ease, box-shadow 0.8s ease;
}
  
.historia__foto--foto3 img:hover {
    animation: swing 1s ease infinite; /* Aplica la animación */
    box-shadow: 0 1rem 2rem rgba(0, 0, 0, 0.5);
}
  
@keyframes swing {
    0%, 100% {
      transform: rotate(0deg); /* Estado inicial/final */
    }
    25% {
      transform: rotate(4deg); /* Gira a la derecha */
    }
    50% {
      transform: rotate(-4deg); /* Gira a la izquierda */
    }
    75% {
      transform: rotate(2deg); /* Gira ligeramente de vuelta */
    }
}
  

.historia__foto--imagen5 img{
  border: .5rem solid var(--colorTexto); /* Marco dorado */
  border-radius: 1.5rem; /* Bordes redondeados */
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}

.historia__foto--imagen5 img:hover{
  transform: scale(0.8); /* Zoom más pronunciado */
  box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.5), 0 0 1.5rem var(--amarillo); /* Sombra + brillo */
}

.historia__foto--cont1{
    display: flex; /* Para alinear las imágenes fácilmente */
    justify-content: center;
    align-items: center;
    overflow: hidden; /* Oculta cualquier desbordamiento de las imágenes */
    
}

.historia__foto--cont1 img{
    width: 100%;
    height: 100%;
    object-fit: cover; /* Ajusta la imagen para que mantenga sus proporciones */
}

.historia__foto > .contenedor {
    padding: 2rem;
}

@media (max-width: 1307px) { 
    .historia__foto--titulo{
        margin-top: 0;
    }
    .historia__foto--contenedor1{
        display: flex;
        flex-direction: column;
        gap: 4rem;
    }

    .historia__foto--contenedor2,
    .historia__foto--contenedor3,
    .historia__foto--contenedor4,
    .historia__foto--contenedor5{
        display: flex;
        flex-direction: column-reverse;
        margin-top: 3rem;
    }

    .historia__foto--foto3{
        display: flex;
        flex-direction: column-reverse;
    }

    .historia__foto--imagen2{
        display: flex;
        flex-direction: column;
    }

    .historia__foto--contenedor6{
        margin-top: 0;
    }
}


@media (max-width: 400px) { 
    .historia__foto--titulo h3{
        font-size: 2.5rem;
    }

    .historia__foto--titulo p{
        font-size: 1.5rem;
    }
}


/** Servicios **/

.servicio{
    margin: 3rem 0;
}
  
.servicio__principal{
    display: grid;
    grid-template-columns: 50% 50%;
    position: relative; /* Necesario para el gradiente superpuesto */
}



.servicio__principal--titulo {
    padding: .2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2rem;
    color: var(--colorTexto); /* Asegúrate de que el texto sea legible */
    z-index: 2; /* Para que esté encima del gradiente si es necesario */
}

.servicio__principal--titulo h3{
    margin-top: 2rem;
    margin-bottom: 0;
    text-align: left;
}

.servicio__principal--titulo p{
    margin-top: 0;
    margin-right: 2rem;
    text-align: justify;
}

.servicio__principal--imagen {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
}


.servicio__principal--imagen img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    position: relative;
    z-index: 1;
    filter: brightness(70%); /* Para oscurecer ligeramente la imagen */
}

.servicio__principal--imagen::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 50%; /* La mitad de la imagen */
    height: 100%;
    background: linear-gradient(to left, rgba(255, 255, 255, 0), #ffffff); /* Gradiente de blanco a azul oscuro */
    z-index: 2;
    pointer-events: none;
}

@media (max-width: 620px) {
    .servicio__principal {
        grid-template-columns: 1fr; /* En pantallas de 768px y menores, usa un solo columna */
    }

    .servicio__principal--titulo {
        padding: 1rem;
    }

    .servicio__principal--titulo h3 {
        margin-top: 1rem;
    }

    .servicio__principal--titulo p {
        margin-right: 0;
    }

    .servicio__principal--imagen {
        width: 100%;
        height: auto; /* Asegura que la imagen se ajuste en pantallas más pequeñas */
    }

    .servicio__principal--imagen img {
        object-fit: contain; /* Ajusta la imagen para mantener su proporción */
        filter: brightness(70%); /* Oscurecer imagen */
    }

    .servicio__principal--imagen::after {
        width: 100%; /* Abarca toda la imagen */
        display: none; /* Elimina el gradiente superpuesto en pantallas más pequeñas */
    }
}

.servicio__item{
    margin-top: 10rem;
    margin-bottom: 0;
    padding: 0 2rem;
}

.servicio__item h3{
    text-align: center;
    font-size: 3rem;
    color: var(--negro);
    margin-bottom: 3rem;
}

.servicio__item--contenedor{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 2.5rem;
}

.servicio__item--card{
    display: grid;
    grid-template-rows: 50% 50%;
    overflow: hidden;
    background-color: var(--blanco);
    cursor: pointer;
    border-radius: 1rem;
    box-shadow: 0 .4rem .6rem rgba(0, 0, 0, .3);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.servicio__item--card:hover{
    transform: translateY(-1rem);
    border: .5px solid #555;
    box-shadow: 0 .8rem 1.2rem rgba(0, 0, 0, 0.2);
}

.servicio__item--card:last-child{
    grid-column: 2/4;
}

.servicio__item--imagen {
    overflow: hidden;
    height: 35rem;
    position: relative;
    border-top-left-radius: 1rem;
    border-top-right-radius: 1rem;
}

.servicio__item--imagen img {
    width: 100%; /* Asegura que la imagen ocupe todo el ancho del contenedor */
    height: 100%; /* Asegura que la imagen respete el alto asignado */
    object-fit: cover; /* Ajusta la imagen para que se recorte y mantenga proporciones */
    transition: transform 0.4s ease;
}

.servicio__item--card:hover .servicio__item--imagen img {
    transform: scale(0.9);
}

.servicio__item--contenido {
    padding: 1.5rem;
    text-align: center;
}

.servicio__item--contenido h3{
    margin-bottom: 0.5rem;
    font-size: 2rem;
    color: var(--Borgoña);
}

.servicio__item--contenido p{
    margin-top: 1rem;
    text-align: justify;
    font-size: 1.4rem;
    color: #555;
}

.servicio__item--card:hover .servicio__item--contenido h3 {
    color: var(--amarillo); /* Amarillo dorado */
    transition: color 0.3s ease;
}

.servicio__item--card {
    animation: fadeInUp 0.6s ease both;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


@media (max-width: 1200px) {
    .servicio__item--contenedor {
        grid-template-columns: repeat(2, 1fr); /* Dos columnas */
    }

    .servicio__item--card:last-child {
        grid-column: span 2; /* Última tarjeta ocupa todo el ancho */
    }
}

@media (max-width: 600px) {
    .servicio__item--contenedor {
        grid-template-columns: 1fr; /* Una columna */
    }

    .servicio__item--card:last-child {
        grid-column: span 1; /* Última tarjeta también se alinea a una columna */
    }
}

.servicios__carousel{
    margin-top: 10rem;
}

.servicios__wrapper{
    display: grid;
    grid-template-columns: repeat(3,1fr);
    text-align: center;
    gap: 4rem;
}

.servicios__wrapper--card {
    width: auto;
    height: 360px;
    padding: 2rem 1rem;
    margin: auto;
    background: #fff;
    position: relative;
    display: flex;
    flex-direction: column; /* Cambiar dirección a columna */
    align-items: center; /* Centrar en el eje horizontal */
    justify-content: flex-end; /* Alinear contenido hacia abajo */
    box-shadow: 0px 7px 10px rgba(0, 0, 0, 0.5);
    transition: .5s ease-in-out;
}

.servicios__wrapper--card:last-child{
    grid-column: 2/4;
}

.servicios__card--info h3{
    font-size: 2.2rem;
    text-align: left;
}

.servicios__card--info p{
    font-size: 1.6rem;
    text-align: left;
}

.servicios__wrapper--card:hover{
    transform: translateY(20px);
}

.servicios__wrapper--card::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: linear-gradient(to bottom, rgba(139, 0, 0, 0.5), rgba(243, 156, 18, 1)); /* Borgoña y amarillo */
    z-index: 2;
    transition: 0.5s all;
    opacity: 0;
}

.servicios__wrapper--card:hover:before{
    opacity: 1;
}

.servicios__wrapper--card img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}

.servicios__wrapper--card .servicios__card--info{
    position: relative;
    z-index: 3;
    color: #fff;
    opacity: 0;
    transform: translateY(30px);
    transition: 0.5s all;
}

.servicios__wrapper--card:hover .servicios__card--info{
    opacity: 1;
    transform: translateY(0px);
}

.servicios__wrapper--card .servicios__card--info h3{
    margin: 0;
}

.servicios__wrapper--card .servicios__card--info p{
    letter-spacing: 1px;
    font-size: 1.5rem;
    margin-top: .8rem;
    margin-bottom: 2rem;
}

.servicios__wrapper--card:hover {
    box-shadow: 0px 15px 20px rgba(0, 0, 0, 0.7);
}



@media (max-width: 768px) { 
    .servicios__wrapper{
        grid-template-columns: repeat(2,1fr);
    }

    .servicios__wrapper--card:last-child{
        grid-column: span 2; /* Última tarjeta ocupa todo el ancho */
    }
}

@media (max-width: 400px) { 
    .servicios__wrapper{
        grid-template-columns: 1fr;
    }

    .servicios__wrapper--card:last-child{
        grid-column: span 1; /* Última tarjeta ocupa todo el ancho */
    }

    .servicios__wrapper--card:last-child img{
        object-position: right;
    }
}


.servicio__features {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    padding: 2rem;
    background-color: var(--blanco);
    color: #333;
    text-align: center;
    margin: 0; /* Elimina márgenes */
    margin-top: 8rem;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.servicio__features--contenedor {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1.5rem;
    background: var(--blanco);
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.servicio__features--contenedor:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.15);
}

.material-icons {
    font-size: 48px;
    color: var(--amarillo); /* Borgoña oscuro */
    margin-bottom: 1rem;
}

.servicio__features--title{
    font-size: 1.5rem;
    font-weight: bold;
    color: var(--Borgoña);
    margin-bottom: 0.5rem;
}

.servicio__features--description {
    font-size: 1rem;
    color: #555;
    line-height: 1.5;
}

@media (max-width: 768px) {
    .servicio__features {
        grid-template-columns: 1fr;
    }
}


/** Portafolio **/

.portafolio__titulo {
    padding: 2rem;
    margin-top: 6rem;
    border-radius: 8px; /* Bordes redondeados para suavizar las esquinas */
    margin-bottom: 0; /* Espacio entre secciones */
}

.portafolio__titulo h3{
    font-size: 3rem;
    font-weight: 800;
    font-family: var(--fuentePrincipal);
    text-align: center;
    color: var(--colorTexto);
    margin-bottom: 1.5rem;
}

.portafolio__titulo p {
    margin-top: 0;
    text-align: center;
    font-size: 1.5rem;
    line-height: 1.6; /* Espaciado entre líneas para mayor legibilidad */
}


.contenedor{
    width: 90%;
    max-width: 120rem;
    margin: auto;
}

.barra-busqueda{
    width: 70%;
    height: 4rem;
    line-height: 4rem;
    background: #fff;
    padding: 0 2rem;
    border-radius: 10rem;
    text-align: center;
    font-size: 1.6rem;
}

.contenedor .form{
    width: 100%;
    display: flex;
    justify-content: center;
    margin-bottom: 2rem;

}

.categoria{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.categoria a{
    color: #9b9b9b;
    margin: 1rem 2rem;
    font-size: 1.8rem;
    font-weight: 700;
}

.categoria a.activo{
    color: var(--Borgoña);
}

.grid {
	position: relative;
    margin-bottom: 8rem;
	width: 100%;
	opacity: 0;
	transition: opacity 0.4s linear 1s;
}

.grid.imagenes-cargadas {
	opacity: 1;
}

.grid .item1 {
	position: absolute;
	display: block;
	padding: 0;
	margin: 10px;
	width: calc(33.333333% - 20px);
}

.grid .item-contenido1 {
	position: relative;
}

.grid .item1 img {
	width: 100%;
	cursor: pointer;
	vertical-align: top;
}
/* ------------------------- */
/* Overlay */
/* ------------------------- */
.overlay {
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: rgba(0,0,0,.9);
	width: 100%;
	height: 100vh;
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}

.overlay.activo {
	display: flex;
}

.overlay img {
	max-width: 40%; /* Ajusta el tamaño de la imagen */
    margin-bottom: 20px; /* Espacio entre la imagen y la descripción */
}

.overlay .descripcion {
	display: block;
	background: var(--amarillo);
	padding: 20px;
    color: var(--Borgoña);
	text-align: center;
	margin-top: 5px;
	border-radius: 10px;
	max-width: 80%;
}

.contenedor-img {
	display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    position: relative;
}

.overlay #btn-cerrar-popup {
	background: none;
	font-size: 20px;
	color: var(--Borgoña);
	border: none;
	cursor: pointer;
	position: absolute;
	right: 24.5rem;
	top: -3rem;
}

@media screen and (max-width: 700px) {
	.grid .item1 {
		width: calc(50% - 20px);
	}

	.barra-busqueda {
		width: 100%;
	}
}



/** blog **/

.blog__contenidos{
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 3rem;
}

.entrada{
    border-bottom: .1rem solid #e1e1e1;
    margin-bottom: 2.5rem;
}

.entrada__contenido{
    margin-bottom: 1rem;
}

.entrada__contenido h4{
    margin: 0;
    font-size: 2.5rem;
    line-height: 1.2;
}


.entrada:last-of-type{
    border: none;
    margin-bottom: 0;
}

.but{
    display: block;
    font-family: var(--fuenteHeading);
    color: var(--blanco);
    text-align: center;
    padding: 1rem 3rem;
    font-size: 1.8rem;
    text-transform: uppercase;
    font-weight: 700;
    margin-bottom: 2rem;
    border: none;
}

@media (min-width: 768px) { 
    .but{
        display: inline-block;
    }
}


.but:hover{
    cursor: pointer;
    background-color: var(--Borgoña);
}

.boton--primario{
    background-color: var(--amarillo);
}

.blog__contenidos--lateral{
    border-bottom: .1rem solid #e1e1e1;
    margin-bottom: 2.5rem;
}

.aside__imagen{
    margin-bottom: 1rem;
}

.blog__contenidos--lateral h4{
    margin: 0;
    margin-bottom: 2rem;
    font-size: 2.2rem;
    line-height: 1.2;
    text-align: center;
}

.blog__contenidos--lateral:nth-child(2) h4{
    margin: 0;
}

.blog__contenidos--lateral:nth-child(3) ul{
    list-style: none;
}

.blog__contenidos--lateral:nth-child(3) ul li{
    font-size: 1.6rem;
    color: #555;  /* Color gris oscuro para los ítems */
    margin-bottom: .5rem;
    line-height: 1.5;
}

.blog__contenidos--lateral:nth-child(3) ul li::before{
    content: "⏰";  /* Ícono de reloj antes de cada línea */
    margin-right: .8rem;
    color: var(--amarillo);  /* Color del ícono */
}

.blog__contenidos--lateral:nth-child(4) iframe{
    margin-bottom: 1rem;
    margin-left: 2rem;
}

.blog__contenidos--lateral:last-of-type{
    border: none;
    margin-bottom: 0;
}

@media (max-width: 768px) { 
    .blog__contenidos--lateral h4{
        font-size: 1.4rem;
    }

    .blog__contenidos--lateral:nth-child(2) p{
        font-size: 1.2rem;
    }

    .blog__contenidos--lateral:nth-child(3) ul li{
        font-size: 1rem;
        line-height: 1.2;
    }

    .blog__contenidos--lateral:last-of-type blockquote{
       font-size: 1.4rem;
    }
}

@media (max-width: 600px) { 
    .blog__contenidos{
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .blog__contenidos--lateral h4{
        font-size: 2.2rem;
    }

    .blog__contenidos--lateral:nth-child(2) p{
        font-size: 1.6rem;
        text-align: center;
    }

    .blog__contenidos--lateral:nth-child(3) ul li{
        font-size: 1.8rem;
        line-height: 1.2;
    }

    .blog__contenidos--lateral:last-of-type blockquote{
       font-size: 1.8rem;
    }
}

/** Entrada 1 **/

.contenedor__entrada1,
.contenedor__entrada2,
.contenedor__entrada3,
.contenedor__entrada4{
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 3rem;
    margin-bottom: 3rem;
}

.entrada4__contenido h5{
    font-size: 2.1rem;
}

.entrada4__contenido--enlace{
    color: var(--Borgoña);
    text-transform: uppercase;
    font-weight: 800;
}

.entrada1__contenido p,
.entrada2__contenido p,
.entrada3__contenido p,
.entrada4__contenido p{
    text-align: justify;
}

/* Estilo del título h3 */
.contenedor__entrada1--aside aside h3,
.contenedor__entrada2--aside aside h3,
.contenedor__entrada3--aside aside h3,
.contenedor__entrada4--aside aside h3 {
    font-size: 3rem;
    color: #333; /* Color oscuro para el título */
    margin-bottom: 1.5rem; /* Espaciado debajo del título */
    font-weight: bold; /* Acentúa el peso del texto */
}

/* Estilo de la lista */
.contenedor__entrada1--aside aside ul,
.contenedor__entrada2--aside aside ul,
.contenedor__entrada3--aside aside ul,
.contenedor__entrada4--aside aside ul {
    list-style-type: none; /* Elimina las viñetas predeterminadas */
    padding: 0; /* Elimina el relleno */
    margin: 0; /* Elimina el margen */
}

/* Estilo de cada ítem de la lista */
.contenedor__entrada1--aside aside ul li,
.contenedor__entrada2--aside aside ul li,
.contenedor__entrada3--aside aside ul li,
.contenedor__entrada4--aside aside ul li {
    margin-bottom: 1rem; /* Espaciado entre los elementos */
    font-size: 2.2rem; /* Tamaño de fuente adecuado */
    line-height: 1.5; /* Altura de línea para mejorar la legibilidad */
}

/* Estilo de los enlaces */
.contenedor__entrada1--aside aside ul li a,
.contenedor__entrada2--aside aside ul li a,
.contenedor__entrada3--aside aside ul li a,
.contenedor__entrada4--aside aside ul li a {
    color: #007bff; /* Color azul para los enlaces */
    text-decoration: none; /* Eliminar subrayado */
    font-weight: 500; /* Peso medio para el enlace */
    transition: color 0.3s ease; /* Transición suave para el color */
}

/* Efecto de hover en los enlaces */
.contenedor__entrada1--aside aside ul li a:hover,
.contenedor__entrada2--aside aside ul li a:hover,
.contenedor__entrada3--aside aside ul li a:hover,
.contenedor__entrada4--aside aside ul li a:hover {
    color: #0056b3; /* Cambio de color cuando se pasa el mouse */
    text-decoration: underline; /* Subrayado cuando se pasa el mouse */
}

.entrada2__contenido--parrafos ul{
    list-style-type: none; /* Elimina las viñetas predeterminadas */
    padding: 0; /* Elimina el relleno */
    margin: 0; /* Elimina el margen */
    margin-bottom: 4rem;
}

.entrada2__contenido--parrafos ul li{
    margin-bottom: 1rem; /* Espaciado entre los elementos */
    text-align: justify;
}

.entrada2__contenido--image{
    display: grid;
    grid-template-columns: 50% 50%;
    gap: 2rem;
}

@media (max-width: 768px) { 
    .entrada1 h3,
    .entrada2 h3,
    .entrada3 h3,
    .entrada4 h3{
        font-size: 2.6rem;
    }

    .entrada1__contenido h4,
    .entrada2__contenido h4,
    .entrada3__contenido h4,
    .entrada4__contenido h4{
        font-size: 2.6rem;
    }

    .contenedor__entrada1--aside aside h3,
    .contenedor__entrada2--aside aside h3,
    .contenedor__entrada3--aside aside h3,
    .contenedor__entrada4--aside aside h3 {
        font-size: 2.6rem;
        text-align: center;
    }

    .contenedor__entrada1--aside aside ul li,
    .contenedor__entrada2--aside aside ul li,
    .contenedor__entrada3--aside aside ul li,
    .contenedor__entrada4--aside aside ul li {
        font-size: 1.8rem; /* Tamaño de fuente adecuado */
    }
}

@media (max-width: 600px) { 
    .contenedor__entrada1,
    .contenedor__entrada2,
    .contenedor__entrada3,
    .contenedor__entrada4{
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .entrada2__contenido h4{
        font-size: 2rem;
    }

    .contenedor__entrada1--aside aside ul li,
    .contenedor__entrada2--aside aside ul li,
    .contenedor__entrada3--aside aside ul li,
    .contenedor__entrada4--aside aside ul li  {
        font-size: 1.8rem; /* Tamaño de fuente adecuado */
        text-align: justify;
    }

    .entrada2__contenido--image{
        grid-template-columns: 1fr;
        gap: 2rem;
    }
}









/** Contacto **/

.header__contacto{
    margin: 0;
}

.formulario{
    background-color: var(--cloud);
    margin: 0; /* Elimina márgenes */
    padding: 5rem 2rem; /* Agrega espacio interior */
    padding-top: 0;
    width: 100vw; /* Extiende el fondo al ancho completo */
    position: relative;
    padding-top: 5rem;
    text-align: center;
    left: calc(-50vw + 50%); /* Centra la sección respecto al viewport */
}

.formulario__titulo{
    margin-bottom: 4.5rem;
} 

.formulario__titulo > h2{
    text-align: center;
    font-family: var(--fuentePrincipal);
    font-weight: 700;
    margin-bottom: 0;
    font-size: 3.5rem;
}

.formulario__titulo > p{
    text-align: center;
    margin-top: 0;
    font-family: var(--fuentePrincipal);
    font-weight: 400;
    font-size: 1.5rem;
}

.formulario__imagen{
    background-image: url(img/contacto3.JPG);
    height: 40rem;
    background-size: cover;
    background-repeat: no-repeat;
}

.formulario__contenido--contacto{
    background-color: var(--blanco);
    width: 95%;
    border: .5rem solid var(--negro);
    border-radius: 1rem;
    padding: 5rem;
    margin: -7rem auto 0 auto;
    display: grid;
    grid-template-columns: 25% 25% 50%;
    column-gap: 2rem;
    row-gap: 1rem;
}


@media (min-width: 890px) and (max-width: 1140px) { 
    .formulario__contenido--contacto{
        display: grid;
        grid-template-columns: 1fr 1fr;
        padding: 2rem;
        margin: -4rem auto 0 auto;
    }
}

.campo__field{
    width: 100%;
    background-color: rgba(131, 149, 167,.2);
    border: none;
    outline: none;
    padding: 1.5rem 1.35rem calc(0.75rem - 2px) 1.35rem;
    font-family: var(--fuentePrincipal);
    border-radius: 1.5rem;
    font-weight: 600;
    color: var(--negro);
    font-size: 1.15rem;
    border: .2rem solid transparent;
    box-shadow: 0 0 0 0 rgba(131, 149, 167,.4);
    transition: .3s;

}

.campo{
    position: relative;
}

.campo__field:hover{
    background-color: rgba(131, 149, 167,.4);
}

.campo__label{
    position: absolute;
    top: 50%;
    left: calc(1.35rem + 2px);
    transform: translateY(-50%);
    color: #555;
    pointer-events: none;
    transition: .25s;

}

.campo__icon{
    position: absolute;
    right: calc(1.35rem + 2px);
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: #555;
    font-size: 1.25rem;
    transition: .3s;
}

.campo__label--textarea{
    resize: none;
    width: 100%;
    min-height: 15rem;
}

.campo__label--textarea ~ label{
    top: 1.2rem;
    transform: none;
}

.campo__label--textarea ~ i{
    top: 1.3rem;
    transform: none;
}

.campo:nth-child(3){
    grid-row: 2/3;
    grid-column: 1/3;
}


.campo:nth-child(4){
    grid-row: 3/4;
    grid-column: 1/3;
}

.campo.focus .campo__field{
    background-color: var(--blanco);
    border: .1rem solid rgba(131, 149, 167,.4);
    box-shadow: 0 0 0 .15rem rgba(131, 149, 167,.4);
}

.campo.focus label{
    color: rgba(53, 59, 72,.6);
}


.campo.focus i{
    color: rgba(53, 59, 72,.6);
}

.campo.not-empty label{
    font-size: .66rem;
    top: 0.75rem;
    transform: translateY(0);
}

.campo:nth-child(5){
    grid-row: 4/5;
}


.campo__button{
    display: grid;
    grid-template-columns: 50% 50%;
    column-gap: 1rem;
    margin-top: 1rem;
    width: 100%;
    grid-column: span 2;
}

.campo__button--input,
.campo__button--upload{
    display: inline-block;
    padding: 1.1rem 2rem;
    background-color: var(--mainBlue);
    color: var(--blanco);
    border-radius: 4rem;
    border: none;
    font-family: var(--fuentePrincipal);
    font-weight: 500;
    font-size: 1rem;
    cursor: pointer;
    transition: .3s;
}

.bttn:hover{
    background-color: #555;
}
.bttn.upload{
    position: relative;
    background-color: #2A2A2A;
}

.bttn.upload span{
    color: var(--blanco);
}

.bttn.upload:hover{
    background-color: #555;
}

.bttn.upload input{
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    cursor: pointer;
    opacity: 0;
}

.campo__mapa{
    grid-column: span 3;
    justify-content: center;
    align-items: center;
}

.campo:nth-child(6){
    grid-column: 3/4;
    grid-row: 1/5;
}

@media (max-width: 890px) {

    .formulario__titulo {
        margin-bottom: 3.5rem;
    }

    .formulario__titulo > h2{
        font-size: 2.2rem;
        white-space: normal;
    }

    .formulario__titulo > p{
        font-size: 1.1rem;
        white-space: normal;
    }

    .formulario__contenido--contacto {
        display: grid;
        grid-template-columns: 50% 50%;
        padding: 3.5rem;
        margin: -7rem auto 0 auto;
        column-gap: .8rem;
        row-gap: .65rem;
    }

    .campo__label{
        font-size: .91rem;
        left: calc(1.2rem + 2px);
    }

    .campo__icon{
        font-size: 1.1rem;
        right: calc(1.2rem + 2px);
    }

    .campo__label--textarea ~ label{
        top: 1.2rem;
    }

    .campo__label--textarea ~ i{
        top: 1.3rem;
    }

    .campo.focus .campo__field{
        box-shadow: 0 0 0 3.5px rgba(131, 149, 167,.4);
    }

    .campo.not-empty label{
        font-size: .61rem;
    }

    .campo__button{
        column-gap: .8rem;
        margin-top: .45rem;
    }

    .bttn{
        padding: 1rem 1.5rem;
        font-size: .87rem;
    }

    .campo:nth-child(6){
        margin-top: 3rem;
        grid-column: 1/4;
        grid-row: 5/6;
    }
    
    
}

@media (max-width: 490px) { 
    .formulario{
        padding-top: 3rem;
    }
    .formulario__titulo > h2{
        font-size: 1.8rem;
        text-align: justify;
        white-space: normal;
    }

    .formulario__titulo > p{
        margin-top: .8rem;
        font-size: 1rem;
        text-align: justify;
        white-space: normal;
    }

    .formulario__contenido--contacto {
        margin: -8rem auto 0 auto;
    }

}