
/* Estilos generales */
* {
    box-sizing: border-box;
}

html, body {
    --blanco: #F0F0F0;
    --azul: #1A3C99;
    --morado: #792187;
    --celeste: #638EBF;
    --blue_f: rgba(99, 142, 191, 0.58);
    --negro_a: #0f1b3b;

    margin: 0;
    padding: 0;
    background: var(--blanco);
    overflow-x: hidden; /* Elimina el scroll horizontal */
    overflow-y: auto;   /* Permite el scroll vertical */
    font-family: "DM Sans", sans-serif;
}

header {
    display: flex;
    position: fixed;
    background-color: var(--blanco);
    width: 100vw;
    padding-top: 0.5em;
    padding-bottom: 0.4em;
    padding-left: 1.3em;
    align-items: baseline;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
    z-index: 4;
}

a {
    text-decoration: none;
    color: var(--azul);
    font-family: "DM Sans", sans-serif;
    font-weight: bold;
}

nav ul {
    display: flex;
    gap: 1.3em;
    width: 80vw;
    padding-top: 1em;
    align-items: center;
    justify-content: flex-end;
    padding-right: 0.7em;
}

nav ul li {
    list-style: none;
}

h1 {
    color: var(--azul);
    font-family: "aktiv-grotesk", sans-serif;
    font-weight: 700;
    font-size: 1.8em;
}

.introduccion {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 35vh;
    background-color: var(--blanco);
    min-height: 14.25rem; /* Cambiado a min-height */
    justify-content: center;
    align-items: flex-start;
    padding-top: 4em;
    padding-bottom: 2em;
    padding-left: 1em;
    padding-right: 1em;
}

div.introduccion-de-la-empresa{
    width: 24rem;
    font-size: 1em;
    color: var(--negro_a);
    text-align: left;
    display: flex;
    flex-direction: column;
    height: 10.125rem;
    padding-left: 0.5em;
    align-items: flex-start; /* Centrado vertical */
    background-color: var(--blanco);
}

.introduccion-de-la-empresa h1 {
    text-align: center; /* Centrado adicional para el h1 */
    width: 100%; /* Asegura que ocupe todo el ancho disponible */
    padding-top: 0; /* Ajuste del padding superior */
    margin-bottom: 1rem; /* Espacio entre el título y el párrafo */
    padding-top: 2em;
}

.servicios {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 2rem;
    padding: 1rem;
    max-width: 1400px;
    margin: 0 auto;
}

/* Tarjetas individuales */
.servicios > div {
    flex: 1 1 300px; /* Flex-grow | Flex-shrink | Flex-basis */
    max-width: 350px;
    background: white;
    border-radius: 8px;
    padding: 1.5rem;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
    transition: all 0.3s ease;
}

.floating-button-container {
    width: 100vw;
    justify-content: center;
    margin: 0 auto;
    padding-bottom: 3em;

} 

.btn-outline-primary {
    text-decoration: none;
    color: var(--azul);
    font-family: "DM Sans", sans-serif;
    font-weight: bold;
} 

.btn-outline-primary:hover {
    background-color: var(--azul);
    color: var(--blanco);
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(26, 60, 153, 0.3);
    border: var(--azul);
}

.floating-button-container button {
    width: 60%;
    min-width: 120px; /* Ancho mínimo */
    position: relative;
    border-radius: 32px;
    border: 2px solid #1a3c99;
    box-sizing: border-box;
    height: 4em;
    color: var(--azul);
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

.foto-circular {
    width: 1em;
    border-radius: 50%;
    overflow: hidden; /* Evita que la imagen sobresalga */
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: -60px;
    z-index: 2;
    position: relative;
    background-color: var(--blanco);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    scale: 70%; 
}

.foto-circular img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Hace que la imagen llene el círculo sin deformarse */
    object-position: center;
}

/* Estilos para los títulos */
.servicios h5 {
    background-color: var(--azul);
    color: var(--blanco);
    padding: 70px 1em 1em 1em; /* Más espacio arriba para la foto */
    margin: 0;
    width: 100%;
    text-align: center;
    border-radius: 8px 8px 0 0;
    position: relative;
    z-index: 1;
    text-transform: uppercase;
    font-size: 1em;
    font-weight: bold;
    letter-spacing: 1px;
}

