@import url('https://fonts.googleapis.com/css2?family=Didact+Gothic&family=Raleway:wght@100..900&display=swap');
@import url(../vendor/bootstrap/css/bootstrap.css);
@import url(../vendor/fontawesome/css/all.min.css);
@import url(../vendor/owlcarousel/owl.carousel.css);
@import url(../vendor/owlcarousel/owl.theme.default.css);
@import url(../vendor/aos/aos.css);

html,
body {
  overflow-x: hidden;
}

/**/

body {
  font-family: "Didact Gothic", sans-serif;
  font-size: 1.2rem;
  --color-gray: #dbd9d9;
  --color-gray-dark: #3C3C3B;
  --color-black: #161e28;
  --color-primary: #2b3175;
  --color-secondary: #1669B1;
  --color-secondary-light: #35A8E0;
  --color-tertiary: #5FB9B8;
  --shadow-small: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px,
    rgba(0, 0, 0, 0.06) 0px 1px 2px 0px;
  --shadow-medium: rgba(0, 0, 0, 0.1) 0px 4px 6px -1px,
    rgba(0, 0, 0, 0.06) 0px 2px 4px -1px;
  --shadow-large: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px,
    rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  --shadow-extra: rgba(0, 0, 0, 0.1) 0px 20px 25px -5px,
    rgba(0, 0, 0, 0.04) 0px 10px 10px -5px;

}

.textsecondary {
  color: var(--color-secondary);
}


header {
  width: 100%;
  position: absolute;
  z-index: 2;
}


.btn-nav {
  background: var(--color-secondary);
  padding: 2% 5%;
  position: relative;
}

.btn-nav:before {
  content: "";
  top: 0;
  position: absolute;
  width: 100%;
  height: 100%;
  background: var(--color-secondary);
}

.btn-nav:hover {
  background: var(--color-black);
}


.btn-nav:hover:before {
  background: var(--color-black);
}

.btn-nav a {
  color: #ffffff !important;
}





header .head_nav ul {
  text-align: center;
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: space-around;
  justify-items: center;
  align-items: center;

}



header .head_nav ul li {
  display: inline-block;
  margin: 0 10px;
}

header .head_nav ul li a {
  display: inline-block;
  font-weight: 500;
  position: relative;
  color: #ffffff;
  text-decoration: none;
  font-size: 1em;
  padding: 40px 0;
  font-family: "Raleway", sans-serif;
}

header .head_nav ul li:hover a {
  color: var(--color-secondary-light);
}

header .redes-menu {
  text-align: center;
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: end;
  justify-items: center;
  align-items: center;

}

header .redes-menu li a {
  padding: 30px 10px;
  font-size: 1.4em;
  color: #ffffff;
}

header .redes-menu li a:hover {
  color: var(--color-tertiary);
}

.dot-size {
  font-size: .4rem;
}


header .mobile_nav {
  margin: 1px 10px 0;
  display: none;
}

header .mobile_nav .burger {
  width: 19px;
  height: 19px;
  position: relative;
  overflow: hidden;
}

header .mobile_nav .burger:active .top,
header .mobile_nav .burger:focus .top,
header .mobile_nav .burger:hover .top {
  width: 60% !important;
}

header .mobile_nav .burger:active .middle,
header .mobile_nav .burger:focus .middle,
header .mobile_nav .burger:hover .middle {
  width: 70% !important;
}

header .mobile_nav .burger:active .bottom,
header .mobile_nav .burger:focus .bottom,
header .mobile_nav .burger:hover .bottom {
  width: 80% !important;
}

header .mobile_nav .burger .mobile_nav__label {
  margin: -10px 5px;
  width: 135px;
  position: absolute;
}

header button,
header input {
  border: 0;
  background: 0;
  margin: 0;
  padding: 0;
}

header .mobile_nav .burger .stripe {
  height: 4px;
  background: #ffffff;
  position: absolute;
  transition: 0.2s ease;
}

header .mobile_nav .burger .top {
  right: 0;
  top: 0;
  width: 100%;
}

header .mobile_nav .burger .middle {
  left: 0;
  top: 0;
  margin: 6.9px 0;
  width: 60%;
}

header .mobile_nav .burger .bottom {
  right: 0;
  top: 0;
  margin: 14px 0;
  width: 80%;
}






header .icons .block {
  display: inline-block;
}

header .icons svg {
  display: block;
  transition: 0.2s ease;
}


.mobile_menu_adcof {
  background: var(--color-primary);
  width: 90%;
  height: 420px;
  top: 65px;
  left: 0;
  margin: 10px 20px;
  border-radius: 4px;
  position: absolute;
  z-index: 10;
  display: none;
}

.mobile_menu_adcof:before {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 15px 15px 15px;
  border-color: transparent transparent #000000 transparent;
  margin: -10px 35px;
}

.mobile_menu_adcof nav {
  padding: 50px;
}

