* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: Arial, sans-serif;
}

.top-bar {
    background-color: #003366;
    height: 18px;
    width: 100%;
    clip-path: polygon(-10% 0, 100% 0, 98% 100%, -10% 100%);
}

.navbar {
    background-color: #ffffff;
    color: white;
    padding: 1.9em;
    display: flex;
    align-items: center;
    box-shadow: 0 6px 6px rgba(0, 0, 0, 0.3);
    margin-top: 5px;
}

.navbar .logo img {
    height: 80px;
    margin-left: 200px;
    margin-top: 2px;
}

.nav-links {
    list-style: none;
    display: flex;
    flex-grow: 1;
    justify-content: center;
    margin-top: 0;
}

.nav-links li {
    margin-left: 1.5em;
}

.nav-links a {
    color: rgb(129, 129, 129);
    text-decoration: none;
    font-size: 1.2em;
    font-weight: bolder;
    letter-spacing: 0.05em;
    transition: color 0.3s ease, background-color 0.3s ease;
    padding: 0.5em;
    border-radius: 4px;
}

.nav-links a:hover,
.nav-links a.selected {
    color: #003366;
}

.content {
    padding: 2em;
    text-align: center;
}

.about-section {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 2em;
}

.about-image {
    width: 40%;
    margin-left: 40px;
}

.about-text {
    width: 50%;
    /* Reducido de 55% a 50% */
    text-align: left;
    margin-left: 5%;
    font-size: 1.2em;
    /* Aumentado el tamaño de la letra */
    margin-right: 60px;
}

.about-section {
    padding-left: 2em;
    /* Añadido para crear margen a los extremos */
    padding-right: 2em;
    /* Añadido para crear margen a los extremos */
}

.about-text,
.about-image {
    margin-bottom: 1em;
    /* Añadido para crear espacio entre la imagen y el texto */
}

.about-text p {
    font-size: 20px;
    text-align: justify;
}


.mission-vision-section {
    display: flex;
    justify-content: space-between;
    margin-bottom: 2em;
    padding-left: 300px;
    padding-right: 300px;
    margin-bottom: 70px;
}

.box {
    background-color: #f1f1f1;
    color: rgb(0, 0, 0);
    padding: 1em;
    width: 45%;
    /* Reducido de 48% a 45% */
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    border-top: 8px solid #003366;
    /* Borde azul solo en la parte superior */
}

.box h2 {
    margin-bottom: 20px;
}

.box p {
    text-align: justify;
}

.values-section {
    text-align: center;
    margin-bottom: 2em;
    padding-left: 300px;
    padding-right: 300px;
}

.title-container {
    position: relative;
    text-align: center;
    margin: 2em 0;
    /* Ajusta el espacio según sea necesario */
}

.title-container::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 50%;
    height: 2px;
    /* Grosor de la línea */
    background-color: #003366;
    /* Color azul de la línea */
    z-index: 0;
}

.title-container h2 {
    position: relative;
    display: inline-block;
    background: #fff;
    /* Fondo blanco para el título */
    padding: 0 1em;
    /* Espacio alrededor del título */
    z-index: 1;
    /* Asegura que el texto esté sobre la línea */
    color: #003366;
    font-size: 35px;
}

.values {
    display: flex;
    justify-content: space-between;
    margin-top: 1em;
    gap: 10px;
    /* Añadido para reducir el espacio entre los valores */
}

.value {
    text-align: center;
    width: 18%;
}

.value img {
    width: 50px;
    height: 50px;
    margin-bottom: 10px;
    /* Añadido para crear espacio entre el icono y el texto */
}

.value p {
    font-size: 1.2em;
    /* Aumentado el tamaño de la letra */
    font-weight: bold;
}

.stars {
    font-size: 3.5em;
    color: gold;
    margin-bottom: 20px;
    margin-top: 30px;
}

.review-boxes {
    display: flex;
    justify-content: space-between;
    margin-left: 300px;
    margin-right: 300px;
    margin-bottom: 30px;
    gap: 30px;
}

.review-box {
    background-color: #f0f0f0;
    padding: 1em;
    width: 45%;
    /* Reducido de 48% a 45% */
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    font-style: italic;
}