/* Contenedor de cada servicio */
.servicios > div {
    display: flex;
    flex-direction: column;
    align-items: center;
    background: var(--blanco);
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    margin-bottom: 2.5em;
    overflow: hidden;
    transition: transform 0.3s ease;
    max-width: 600px;
    width: 90%;
}

/* Contenido del servicio */
.servicios > div > p,
.servicios > div > ul {
    padding: 1.5em;
    margin: 0;
    width: 100%;
}

.servicios > div > p {
    padding-bottom: 0.5em; /* Ajusta este valor según necesites */
    margin-bottom: 0; /* Asegura que no haya margen adicional */
}

.servicios div {
    display: flex;
    flex-direction: column;
    align-items: center; /* Centra horizontalmente los elementos */
    margin-bottom: 2em;
    width: 100%;
}

.servicios h5 {
    padding-top: 1.5em;
    padding-bottom: 0.6em;
    text-align: center;
    text-transform: uppercase;
    color: var(--blanco);
}

.servicios p {
    font-size: 0.8em;
}

.servicios ul {
    font-size: 0.8em;
    padding-bottom: 1em;

    list-style-position: inside; /* Alinea viñetas con el texto */
    width: 100%; /* Ocupa todo el ancho disponible */
    max-width: 600px; /* Ancho máximo para mejor legibilidad */
    margin: 0 auto; /* Centra la lista */
}

.servicios li {
    margin-bottom: 0.7em; /* Espacio entre elementos de lista */
    line-height: 1.6; /* Altura de línea para mejor legibilidad */
    padding-left: 1em; /* Espacio para la viñeta */
    text-indent: -1em; /* Alineación del texto con viñetas */
}

/* Estilos para la sección footer */
.footer {
    background-color: var(--blue_f);
} 

