*{
    padding: 0;
    margin: 0;
    font-family: "Montserrat", sans-serif;
    box-sizing: border-box;
    text-decoration: none;
}

html {
    scroll-behavior: smooth;
}
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
}

/* Hero section */
.hero-section {
    padding: 25px 0;
    background-color: #054D64;
    text-align: center;
    font-weight: 300;
    color: white;
    font-size: 1em;
    display: flex;
    align-items: center;
    justify-content: center;
}

.barra-header{
    margin: 0 10px;
}

.hero-section p a {
    color: white;
    border-bottom: 1px solid white;
}

/* Logo */
.navbar-logo {
    width: 150px;
}

/* Navbar */
.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
}

.menu-icono{
    width: 20px;
    background-color: #054D64;
}

/* Links del navbar */
.navbar_links {
    display: flex;
    align-items: center;
    list-style: none;
}

.navbar_links li {
    margin-right: 20px;
}

.navbar_links li a {
    color: rgb(0, 0, 0);
    font-size: 1em;
    font-weight: 600;
}

/* Ícono de hamburguesa */
.hamburger {
    display: none;
    font-size: 30px;
    cursor: pointer;
  
}

/* Checkbox para controlar el estado del menú */
.menu-toggle {
    display: none;
}


/* Estilos section principal */
.principal {
    display: flex;
    justify-content: space-between;
    height: 350px;
    margin-top: 50px;
    margin-bottom: 50px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Desplaza hacia abajo */
    animation: fadeInUp 0.7s forwards; /* Aplica la animación */
}

@keyframes fadeInUp {
    to {
        opacity: 1; /* Hacer visible */
        transform: translateY(0); /* Vuelve a la posición original */
    }
}

.principal-img {
    width: 49%;
    background-image: url(/assets/imagenes/Home.png);
    background-position: center;
    background-size: cover;
    border-radius: 10px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazada hacia abajo */
    animation: fadeInUp 0.7s forwards; /* Aplica la animación */
    animation-delay: 0.1s; /* Retraso para la imagen */
}

.principal-text {
    width: 49%;
    background-color: #054D64;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: white;
    padding: 0 40px;
}

.principal-text h1 {
    font-size: 4em;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: fadeInUp 0.5s forwards; /* Aplica animación a h1 */
    animation-delay: 0.2s; /* Retraso para h1 */
}

.principal-text h2 {
    font-size: 1em;
    font-weight: 300;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: fadeInUp 0.5s forwards; /* Aplica animación a h2 */
    animation-delay: 0.4s; /* Retraso para h2 */
}


