 * {
   margin: 0;
   padding: 0;
   box-sizing: border-box;
   transition: all 0.8s ease-in-out;
   scroll-behavior: smooth;
   color: rgb(84, 81, 81);
 }

 body {
   font-family: monospace -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
   background-color: var(--light);
   color: var(--dark);

 }

 /* preloader */
 #preloader {
   position: fixed;
   top: 0;
   left: 0;
   width: 100%;
   height: 100%;
   background: #fff;
   display: flex;
   justify-content: center;
   align-items: center;
   z-index: 9999;
 }

 /* Spinner */
 .spinner {
   width: 50px;
   height: 50px;
   border: 5px solid #ddd;
   border-top: 5px solid #3498db;
   border-radius: 50%;
   animation: girar 1s linear infinite;
 }

 @keyframes girar {
   0% {
     transform: rotate(0deg);
   }

   100% {
     transform: rotate(360deg);
   }
 }

 #preloader.fade-out {
   opacity: 0;
   transition: opacity 0.6s ease;
   pointer-events: none;
 }

 /* preloader */

 .container-padre-operaciones {
   width: 100%;
   background-color: #e6ebf1;
   background-size: cover;
   background-attachment: fixed;
   color: rgb(22, 56, 99);
   font-family: 'IBM Plex Sans', sans-serif;
   margin: 0 auto;
   padding: 0;
   box-sizing: border-box;


 }

 /*inicio menu superior*/

 .header {
   display: flex;
   position: fixed;
   top: 0;
   left: 0;
   right: 0;
   z-index: 1000;
   width: 100%;
   color: rgb(22, 56, 99);
   text-align: center;
   box-sizing: border-box;
   background-color: #dadfe2;
   transition: transform 0.3s ease-in-out;
 }

 .header.hide {
   transform: translateY(-100%);
 }

 .menu-nav {
   display: flex;
   flex-wrap: wrap;
   width: 100%;
   min-height: 80px;
   box-sizing: border-box;
   justify-content: start;
   color: rgb(22, 56, 99);
   box-sizing: border-box;

 }

 .logo {
   width: 4%;
   background-color: #e7ebec;
   border-radius: 10%;
   height: 60px;
   margin-top: 10px;
   margin-left: 10px;
 }

 .redes-sociales {
   width: 10%;
   color: rgb(22, 56, 99);
   box-sizing: border-box;
   place-content: center;
   box-sizing: border-box;
 }

 .redes-sociales img {
   width: 10%;
   margin: 5px;
   color: #00ccff;
 }

 .redes-sociales a {
   text-decoration: none;
   color: rgb(22, 56, 99);
 }

 .div-titulo {
   width: 45%;
   display: flex;
   justify-content: center;
   align-items: center;
   margin-left: 5%;
 }

 .div-titulo img {
   width: 20%;
   height: 70px;
   cursor: pointer;
   text-decoration: none;
 }

 /* inicio responsive */
 .div-enlaces {
   display: flex;
   flex-direction: row;
   width: 45%;
   margin-right: 5%;
 }

 /* inicio responsive */

 /* ---------------------------------------------- */

 .nav-enlaces {
   display: flex;
   width: 45%;
   justify-content: end;
   margin-left: 38%;
   box-sizing: border-box;
 }

 .nav-enlaces a {
   width: 12%;
   place-content: center;
   text-decoration: none;
   font-size: 15px;
   font-weight: 500;
   color: rgb(22, 56, 99);
 }

 .nav-enlaces a:hover {
   color: #00ccff;
   transition: 0.5s ease;
 }

 .container-menu-responsive {
   display: none;
 }

 /*fin menu superior*/

 /*------------------------------------------*/

 .operaciones-1 {
   width: 100%;
   margin: auto;
   margin-top: 4%;
   min-height: 700px;
   display: flex;
   flex-wrap: wrap;
   border: solid 1px #dadfe2;
   background-image:
     linear-gradient(to top, rgba(28, 105, 73, 0.55), rgba(83, 196, 177, 0.15)),
     url("../assets/personal/operaciones-fondo.jpg");
   background-size: cover;
   background-position: center;
   background-repeat: no-repeat;
   box-sizing: border-box;
 }

 .div-info-operaciones {
   width: 30%;
   display: flex;
   flex-wrap: wrap;
   min-height: 400px;
   justify-content: center;
   align-items: center;
   box-sizing: border-box;
   padding: 20px;
   margin: auto;
   margin-left: 2%;

 }

 .div-info-operaciones h3 {
   width: 100%;
   text-align: center;
   font-size: 40px;
   color: white;
 }

 .div-info-operaciones p {
   width: 100%;
   text-align: center;
   font-size: 20px;
   color: white;
 }


 .operaciones-2 {
   width: 100%;
   margin: auto;
   min-height: 500px;
   display: flex;
   flex-wrap: wrap;
   border: solid 1px #dadfe2;
   box-sizing: border-box;
   padding-top: 4%;
 }

 .operaciones-2 img {
   width: 50%;
   height: 650px;
   object-fit: cover;
   border-radius: 10px;
 }

 .features-peajes {
   display: flex;
   flex-wrap: wrap;
   width: 100%;
   margin: auto;
   margin-left: 2%;
   padding: 1%;
   box-sizing: border-box;
   border-radius: 10px;
   color: rgb(168, 180, 184);
   margin-bottom: 5%;
 }

 .features-peajes div {
   box-sizing: border-box;
   margin: auto;
   margin-left: 2%;
   width: 30%;
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
   padding: 1%;
 }

 .features-peajes p {
   width: 100%;
   text-align: center;
   font-size: 20px;
   color: rgb(22, 56, 99);
   justify-content: center;
 }

 .features-peajes h2 {
   width: 100%;
   text-align: center;
   font-size: 40px;
   color: rgb(22, 56, 99);
   margin-bottom: 5%;
 }

 /* -------------------------------------------------------- */

 .operaciones-3 {
   width: 100%;
   min-height: 250px;
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
   margin-top: 2%;
   background-image:
     linear-gradient(to top, rgba(28, 105, 73, 0.55), rgba(83, 196, 177, 0.15)),
     url("../assets/personal/operaciones-fondo-2.jpg");
   background-size: cover;
   background-position: center;
   background-repeat: no-repeat;
   box-sizing: border-box;
 }

 .operaciones-3 h4 {
   width: 100%;
   text-align: center;
   font-size: 2rem;
   color: rgb(247, 250, 255);
 }





 /* ----------------------------- */
 .contactos {
   width: 100%;
   display: flex;
   flex-wrap: wrap;
   flex-direction: column;
   margin: auto;
   min-height: 400px;
   margin-top: 2%;
   box-sizing: border-box;
   background-color: #e6ebf1;
 }

 .contactos h2 {
   width: 100%;
   text-align: center;
   font-size: 30px;
   color: rgb(22, 56, 99);
   margin-top: 20px;
 }

 .contactos 
 span {
   width: 100%;
   text-align: center;
   color: rgb(22, 56, 99);
   margin: 5px 0px 5px 0px;

 }
  .contactos p {
   width: 100%;
   text-align: center;
   color: rgb(22, 56, 99);
   margin: 5px 0px 5px 0px;

 }


 .map {
   width: 50%;
   min-height: 400px;
   margin: auto;
   margin-top: 2%;
   box-sizing: border-box;
   border-radius: 10px;
 }

 /* ------------------------------- */
 footer {
   width: 100%;
   display: flex;
   flex-wrap: wrap;
   min-height: 200px;
   background-color: var(--dark);
   box-shadow: 2px 2px 5px black;
   color: rgb(126, 119, 119);
   text-align: center;
   padding: 1rem;
   margin-top: 3rem;
   box-sizing: border-box;

 }

 .footer-nosotros {
   width: 20%;
   margin: auto;
   margin-right: 1%;
   margin-left: 18%;
   display: flex;
   flex-direction: column;
   align-items: center;
   padding: 1%;
   color: rgb(22, 56, 99);
 }

 .footer-nosotros h4 {
   margin-bottom: 2%;
   color: rgb(84, 81, 81);
 }

 .footer-nosotros a {
   margin-bottom: 2%;
   color: rgb(22, 56, 99);
   text-decoration: none;
 }

 .footer-nosotros a:hover {
   color: #00ccff;
   transition: 0.5s ease;
 }

 /* ----------------------------- */
 .footer-nuestra-empresa {
   width: 20%;
   margin: auto;
   margin-left: 1%;
   margin-right: 1%;
   display: flex;
   flex-direction: column;
   align-items: center;
   padding: 1%;
 }

 .footer-nuestra-empresa h4 {
   margin-bottom: 2%;
   color: rgb(84, 81, 81);
 }

 .footer-nuestra-empresa a {
   margin-bottom: 2%;
   color: rgb(22, 56, 99);
   text-decoration: none;
 }

 .footer-nuestra-empresa a:hover {
   color: #00ccff;
   transition: 0.5s ease;
 }

 /* ------------------------ */
 .footer-redes {
   width: 20%;
   margin: auto;
   margin-left: 1%;
   margin-right: 1%;
   margin-top: 1%;
   margin-bottom: 1%;
   display: flex;
   flex-direction: column;
   align-items: center;
   padding: 1%;
   padding-top: 2%;
   box-sizing: border-box;
   color: rgb(22, 56, 99);
 }

 .footer-redes h4 {
   margin-bottom: 2%;
   color: rgb(84, 81, 81);
 }

 .footer-redes a {
   margin-bottom: 2%;
   color: rgb(22, 56, 99);
   text-decoration: none;
 }

 .redes--subdiv {
   display: flex;
   width: 80%;
   margin: auto;
   margin-left: 25%;
 }

 .redes--subdiv img {
   margin-right: 5%;
   padding-bottom: 5%;

 }

 .footer-direccion {
   width: 100%;
   display: flex;
   flex-direction: column;
   align-items: center;
   box-sizing: border-box;
   color: rgb(22, 56, 99);
 }

 .footer-direccion span,
 p {
   color: rgb(22, 56, 99);

 }

 .footer-redes a:hover {
   color: #00ccff;
   transition: 0.5s ease;
 }

 /* --------------------------- */

 footer h4 {
   display: flex;
   width: 100%;
   justify-content: center;
   margin-top: 1%;
   margin-bottom: 1%;
 }

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

   .header {
     display: none;
   }

   .menu-nav {
     display: none;
   }

   .container-menu-responsive {
     display: flex;
     width: 100%;
     min-height: 50px;
     background-color: rgb(24, 24, 24);
     align-content: center;
     padding: 2px;
     position: fixed;
     top: 0;
     z-index: 1000;
     transition: all 0.8s ease-in-out;
     scroll-behavior: smooth;
   }

   .container-menu-responsive img {
     width: 10%;
     height: 50px;
     cursor: pointer;
     text-decoration: none;
   }

   .div-enlaces {
     position: absolute;
     top: 0px;
     left: 0px;
     display: none;
     flex-direction: column;
     width: 100%;
     height: 100vh;
     background-color: black;
     padding: 5px;
     animation-name: fx;
     animation-duration: 0.5s;
     transition: all 0.5s ease-in-out;
   }

   @keyframes fx {
     0% {
       left: -1000px;
     }

     100% {
       left: 0px;
     }
   }

   .div-enlaces a {
     background-color: rgb(10, 10, 10);
     width: 100%;
     padding: 4%;
     text-decoration: none;
     color: white;
     margin: 1px;
   }

   /* ------------------------------------------- */
   .operaciones-1 {
     width: 100%;
     margin: auto;
   }

   .div-info-operaciones {
     width: 100%;
   }

   .features-peajes {
     flex-direction: column;
     width: 100%;
   }

   .features-peajes img {
     width: 90%;
     margin: auto;
     margin-bottom: 10%;
   }

   .features-peajes div {
     width: 100%;
   }

   .features-peajes h2 {
     width: 100%;
     margin: auto;
     margin-bottom: 5%;
   }

   /* ------------------------------------- */
   .map {
     width: 90%;
   }


 }