.mobile_menu_adcof nav ul .slide a {
  opacity: 1;
  position: relative;
  animation: hidecolor 0.8s ease;
}

.mobile_menu_adcof nav ul .slide a:before {
  content: "";
  position: absolute;
  background: var(--color-secondary);
  width: 0%;
  height: 35px;
  animation: slide 0.8s ease;
}

.mobile_menu_adcof nav ul li {
  margin: 30px 0px;
}

.mobile_menu_adcof nav ul li a {

  opacity: 0;
  font-size: 25px;
  font-weight: 600;
  padding: 10px 0px;
  color: white;
  text-decoration: none;
}

header .logo .logoimg {
  width: 100px;
  margin-top: 5%;
}

@media only screen and (max-width: 1100px) {
  .mobile_menu_adcof {
    display: none;
  }


}

@media only screen and (max-width: 800px) {
  .mobile_menu_adcof {
    display: none;
  }

  header {
    padding: 0 50px;

  }




  header .head_nav {
    display: none;
  }

  header .logo {
    width: 100%;
    text-align: center;
  }



  header .mobile_nav {
    cursor: pointer;
    display: block !important;
    position: absolute;
    top: 40px;
    right: 30px;
  }

  header .mobile_nav .stripe {
    width: 100% !important;
  }


  .banner-carrusel {

    font-size: 1rem !important;


  }

  .banner-carrusel h2 {

    font-size: 2rem !important;
    line-height: 2rem !important;
  }



  .contactofooter {
    margin-top: 5%;
  }

}

@media only screen and (max-width: 500px) {
  header {
    padding: 0 20px;
  }

  header .logo {
    width: 60px;
    overflow: hidden;
  }


  .mobile_menu_adcof {
    height: 295px;
  }

  .mobile_menu_adcof:before {
    margin: -10px 5px;
  }

  .mobile_menu_adcof nav {
    padding: 30px 50px;
  }

  .mobile_menu_adcof nav ul li {
    margin: 20px 0px;
  }

  .mobile_menu_adcof nav ul li a {
    font-size: 18px;
  }

  .mobile_menu_adcof nav ul li a:before {
    height: 23px !important;
  }
}

@keyframes slide {
  0% {
    width: 0;
    padding: 0px 10px;
    margin: 0px -5px;
  }

  80% {
    width: 105%;
    padding: 0px 10px;
    margin: 0px -5px;
  }

  100% {
    width: 0;
    padding: 0 0;
  }
}

@keyframes hidecolor {
  0% {
    color: black;
  }

  75% {
    color: black;
  }

  100% {
    color: white;
  }
}



.banner {
  width: 100%;
  height: 100vh;
  background: url(../img/bg-blur2.jpg);
  background-position: bottom;
  background-size: cover;
  position: relative;
  overflow: hidden;
}


#HeroVideo {
  position: absolute;
  right: 0;
  bottom: 0;
  min-width: 100%;
  min-height: 100%;
  opacity: .2;
}





.inner-slide {
  margin: 20% auto 0 auto;
  width: 90%;
  max-width: 700px;
}

.banner-carrusel {


  color: #ffffff;
  font-size: 1.3rem;


}

.banner-carrusel h2 {
  font-weight: 400;
  margin-bottom: 20px;
  font-size: 2.5rem;
  font-family: "Raleway", sans-serif;
  line-height: 3rem;
}

.banner-carrusel p {
  text-align: justify;
  width: 100%;
  max-width: 500px;
}

.cta-consulting {
  background: #ffffff;
  padding: 10px 10px 10px 40px;
  border-radius: 30px;
  color: var(--color-primary);
  display: inline-block;
  margin-top: 10%;
  font-weight: 800;
  font-size: 1em;
  position: relative;
  z-index: 2;
}

.arrow-icon {

  margin-left: 30px;
}

.cta-consulting:hover {
  background: var(--color-secondary-light);
  color: #ffffff;
}

.bgsecondary {
  background: var(--color-secondary);
}

.textsecondary {
  color: var(--color-secondary);
}

.icon.bgsecondary {
  color: var(--color-gray);
}


.section {
  padding: 5% 0;
  background: aliceblue;
}

.section .container-90 {
  width: 80%;
  margin: auto;
}

.title {
  margin-top: 25%;
  display: block;

}

.title h2 {
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 800;
  font-size: 1em;
  display: flex;
  align-items: center;
  color: var(--color-primary);
  font-family: "Raleway", sans-serif;

}

.title .icon {
  font-size: 10px;
  margin-right: 30px;
  color: var(--color-secondary);
}

.img-rounded {
  width: 100%;
  border-radius: 10px;
}


.section h1,
.section h3 {
  font-size: 2em;
  font-family: "Raleway", sans-serif;


}

.bannernosotros {
  width: 100%;
  height: 450px;
  background: url(../img/nosotros-img.jpeg);
  background-size: cover;
  background-position: top;
  border-radius: 20px;
  margin-top: 5%;
}