footer {
    background-color: #003366;
    /* Azul oscuro para el fondo del footer */
    color: white;
    /* Texto blanco */
    padding: 1em 0;
    /* Espacio alrededor del contenido */
    text-align: center;
    /* Centra el texto */
    position: relative;
    /* Posición relativa para el contenido del footer */
    bottom: 0;
    /* Asegura que el footer esté en la parte inferior */
    width: 100%;
    /* Asegura que el footer ocupe todo el ancho */
    padding-top: 50px;
    padding-bottom: 20px;
}

.footer-content {
    display: flex;
    flex-direction: column;
    /* Disposición vertical de los elementos */
    align-items: center;
    /* Centra los elementos horizontalmente */
}

.footer-text {
    margin-top: -20px;
    margin-bottom: 10px;
    /* Espacio debajo del texto */
    font-size: 1.4em
}

.footer-social {
    display: flex;
    flex-direction: column;
    /* Disposición vertical del ícono y el texto */
    align-items: center;
    /* Centra los elementos horizontalmente */
}

.social-link {
    display: flex;
    align-items: center;
    /* Centra verticalmente el ícono y el texto */
    color: white;
    /* Asegura que el texto sea blanco */
    text-decoration: none;
    /* Elimina el subrayado del enlace */
}

.footer-icon {
    width: 24px;
    /* Ajusta el tamaño del ícono según sea necesario */
    height: auto;
    /* Mantiene la proporción del ícono */
    margin-right: 0.5em;
    /* Espacio entre el ícono y el texto */
}

.footer-social p {
    margin: 0;
    /* Elimina los márgenes del párrafo */
}

.fixed-icons {
    position: fixed;
    /* Fija el contenedor en la esquina */
    bottom: 20px;
    /* Espacio desde el borde inferior */
    right: 20px;
    /* Espacio desde el borde derecho */
    display: flex;
    /* Alinea los íconos horizontalmente */
    flex-direction: column;
    /* Disposición vertical de los íconos */
    gap: 10px;
    /* Espacio entre los íconos */
    z-index: 1000;
    /* Asegura que los íconos estén encima de otros elementos */
}

.icon-link {
    display: flex;
    /* Centra el ícono */
    align-items: center;
    justify-content: center;
    background-color: #ffffff;
    /* Fondo blanco para los íconos */
    border-radius: 50%;
    /* Forma circular */
    padding: 10px;
    /* Espacio interno */
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
    /* Sombra para el efecto de profundidad */
}

.fixed-icon {
    width: 40px;
    /* Tamaño del ícono */
    height: auto;
    /* Mantiene la proporción del ícono */
}

.icon-link:hover {
    background-color: #f1f1f1;
    /* Color de fondo al pasar el ratón */
    transition: background-color 0.3s;
    /* Transición suave del fondo */
}


.page-title {
    margin-top: 50px;
    ;
    color: #003366;
    /* Color azul para el fondo del título */
    padding: 1em;
    /* Espacio alrededor del título */
    text-align: center;
    /* Centra el texto */
}

.page-title p {
    margin: 0;
    /* Elimina el margen predeterminado */
    font-size: 2em;
    /* Tamaño del texto */
    font-weight: 700;
}

.footer-contact {
    position: absolute;
    right: 10%;
    /* Ajusta la posición izquierda según sea necesario */
    text-align: right;
    margin-top: -30px;
}

.footer-contact .contact-item {
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
}

.footer-contact .contact-item p {
    margin: 0;
    margin-left: 0.5em;
}

.footer-contact a {
    color: white;
    /* Asegura que el texto sea blanco */
    text-decoration: none;
    /* Elimina el subrayado del enlace */
}

.contact-icon {
    width: 20px;
    /* Ajusta el tamaño del ícono */
    height: 20px;
    /* Ajusta el tamaño del ícono */
    margin-right: 0.5em;
    /* Espacio entre el ícono y el texto */
}

.navbar-mobile {
    display: none;
}

.values-section-mb {
    display: none;
}

.aliados {
    display: flex; /* Alinea las imágenes en fila */
    gap: 20px; /* Espacio entre las imágenes */
    justify-content: center; /* Centra las imágenes horizontalmente */
    align-items: center; /* Alinea las imágenes verticalmente */
    flex-wrap: wrap; /* Permite que las imágenes se muevan a una nueva fila si es necesario */
}