/* Estilos del banner */
.banner {
    background-color: #054D64;
    padding: 30px 50px;
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-radius: 10px;
    font-size: 1em;
    margin-top: 50px;
    opacity: 0; /* Comienza invisible */
    animation: fadeIn 0.9s forwards; /* Animación general para el banner */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

.banner-text {
    transform: translateX(-280px); /* Comienza desplazado hacia la izquierda */
    animation: slideInLeft 0.8s forwards; /* Aplica la animación */
    font-weight: 200;
}

.banner-text h4{
    font-weight: 400;
}

@keyframes slideInLeft {
    to {
        transform: translateX(0); /* Vuelve a la posición original */
    }
}

.banner-info a{
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 500;
    color: white;
    transform: translateX(50px); /* Comienza desplazado hacia la derecha */
    animation: slideInRight 0.8s forwards; /* Aplica la animación */
}

@keyframes slideInRight {
    to {
        transform: translateX(0); /* Vuelve a la posición original */
    }
}

.banner-info a img{
    width: 30px;
}

/* Estilos de la section info */
.info {
    margin-top: 50px;
    display: flex;
    height: 600px;
    height: 400px;
    justify-content: space-between;
    opacity: 0; /* Comienza invisible */
    animation: fadeIn 0.7s forwards; /* Animación general para la sección */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

.info-text {
    width: 59%;
    font-size: 1em;
    background-color: #054D64;
    color: white;
    padding: 30px;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    transform: translateX(-50px); /* Comienza desplazado hacia la izquierda */
    animation: slideInLeft 0.5s forwards; /* Aplica la animación */
}

@keyframes slideInLeft {
    from {
        transform: translateX(-50px); /* Comienza desplazado */
    }
    to {
        transform: translateX(0); /* Vuelve a la posición original */
    }
}

.info-text h2 {
    font-weight: 500;
    padding-bottom: 50px;
}

.info-content {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 14px;
    line-height: 1.5em;
    font-weight: 300;
    opacity: 0; /* Comienza invisible */
    animation: fadeInContent 0.5s forwards; /* Aplica la animación */
    animation-delay: 0.3s; /* Retrasa la animación para que aparezca después del título */
}

@keyframes fadeInContent {
    to {
        opacity: 1; /* Hacer visible el contenido */
    }
}

.info-img {
    background-image: url(/assets/imagenes/Nosotros.png);
    background-size: cover;
    width: 39%;
    height: 400px;
    border-radius: 10px;
    transform: translateX(50px); /* Comienza desplazado hacia la derecha */
    animation: slideInRight 0.5s forwards; /* Aplica la animación */
}

@keyframes slideInRight {
    from {
        transform: translateX(50px); /* Comienza desplazado */
    }
    to {
        transform: translateX(0); /* Vuelve a la posición original */
    }
}



/* Estilos de la section indutria */

.industrias {
    opacity: 0; /* Comienza invisible */
    animation: fadeIn 0.7s forwards; /* Aplica la animación general a la sección */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

.industrias-title {
    padding: 50px 0;
    text-align: center;
    font-size: 1.3em;
}

.industrias-container {
    background-color: #054D64;
}

.industrias-grid {
    background-color: #054D64;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 40px; 
    justify-items: center; 
    padding: 50px 0;
}

.industrias-cards {
    width: 180px; 
    height: 200px; 
    background-color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    flex-wrap: wrap;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a cada tarjeta */
}

/* Crea un retraso para cada tarjeta usando nth-child */
.industrias-cards:nth-child(1) { animation-delay: 0.1s; }
.industrias-cards:nth-child(2) { animation-delay: 0.2s; }
.industrias-cards:nth-child(3) { animation-delay: 0.3s; }
.industrias-cards:nth-child(4) { animation-delay: 0.4s; }
.industrias-cards:nth-child(5) { animation-delay: 0.5s; }
.industrias-cards:nth-child(6) { animation-delay: 0.6s; }
.industrias-cards:nth-child(7) { animation-delay: 0.7s; }
.industrias-cards:nth-child(8) { animation-delay: 0.8s; }
.industrias-cards:nth-child(9) { animation-delay: 0.9s; }
.industrias-cards:nth-child(10) { animation-delay: 1s; }

@keyframes slideIn {
    to {
        opacity: 1; /* Hacer visible */
        transform: translateY(0); /* Vuelve a la posición original */
    }
}

.industrias-cards img {
    max-width: 80px; 
    margin-bottom: 20px;
}

.industrias-cards-text {
    text-align: center;
}

/* Estilos de la section servicios */
.servicios {
    margin-top: 50px;
    opacity: 0; /* Comienza invisible */
    animation: fadeIn 0.7s forwards; /* Aplica la animación general a la sección */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

.servicios h2 {
    text-align: center;
    padding: 50px 0;
}




.capacitacion {
    background-color: #054D64;
}

.capacitacion h2 {
    text-align: center;
    padding: 50px;
    color: white;
    font-weight: 600;
}



/* Estilos de la section izaje */

.izaje-img {
    width: 35%;
    border-radius: 10px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a la imagen de izaje */
}

.izaje {
    display: flex;
    gap: 20px;
    margin-bottom: 30px;
    height: 400px;
}

.izaje-content {
    background-color: white;
    width: 65%;
    border-radius: 10px;
    padding: 40px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación al contenido de izaje */
}

/* Crea un retraso para la animación de la tarjeta de izaje */
.izaje-content {
    animation-delay: 0.1s; /* Retraso para la animación de izaje */
}

.izaje-content h3 {
    font-size: 1em;
    color: #054D64;
    font-weight: 600;
    margin-bottom: 30px;
}

.izaje-list {
    font-size: 0.9em;
    line-height: 1.8em;
    font-weight: 500;
    padding-left: 20px;
}



/* Estilos de la section maquina pesada */

.maqpesada {
    display: flex;
    gap: 20px;
    padding-bottom: 30px;
}

.maqpesada-content {
    background-color: white;
    width: 65%;
    border-radius: 10px;
    padding: 40px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación al contenido de maquinaria pesada */
}

/* Crea un retraso para la animación de la tarjeta de maquinaria pesada */
.maqpesada-content {
    animation-delay: 0.3s; /* Retraso para la animación de maquinaria pesada */
}

.maqpesada-content h3 {
    font-size: 1em;
    color: #054D64;
    font-weight: 600;
    margin-bottom: 30px;
}

.maqpesada-list {
    font-size: 0.9em;
    line-height: 1.8em;
    font-weight: 500;
    padding-left: 20px;
}

.maqpesada-img {
    width: 35%;
    object-fit: cover;
    border-radius: 10px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a la imagen de maquinaria pesada */
}

/* Crea un retraso para la animación de la imagen de maquinaria pesada */
.maqpesada-img {
    animation-delay: 0.4s; /* Retraso para la animación de maquinaria pesada */
}

@keyframes slideIn {
    to {
        opacity: 1; /* Hacer visible */
        transform: translateY(0); /* Vuelve a la posición original */
    }
}


/* Estilos de la section inspeccion */


.insp {
    display: flex;
    gap: 20px;
    padding-bottom: 30px;
    height: 450px;
}

.inspeccion {
    opacity: 0; /* Comienza invisible */
    animation: fadeIn 0.7s forwards; /* Aplica la animación general a la sección de inspección */
}

.inspeccion h2 {
    text-align: center;
    font-size: 1.3em;
    padding: 50px 0;
    color: #054D64;
    font-weight: 600;
}

.inspeccion-content {
    background-color: #054D64;
    width: 65%;
    border-radius: 10px;
    padding: 40px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación al contenido de inspección */
}

.inspeccion h3 {
    font-size: 1em;
    color: white;
    font-weight: 600;
    margin-bottom: 30px;
}

.inspeccion-img {
    width: 35%;
    object-fit: cover;
    border-radius: 10px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a la imagen de inspección */
}

/* Crea un retraso para la animación de la imagen de inspección */
.inspeccion-img {
    animation-delay: 0.2s; /* Retraso para la animación de la imagen de inspección */
}

.inspeccion-list {
    font-size: 0.9em;
    line-height: 1.8em;
    font-weight: 400;
    color: white;
    padding-left: 20px;
}

.pesada {
    display: flex;
    gap: 20px;
    padding-bottom: 30px;
}

.pesada-content {
    background-color: #054D64;
    width: 65%;
    border-radius: 10px;
    padding: 40px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación al contenido de pesada */
}

/* Crea un retraso para la animación del contenido de pesada */
.pesada-content {
    animation-delay: 0.3s; /* Retraso para la animación de contenido pesada */
}

.pesada h3 {
    font-size: 1em;
    color: white;
    font-weight: 600;
    margin-bottom: 30px;
}

.pesada-list {
    font-size: 0.9em;
    line-height: 1.8em;
    font-weight: 400;
    color: white;
    padding-left: 20px;
}

.pesada-img {
    width: 35%;
    object-fit: cover;
    border-radius: 10px;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a la imagen de pesada */
}

/* Crea un retraso para la animación de la imagen de pesada */
.pesada-img {
    animation-delay: 0.4s; /* Retraso para la animación de la imagen de pesada */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

@keyframes slideIn {
    to {
        opacity: 1; /* Hacer visible */
        transform: translateY(0); /* Vuelve a la posición original */
    }
}


/* Estilos de la section campo */


.campo{
    padding-bottom: 100px;
}

.campo-img {
    display: grid;
    grid-template-columns: repeat(3, 1fr); 
    grid-gap: 10px; 
}

.campo-img a {
    display: block; /* Asegura que el enlace sea un bloque */
}

.campo-img img {
    width: 100%; 
    height: auto;
    border-radius: 10px; 
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: slideIn 0.5s forwards; /* Aplica la animación a las imágenes */
}

/* Crea un retraso para las animaciones de las imágenes */
.campo-img img:nth-child(1) { animation-delay: 0.2s; }
.campo-img img:nth-child(2) { animation-delay: 0.3s; }
.campo-img img:nth-child(3) { animation-delay: 0.4s; }
.campo-img img:nth-child(4) { animation-delay: 0.5s; }
.campo-img img:nth-child(5) { animation-delay: 0.6s; }
.campo-img img:nth-child(6) { animation-delay: 0.7s; }
.campo-img img:nth-child(7) { animation-delay: 0.8s; }
.campo-img img:nth-child(8) { animation-delay: 0.9s; }
.campo-img img:nth-child(9) { animation-delay: 0.10s; }

.campo h2 {
    text-align: center;
    padding: 50px;
    color: #054D64;
    font-weight: 600;
    font-size: 1.3em;
    opacity: 0; /* Comienza invisible */
    transform: translateY(20px); /* Comienza desplazado hacia abajo */
    animation: fadeIn 0.7s forwards; /* Aplica la animación al título */
    animation-delay: 0.3s; /* Retraso para que aparezca después de las imágenes */
}

@keyframes fadeIn {
    to {
        opacity: 1; /* Hacer visible */
    }
}

@keyframes slideIn {
    to {
        opacity: 1; /* Hacer visible */
        transform: translateY(0); /* Vuelve a la posición original */
    }
}


.certificaciones{
    background-color: #054D64;
    padding-bottom: 80px;
}

.certificaciones h2{
    text-align: center;
    padding: 50px;
    color: #ffffff;
    font-weight: 600;
    font-size: 1.3em;
}

.certificaciones h5{
    color: white;
    font-size: 1em;
    font-weight: 600;
    margin-bottom: 5px;
}

.certificaciones p{
    color: white;
    border-bottom: 1px solid white;
    padding-bottom: 10px;
    font-style: italic;
    font-weight: 300;
    font-size: 0.9em;
}
.certificaciones div{
    margin-bottom: 20px;
}

.certificaciones a {
    color: white;
    border-bottom: 1px solid white;
    cursor: pointer;
    font-weight: 500;
    font-style: normal;
    font-size: 0.9em;
}


.form{
    margin-bottom: 50px;

}

.form h2{
    text-align: center;
    padding: 50px;
    color: #054D64;
    font-weight: 600;
    font-size: 1.3em;
}

.form-content{
    display: flex;
    justify-content: space-around;
    gap:20px;
    align-items: center;
}

/* Estilos generales del formulario */

.contact-form {
    width: 60%; 
    padding: 20px;
    border-radius: 10px; 
    font-size: 1em;
}

.contact-form label {
    display: block;
    font-weight: 500; 
    margin-bottom: 20px;
    color: #000000;
}

.contact-form input,
.contact-form textarea {
    width: 100%; 
    padding: 10px;
    margin-bottom: 20px;
    border: 1px solid #ccc; 
    border-radius: 10px; 
    font-size: 12px;
    background-color: #b3b0b0;
}

.contact-form input:focus,
.contact-form textarea:focus {
    border-color: #054D64; 
    outline: none; 
}

.contact-form button {
    width: 35%; 
    padding: 20px 10px;
    background-color: #054D64; 
    color: white; 
    border: none;
    border-radius: 10px;
    font-size: 14px;
    cursor: pointer; 
    text-transform: uppercase;
    font-weight: 600;
}




.card-form{
    background-color: #054D64;
    width: 38%;
    height: 400px;
    display: flex;
    flex-direction: column;
    padding: 30px;
    justify-content: center;
    border-radius: 10px;
    gap: 50px;
    color: white;
   
}

.card-form ul{
    list-style: none;
}

.card-form a{
    color: white;
}

.card-form h3{
    margin-bottom: 20px;
    font-weight: 500;
}

.card-form p{
    margin-bottom: 5px;
}

.mail-form{
    color: white;
    border-bottom: 1px solid white;
}

footer{
  background-color: #054D64;
  min-height: 120px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 10px;
  color: white;
  padding: 20px 0;
}

   
/* Estilos específicos para teléfonos grandes */

@media (max-width: 768px) {
        .hero-section{
            font-size: 0.9em; 
            padding: 20px 10px;
        }

    
        .navbar-logo{
            width: 120px;
        }

        /* Cambios en el navbar */
        .navbar_links {
            display: none;
            flex-direction: column;
            position: absolute;
            top: 130px;
            right: 0;
            background-color: #054c64f9;
            width: 100%;
            text-align: center;
            padding: 40px 0;
            border-radius: 10px;
            z-index: 1000
            ;
        }

        .navbar_links li {
            margin: 15px 0;
            padding: 10px 0;
            
        }

        .navbar_links li a {
            color: white;
            font-size: 14px;
            font-weight: 400;
            padding: 20px 0;
        }

        /* Mostrar el ícono de hamburguesa en pantallas pequeñas */
        .hamburger {
            display: block;
        }

        /* Si el checkbox está marcado, mostrar el menú */
        #menu-toggle:checked + .hamburger + .navbar_links {
            display: flex;
        }
        .navbar {
            position: relative;
        }
        .hero-section{
            flex-direction: column;
        }
        .barra-header{
            display: none;
        }

        .parrafo-header{
            margin-bottom: 10px;
        }
        .principal{
            flex-direction: column;
            justify-content: center;
            align-items: center;
            height: auto;
            gap: 20px;
            margin-top:10px
        }

        .principal-text{
            width: 100%;
            padding: 50px 10px;
        }

        .principal-text h1{
            font-size: 4em;
            margin-bottom: 10px;
        }

        .principal-img{
            height: 200px;
            width: 100%;
        }

        .banner{
            padding: 30px 10px;
            font-size: 1.1em;
            flex-direction: column;
            text-align: center;
            gap: 20px
        }

        .banner-info{
            gap:5px;
            font-weight: 500;
        }

        .banner-info img{
            width: 30px;
        }

        .info{
            flex-direction: column;
            gap:10px;
            height: auto;
        }

        .info-text{
            font-size: 0.9em;
            width: 100%;
        }
        .info-text h2{
            padding-bottom: 10px;
        }
        .info-img{
            height: 400px;
            width: 100%;
        }

        .industrias-title{
            font-size: 1.5em;
        }

        .industrias-grid {
            grid-template-columns: repeat(2, 1fr); /* Dos columnas en pantallas pequeñas */
            padding: 20px 5px;
            gap: 10px;
        }

        .industrias-cards{
            width: 150px;
            height: 160px;
        }

        .servicios h2  {
            font-size: 1.5em;
        }

        .maqpesada{
            padding-bottom: 100px;
            flex-direction: column-reverse;
        }

        .maqpesada-list, .izaje-list, .pesada-list, .inspeccion-list{
            padding-left: 15px;
        }


        .izaje , .insp, .form-content{
            flex-direction: column;
            height: auto;
        }
        .izaje-img, .maqpesada-img, .inspeccion-img, .pesada-img{
            width: 100%;
            height: 300px;
            object-fit: cover;

        }
        .inspeccion h2{
            padding: 50px 5px;
            font-size: 1.4em;
        }
        .izaje-content, .maqpesada-content, .inspeccion-content,.pesada-content{
         width: 100%;
         padding: 20px;
        }
        .pesada{
            flex-direction: column-reverse;
        }
        .campo h2 {
            font-size: 1.5em;
            padding: 50px 0;
        }
        .campo-img{
            grid-template-columns: repeat(1, 1fr);
        }
        .form h2 {
            font-size: 1em;
            padding: 50px 0;
        }

        .contact-form{
            width: 100%;
            padding: 5px;
        }

        .contact-form button{
            width: 100%;
            margin-bottom: 50px;
        }

        .card-form{
            width: 100%;
        }

        footer{
            padding: 20px 20px;
            text-align: center;
        }

  }