.item-servicio {
  min-height: 650px;
  padding: 7%;
  border-radius: 20px;
  margin-top: 10%;
}

.item-servicio.childone {
  background: url(../img/servicio1.jpg);
  background-size: cover;
  color: #ffffff;
}



.item-servicio.childtwo {
  background: url(../img/servicio2.jpg);
  background-size: cover;
  color: #ffffff;
}

.item-servicio.childthree {
  background: url(../img/servicio3.jpg);
  background-size: cover;
  color: #ffffff;
}

.item-servicio.childfour {
  background: url(../img/servicio4.jpg);
  background-size: cover;
  color: #ffffff;
}



.item-servicio .icon {
  font-size: 2em;
}

.item-servicio .title-service {
  font-family: "Raleway", sans-serif;
  font-size: 1.3em;
  font-weight: 600;
  line-height: 1em;
  margin-top: 90%;
  margin-bottom: 5%;
  transition: all .4s;
  -moz-transition: all .4s;
}

.item-servicio .description-service {
  font-size: .9em;
}

.item-servicio:hover .title-service {

  margin-top: 70%;

}

.banner-servicios {
  background: url(../img/servicios-img.jpg);
  background-size: cover;
  padding: 5% 8%;
  margin-top: 5%;

}

.item-bubble {
  background: #ffffff;
  padding: 7% 5%;
  margin: 25% 10% 5% 10%;
  border-radius: 10px;
  font-size: 1em;
  line-height: 1em;
  font-weight: 700;
}

.item-bubble b {
  color: var(--color-secondary);
}

.mt-35 {
  margin-top: 40%;
}

.contacto {

  position: relative;
  padding-bottom: 0;

}

.content-contact {
  position: relative;
  z-index: 3;
}


.overlay {

  background: rgba(43, 49, 117, 0.9);
  position: absolute;
  width: 100%;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
}

.contacto a {
  text-decoration: none;
  color: var(--color-secondary-light);
  font-size: 1.2rem;

}

.contacto a.direccion {
  font-size: 1rem;
  line-height: .8rem !important;
}

.contacto b {
  color: var(--color-black);
  font-weight: 800;
  font-size: 1.3rem;
}

#contact-form {
  margin-top: 5%;
}

#contact-form input.form-control {
  height: 50px;
  font-size: .9rem;
  border-radius: 10px;
  border: none;
  margin-top: 10px;
  background: lightslategray;
  color: #ffffff;
}

#contact-form textarea.form-control {

  font-size: .9rem;
  border-radius: 10px;
  border: none;
  background: lightslategray;
  color: #ffffff;
}

/* Estándar moderno */
input::placeholder {
  color: #fffefe !important;
  opacity: 1;
  /* Necesario en Firefox */
}

/* Compatibilidad antigua */
input::-webkit-input-placeholder {
  color: #ffffff;
}

/* Chrome/Safari/Opera */
input::-moz-placeholder {
  color: #ffffff;
}

/* Firefox 19+ */
input:-ms-input-placeholder {
  color: #ffffff;
}

/* IE 10+ / Edge */

#contact-form label {
  font-size: 1rem;
  font-weight: 800;
}

#contact-form label.error {
  background: rgb(211, 71, 71);
  color: #1a1a1a;
  font-size: .8rem;
  border-radius: 10px;
  padding: 1px 10px;
}

#contact-form .btn-form {
  margin-top: 5%;
  background: var(--color-primary);
  color: #ffffff;
  padding: 10px 30px;
  border: none;
  border-radius: 30px;
  text-transform: uppercase;
  font-weight: 700;
}

#contact-form .btn-form:hover {
  background: var(--color-secondary-light);
}

.redesfooter {
  margin-top: 10%;
}

.banner-footer {
  background: url(../img/banner-footer.jpg);
  background-size: cover;
  height: 450px;
  background-position: center;
  margin-top: 10%;
}

footer {
  background: url(../img/bg-blur2.jpg);
  background-size: cover;
  background-position: center;
  padding: 1% 0;
  color: #c5c5c5;
}

footer a {
  color: #ffffff;
  text-decoration: none;
}

footer a i {
  color: var(--color-secondary-light);
}

footer a:hover {
  color: var(--color-tertiary);
}

.firma {
  font-size: .9rem;
}

.min-vh-90 {
  min-height: 88vh;
}

@media (max-width: 1370px) {


  .item-servicio {
    min-height: 450px;

  }

  .item-servicio .title-service {
    margin-top: 50%;
  }


}

@media (max-width: 797px) {}

@media (max-width: 550px) {

  .inner-slide {
    margin-top: 50%;
  }

  .item-servicio {
    min-height: 300px;

  }

  .item-bubble {
    margin: 5%;
  }

  .logoimg {
    width: 120px !important;
    margin-left: 5px;
  }

  .redes-menu {
    margin-right: 50px !important;
  }

}