.footer {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.footer img {
    width: 55%;
}

.footer h2 {
    font-family: "aktiv-grotesk", sans-serif;
    font-weight: 700;
    color: #1a3c99;
    font-size: 1.3em;
}

.footer p {
    color: var(--negro_a);
    margin-bottom: 0;
    font-size: 0.8em;
}

.footer a {
    color: var(--negro_a);
    font-weight: 400;
    padding-bottom: 1.5em;
    font-size: 0.8em;
}

.floating-button-container {

  max-width: 30em;
  margin: 0 auto;
  padding: 20px;
  background: var(--blanco);
  border-radius: 10px;
  padding-bottom: 5.2em;
}

.floating-button-container .form-control {
  border: 1px solid var(--azul);
  margin-bottom: 15px;
}

.floating-button-container .form-control:focus {
  border-color: var(--morado);
  box-shadow: 0 0 0 0.25rem rgba(121, 33, 135, 0.25);
}

.floating-button-container textarea {
  resize: vertical;
}

/* Centra el contenedor del CAPTCHA */
.h-captcha {
    display: flex;
    justify-content: center;
    margin: 20px 0; /* Añade espacio arriba/abajo */
 }

 /* Corrección específica para Safari/macOS */
@supports (-webkit-touch-callout: none) {
    .floating-button-container form {
      display: block !important; /* Anula flexbox solo en Safari */
    }
    
    .h-captcha {
      margin: 20px auto !important;
      transform: translateX(-8px); /* Compensa desplazamiento peculiar de Safari */
    }
  }

/* Desktop */
@media only screen and (min-width: 1200px){
    
    .introduccion {
        display: flex;
        width: 100%;
        padding-top: 4rem; /* Espaciado vertical y horizontal */
        background-color: var(--blanco);
        height: 30%; /* Cambiado a min-height */
        justify-content: center;
        align-items: center;
        padding-bottom: 0;
    }

    .introduccion p {
        font-size: 1em;
        text-align: left;
    }

    .intro-container {
        display: flex;
    } 

    h1  {
        font-size: 4rem;
        justify-content: center;
        align-items: center;
        padding-top: 2em;
    }

    nav ul {
        width: 95vw;
        gap: 5em;
        padding-right: 2em;
    }

    div.introduccion-de-la-empresa{
        width: 44rem;
        color: var(--negro_a);
        text-align: left;
        display: flex;
        gap: 1.5rem; /* Espacio entre elementos */
        height: auto;
        padding-left: 0.5em;
        align-items: flex-end; /* Centrado vertical */
        background-color: var(--blanco);
    }

   /* Contenedor principal de sectores */
    .servicios {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 2rem;
        padding: 1rem;
        max-width: 1600px;
        margin: 0 auto;
        padding-top: 6.5em;
    }

    /* Tarjetas individuales */
    .servicios > div {
        flex: 1 1 300px; /* Flex-grow | Flex-shrink | Flex-basis */
        max-width: 350px;
        background: var(--blanco);
        border-radius: 8px;
        padding: 1.5rem;
        box-shadow: 0 4px 8px rgba(0,0,0,0.1);
        transition: all 0.3s ease;
    }

    /* Contenido de las tarjetas */
    .sectores img {
        width: 80px;
        height: 80px;
        margin: 0 auto 1rem;
        display: block;
    }

    .sectores h5 {
        text-align: center;
        margin-bottom: 1rem;
        color: var(--celeste);
    }

    .floating-button-container button {
        width: 30%;
    }
    
    h5 {
        padding-top: 1em;
        text-transform: uppercase;
        color: var(--celeste);
        
    }

    .footer {
        padding-bottom: 1.5em;
    }

    .footer img {
        width: 15%;
    }

    nav ul {
        width: 90vw;
        gap: 4em;
        padding-right: 2em;
    }
    
    a img {
        padding-left: 1em;
    }

    .floating-button-container {
        max-width: 700px;
        margin: 0 auto;
        padding: 20px;
        background: var(--blanco);
        border-radius: 10px;
        padding-bottom: 5.2em;
      }
      
}

/* Tablet */

@media only screen and (max-width: 1200px) and (min-width: 540px){
    
    .introduccion {
        display: flex;
        width: 100%;
        background-color: var(--blanco);
        min-height: 20rem; /* Cambiado a min-height */
        justify-content: center;
        align-items: flex-start;
    }

    .intro-container {
        display: flex;
    } 

    h1  {
        font-size: 3rem;
        justify-content: center;
        align-items: flex-start;
        padding: 0;
    }

    nav ul {
        width: 95vw;
        gap: 5em;
        padding-right: 2em;
    }

    div.introduccion-de-la-empresa{
        width: 38rem;
        font-size: 1.063rem;
        color: var(--negro_a);
        text-align: left;
        display: flex;
        flex-direction: column;
        gap: 1.5rem; /* Espacio entre elementos */
        height: 10.125rem;
        padding-left: 0.5em;
        align-items: flex-end; /* Centrado vertical */
        background-color: var(--blanco);
    }

   /* Contenedor principal de sectores */
    .servicios {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 2rem;
        padding: 1rem;
        max-width: 1400px;
        margin: 0 auto;
        padding-top: 4em;
    }

    .servicios > div {
        flex: 1 1 300px; /* Flex-grow | Flex-shrink | Flex-basis */
        max-width: 350px;
        background: var(--blanco);
        border-radius: 8px;
        padding: 1.5rem;
        box-shadow: 0 4px 8px rgba(0,0,0,0.1);
        transition: all 0.3s ease;
    }

    .servicios button {
        width: 30vw;
        height: 10vw;
        align-items: center;
        justify-content: center;
    }

    /* Contenido de las tarjetas */
    .sectores img {
        width: 80px;
        height: 80px;
        margin: 0 auto 1rem;
        display: block;
    }

    .servicios h5 {
        padding-top: 2em;
        font-size: 1.1em;
    }

    .servicios p {
        font-size: 0.8em;
        text-align: left;
        padding-bottom: 0.4em;
    }

    .footer img {
        width: 30%;
    }

    .footer {
        padding-bottom: 1em;
    }

    nav ul {
        width: 90vw;
        gap: 4em;
        padding-right: 2em;
    }

    a img {
        padding-left: 1em;
    }
}

/* dispositivos móviles */

@media only screen and (max-width: 1200px) and (min-width: 320px) {
    .img_dk {
       display: none;
}



}