/* Estilos generales */
body {
    font-family: 'Roboto', sans-serif;
    margin: 0;
    padding: 0;
    background-color: #f0f4f8;
    color: #333;
    background-image: url('Fotos/Fondo.jpg'); /* Imagen de fondo */
    background-size: cover; /* Asegura que la imagen cubra todo el fondo */
    background-position: center; /* Centra la imagen */
    background-attachment: fixed; /* Hace que la imagen quede fija al hacer scroll */
    position: relative;
}

/* Establecer una capa encima de la imagen de fondo */
body::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4); /* Fondo oscuro con opacidad para mejorar la legibilidad */
    z-index: -1; /* Asegura que esté debajo del contenido */
}

/* Header */
header {
    background-color: black;
    padding: 15px 0;
    text-align: center;
    box-sizing: border-box;
}

nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    justify-content: center;
}

nav ul li {
    margin: 0 10px;
}

nav ul li a {
    color: white;
    text-decoration: none;
    font-size: 1em;
    padding: 10px 15px;
    border: 2px solid transparent;
    position: relative;
    display: inline-block;
    transition: background-color 0.3s ease;
}

/* Recuadros de los botones del inicio */
nav ul li a:hover {
    color: #fa7979;
}

/* Sección 1 */
.inicio {
    position: relative;
    background-color: rgba(12, 1, 1, 0.573);
    padding: 50px 0;
    text-align: center;
}

#logo {
    /*max-width: 200px;*/
    height: 350px;
}

.logo-slogan h2 {
    margin-top: 20px;
    font-size: 2.5em;
    color: #fff;
}

/* Sección 2 */
.sobre-nosotros {
    background-color: #fa7979;
    padding: 50px 20px;
    text-align: center;
}

.sobre-nosotros .descripcion {
    margin-bottom: 40px;
    font-size: 1.5em;
    color: BLACK;
}

.mision-vision {
    display: flex;
    justify-content: center;
    gap: 20px;
}

.flip-card {
    background-color: transparent;
    width: 400px;
    height: 450px;
    perspective: 1000px;
}

.flip-card-inner {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    transition: transform 0.6s;
}

.flip-card:hover .flip-card-inner {
    transform: rotateY(180deg);
}

.flip-card-front, .flip-card-back {
    position: absolute;
    width: 100%;
    height: 100%;
    backface-visibility: hidden;
    padding: 10px;
    box-sizing: border-box;
}

.centrar{
    padding: 90px;
}

.flip-card-front {
    font-size: 2.5em;
    background-color: #bdffac;
    color: BLACK;
    display: flex;
    justify-content: center;
    align-items: center;
}

.flip-card-back {
    background-color: #F2F2F2;
    color: black;
    transform: rotateY(180deg);
    text-align: center;
}

.flip-card-back .lista {
    margin-bottom: 40px;
    font-size: 1em;
    color: black;
    text-align: left;
}

/* Sección 3 */

.productos-servicios {
    background-color: rgba(0, 0, 0, 0.4);
    position: relative;
    padding: 50px 20px;
    text-align: center;
}

.productos-servicios h2 {
    font-size: 2.2em;
    color: white;
}

.productos-servicios .productos {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    justify-content: center;
    gap: 40px;
    max-width: 1200px;
    margin: auto;
    padding: 20px;
}

.producto img {
    width: 350px;
    height: 350px;
    border-radius: 50%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.producto:hover img {
    transform: scale(1.1);
}

.producto h3 {
    margin-top: 10px;
    font-size: 1.2em;
    color: white;
}

.producto p {
    font-size: 1em;
    color: white;
}

.producto li {
    font-size: 1em;
    color: white;
}

/* Footer */
footer {
    background-color: black;
    color: #fff;
    padding: 5px 0;
    text-align: center;
}

.footer-links {
    display: flex;
    justify-content: center;
    gap: 20px;
}

footer a {
    color: #ecf0f1;
    text-decoration: none;
}

footer a:hover {
    color: #fa7979;
    transition: color 0.3s ease;
}

/* Estilos responsivos */
@media (max-width: 1024px) {
    nav ul {
         flex-direction: column; /* Cambiar la dirección del menú a vertical */
        gap: 10px; /* Espaciado entre enlaces */
    }

    .mision-vision {
        flex-direction: column; /* Misión y visión en vertical */
        gap: 20px;
    }

    .flip-card {
        width: 90%; /* Hacer que las tarjetas ocupen más ancho en pantallas pequeñas */
    }

    .producto img {
        width: 300px; /* Ajustar tamaño de las imágenes */
        height: 300px;
    }
}

@media (max-width: 768px) {
    /* Sección Inicio */
    .inicio {
        padding: 30px 10px;
    }

    .logo-slogan h2 {
        font-size: 2em; /* Reducir tamaño de texto */
    }

    #logo {
        max-width: 150px; /* Reducir tamaño del logo */
        max-height: 200px;
    }

    /* Sección 2 */
    .sobre-nosotros .descripcion {
        font-size: 1.2em; /* Ajustar tamaño de texto */
    }

    /* Productos en una sola columna */
    .productos-servicios .productos {
            grid-template-columns: 1fr;
    }

    .producto img {
        width: 250px;
        height: 250px; /* Ajustar tamaño de las imágenes */
    }

    .producto h3 {
        font-size: 1.1em;
    }

    .producto p {
        font-size: 0.9em;
    }

    /* Footer */
    footer .footer-links {
        flex-direction: column;
        gap: 10px;
    }
}

@media (max-width: 480px) {
    /* Sección Inicio */
    .inicio {
        padding: 20px 5px;
    }

    .logo-slogan h2 {
        font-size: 1.8em; /* Reducir aún más el tamaño del texto */
    }

    #logo {
        max-width: 120px; /* Reducir tamaño del logo en pantallas más pequeñas */
    }

    /* Ajustar tamaño de las tarjetas */
    .flip-card {
        width: 100%;
    }

    /* Productos más pequeños */
    .producto img {
        width: 200px;
        height: 200px;
    }

    .producto h3 {
        font-size: 1em;
    }

    .producto p {
        font-size: 0.8em;
    }

    /* Footer */
    footer .footer-links {
        gap: 5px;
    }
}

.productos > .producto:only-child,
.productos > .producto:nth-last-child(1):nth-child(odd) {
    grid-column: 1 / -1;
    justify-self: center;
}