.aliados img {
    height: 200px; /* Altura uniforme */
    object-fit: contain; /* Mantiene proporciones */
}

/* Estilos para pantallas pequeñas (celulares) */
@media (max-width: 600px) {
    .aliados {
        flex-direction: column; /* Coloca las imágenes en columna */
        gap: 10px; /* Reduce el espacio entre las imágenes */
    }

    .aliados img {
        height: 80px; /* Reduce el tamaño de las imágenes para pantallas pequeñas */
    }
}



/*  mobile */
@media screen and (max-width: 768px) {

    .footer-contact {
        position: relative;
        margin-top: 10px;
        right: 0px;
        padding-bottom: 0px;
    }

    .footer-text {
        margin-top: 0px;
        font-size: 1.1rem;
    }

    footer {
        padding-top: 30px;
    }

    .footer-content p {
        font-size: 1.1em;
    }

    .card-container {
        margin-bottom: 0px;
        grid-template-columns: repeat(1, 1fr);
    }

    .solution-description {
        font-size: 1.2em !important;
        ;
    }

    .solution-title {
        font-size: 2.3em;
    }

    .info-box {
        position: relative;
        transform: none;
        width: 100%;
        left: 0px;
        height: auto;
    }

    .info-title {
        font-size: 1.9em;
        margin-top: 20px;
    }

    .info-box p {
        padding-top: 10px;
        padding-bottom: 15px;
    }

    .navbar {
        display: none;
    }

    .navbar-mobile {
        display: block;
    }

    .navbar-mobile {
        box-shadow: -1px -6px 18px 3px rgba(0, 0, 0, 0.52);
        -webkit-box-shadow: -1px -6px 18px 3px rgba(0, 0, 0, 0.52);
        -moz-box-shadow: -1px -6px 18px 3px rgba(0, 0, 0, 0.52);
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        padding: 10px;
        color: white;
    }

    .navbar-mobile input[type="checkbox"] {
        display: none;
    }

    .navbar-mobile label {
        display: block;
        cursor: pointer;
        padding: 10px;
        width: 45px;
        font-size: 26px;
        text-align: center;
        color: #000;
    }


    .navbar-mobile .menu-items {
        display: none;
        flex-direction: column;
        width: 100%;
    }

    .navbar-mobile input[type="checkbox"]:checked~.menu-items {
        display: flex;
    }

    .navbar-mobile .menu-item {
        padding: 10px;
        /*  background-color: #003366; */
        border-bottom: 1px solid #005599;
        width: 100%;
    }

    .navbar-mobile .menu-item a {
        color: white;
        text-decoration: none;
        color: #000;

    }

    .navbar-mobile .menu-item a:hover {
        color: #cce6ff;
    }

    .navbar-header {
        display: flex;
        align-items: center;
        width: 100%;
        flex-direction: row-reverse;
        justify-content: space-between;
    }

    .logo {
        height: 40px;
    }

    .banner-image {
        filter: blur(0px);
    }

    .about-image {
        width: 100%;
        margin-left: 0px;
        margin-bottom: 10px;
    }

    .about-section {
        flex-direction: column;
    }

    .about-text {
        width: 100%;
        text-align: left;
        margin-left: 0px;
        font-size: 1.1em;
        margin-right: 0px;
    }

    .mission-vision-section {
        flex-direction: column;
        padding-left: 0px;
        padding-right: 0px;
        margin-bottom: 20px;
        gap: 40px;
    }

    .box {
        width: 100%;
    }


    .values-section {
        text-align: center;
        margin-bottom: 2em;
        padding-left: 0px;
        padding-right: 0px;
    }

    .values-section-mb {
        display: block;
    }

    .values-section {
        display: none;
    }

    .values-mb {
        display: flex;
        justify-content: space-around;
        padding-top: 25px;
    }

    .value {
        text-align: center;
        width: 50%;
    }

    .review-boxes {
        flex-direction: column;
        margin-left: 0px;
        margin-right: 0px;
        margin-bottom: 0px;
        gap: 30px;
    }

    .review-box {
        width: 100%;
    }

    .about-text p {
        font-size: 16px;
        padding-top: 15px;
    }

}