@font-face {
  font-family: 'Avenir Next';
  src: url("../fonts/AvenirNext-Bold.woff2") format("woff2"), url("../fonts/AvenirNext-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Demi';
  src: url("../fonts/AvenirNext-DemiBold.woff2") format("woff2"), url("../fonts/AvenirNext-DemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next';
  src: url("../fonts/AvenirNext-Heavy.woff2") format("woff2"), url("../fonts/AvenirNext-Heavy.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next';
  src: url("../fonts/AvenirNext-Regular.woff2") format("woff2"), url("../fonts/AvenirNext-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next';
  src: url("../fonts/AvenirNext-Medium.woff2") format("woff2"), url("../fonts/AvenirNext-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed Demi';
  src: url("../fonts/AvenirNextCondensed-DemiBold.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-DemiBold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed';
  src: url("../fonts/AvenirNextCondensed-Heavy.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-Heavy.woff") format("woff");
  font-weight: 900;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed';
  src: url("../fonts/AvenirNextCondensed-Bold.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-Bold.woff") format("woff");
  font-weight: bold;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed';
  src: url("../fonts/AvenirNextCondensed-Medium.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-Medium.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed';
  src: url("../fonts/AvenirNextCondensed-Regular.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap; }

@font-face {
  font-family: 'Avenir Next Condensed Ultra';
  src: url("../fonts/AvenirNextCondensed-UltraLight.woff2") format("woff2"), url("../fonts/AvenirNextCondensed-UltraLight.woff") format("woff");
  font-weight: 200;
  font-style: normal;
  font-display: swap; }
.cat-links{
  background-color: #273552;
  border-radius: 3px;
  padding: 1px 5px;
  font-size: 14px;
}
.cat-links a { color: #fff;}
* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility; }

button, a, input {
  outline: none !important;
  box-shadow: none !important; }

body {
  padding: 33px 0 0 0;
  margin: 0;
  font-size: 12px;
  font-family: "Avenir Next"; }

.clear {
  clear: both; }

h1, h2, h3, h4, h5, p, ul, li {
  padding: 0;
  margin: 0; }

li {
  list-style: none; }

a, a:hover {
  text-decoration: none;
  outline: none; }

a {
  outline: none !important; }

.left {
  float: left; }

.right {
  float: right; }

.clear {
  clear: both; }

.trans, .fotohome .botondemo, .botondemo, .fotohome .botonvideo, .funciones a, .servicio a, .contacto input[type="submit"],
.contacto input[type="button"], .contacto .col-md-5 .mail, .contacto2 input[type="submit"], .contacto2 input[type="button"],
footer .col2 ul li a, header .ingresar, .oficinas a, .login .box input[type="submit"], .login .box input[type="button"], #butlogin,
.blog .datos ul li a, .modal input[type="submit"], .modal input[type="button"], .modal1 input[type="submit"],
.modal1 input[type="button"], .modal2 input[type="submit"], .modal2 input[type="button"] {
    -moz-transition: all 0.3s ease-in;
    -webkit-transition: 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}

.fotohome {
  padding-bottom: 70px;
  padding-top: 45px;
  background-image: url(../img/header.jpg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center right;
  max-width: 1400px;
  margin: 0 auto; }
  .fotohome .barrita {
    width: 22px;
    height: 2px;
    background-color: #1f2b45;
    margin-bottom: 15px; }
  .fotohome h2 {
    color: #3cc5be;
    font-size: 33px;
    margin-top: 45px;
    font-weight: 500; }
  .fotohome h1 {
    color: #1f2b45;
    font-size: 60px;
    margin: 0 0 33px 0;
    font-weight: bold;
    line-height: 57px;
    margin-top: 15px; }
  .fotohome p {
    font-size: 15px;
    color: #1f2b45;
    padding-bottom: 45px; }
  .fotohome .botondemo, .botondemo {
    padding: 10px 15px 10px 15px;
    border-radius: 9px;
    background-color: #3cc5be;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    }
  .fotohome .botondemo:hover, .botondemo:hover {
    background-color: #1f2b45;
    color: #fff;
    }
  .fotohome .botonvideo {
    color: #3cc5be;
    font-size: 16px;
    font-weight: 500;
    margin-left: 15px;
    }
  .fotohome .botonvideo:hover {
    color: #1f2b45; }

.franjaazul {
  padding: 15px;
  text-align: center;
  color: #fff;
  background-color: #1f2b45;
  font-size: 22px;
  margin-bottom: 45px; }
  .franjaazul .bold {
    font-weight: bold; }

.iconos {
  padding-bottom: 33px; }
  .iconos img {
    display: block;
    margin: 0px auto auto auto; }
  .iconos h1 {
    color: #1f2b45;
    text-align: center;
    margin-top: 0px;
    font-size: 20px;
    font-weight: bold; }
  .iconos p {
    color: #1f2b45;
    font-size: 14px;
    line-height: 22px;
    text-align: center; }
    .iconos p span {
      display: block; }

.funciones {
  padding: 45px;
  background-color: #f2f1f6;
  color: #1f2b45;
  margin-top: 45px; }
  .funciones .barrita {
    width: 22px;
    height: 2px;
    background-color: #1f2b45;
    margin-bottom: 15px; }
  .funciones p.title {
    font-size: 33px;
    text-align: center;
    margin-bottom: 45px;
    font-weight: 500;
    line-height: 1.2;
  }
  .funciones h2 {
    font-size: 20px;
    font-weight: bold;
    margin: 9px 0 9px 0; }
  .funciones p {
    font-size: 14px;
    margin-bottom: 33px; }
  .funciones a {
    width: 251px;
    text-align: center;
    color: #fff;
    border-radius: 15px;
    padding: 12px;
    display: block;
    background-color: #3cc5be;
    font-size: 16px;
    font-weight: 500;
    margin: 45px auto auto auto; }
  .funciones a:hover {
    background-color: #1f2b45; }

.carouselopinion .item {
  padding: 45px; }

.opinion .logo {
  display: block;
  margin: auto auto 15px auto;
  max-height: 70px; }

.opinion p {
  font-size: 14px;
  text-align: center;
  color: #1f2b45;
  min-height: 200px; }

.opinion .foto {
  display: block;
  margin: 15px auto auto auto; }

.opinion h3 {
  font-size: 16px;
  color: #1f2b45;
  text-align: center;
  font-weight: bold;
  padding-top: 6px; }

.opinion h4 {
  font-size: 14px;
  color: #1f2b45;
  text-align: center; }

.servicio {
  padding: 45px; }
  .servicio p.title {
    color: #1f2b45;
    font-size: 26px;
    font-weight: 500;
    line-height: 1.2;
  }
  .servicio h2 {
    color: #3cc5be;
    font-size: 18px;
    margin-bottom: 33px; }
  .servicio h3 {
    color: #1f2b45;
    font-size: 18px;
    margin-bottom: 6px;
    font-weight: bold; }
  .servicio p {
    color: #1f2b45;
    font-size: 14px; }
  .servicio ul li {
    margin-bottom: 33px;
    padding-left: 45px;
    position: relative; }
    .servicio ul li i {
      position: absolute;
      top: 0;
      left: 0;
      color: #3cc5be;
      font-size: 33px; }
  .servicio a {
    width: 276px;
    text-align: center;
    color: #fff;
    border-radius: 15px;
    padding: 12px;
    display: block;
    font-size: 16px;
    font-weight: 500;
    background-color: #3cc5be;
    margin: 45px auto auto auto;
    }
  .servicio a:hover {
    background-color: #1f2b45; }
  .servicio .fotomobile {
    display: none; }
  .servicio img {
    max-width: 90%;
    display: block;
    margin: auto; }

.clientes {
  padding: 45px;
  background-color: #f2f1f6; }
  .clientes .carouselclientes {
    text-align: center; }
  .clientes .item {
    display: inline-block;
    width: 13%;
    margin: 15px 15px 33px 15px; }
    .clientes .item img {
      width: 100%; }
  .clientes p.title {
    color: #1f2b45;
    text-align: center;
    font-size: 28px;
    padding-top: 15px;
    margin-bottom: 15px;
    font-weight: 500;
    line-height: 1.2;
  }

  .contacto h1 {
    color: #1f2b45;
    font-size: 26px;
    font-weight: bold;
    margin-bottom: 3px;
    text-align: center;
    }
  .contacto p span {
    display: block; }
  .contacto input[type="text"], .contacto input[type="email"], .contacto textarea {
    border: none;
    border-bottom: solid 1px #1f2b45;
    font-size: 15px;
    color: #1f2b45;
    background-color: transparent;
    margin-bottom: 6px;
    /* font-weight: bold; */
    padding: 0 10px 30px 10px;
    width: 100%;
    }
  .contacto input::placeholder, .contacto textarea {
    /* color: #1f2b45; */
    opacity: 1;
    }
  .contacto input[type="submit"], .contacto input[type="button"] {
    background-color: #3cc5be;
    color: #fff;
    border-radius: 15px;
    border: none;
    float: right;
    padding: 10px 20px 7px 20px; }
  .contacto input[type="submit"]:hover, .contacto input[type="button"]:hover {
    background-color: #1f2b45; }
  .contacto .col-md-5 .tel {
    margin: 15px 0 4px 0;
    color: #1f2b45;
    font-size: 14px;
    font-weight: 600; }
    .contacto .col-md-5 .tel i {
      font-size: 20px;
      float: left;
      margin-top: 7px; }
  .contacto .col-md-5 .mail {
    font-weight: 600;
    padding-left: 26px;
    font-size: 15px;
    color: #1f2b45; }
  .contacto .col-md-5 .mail:hover {
    color: #3cc5be; }
  .contacto .dropdown-menu {
    background-color: #f2f1f6;
    font-size: 14px; }
  .contacto .btn {
    font-size: 14px;
    font-weight: 600; }

.contacto2 {
  background-color: #f2f1f6;
  padding: 65px;
  margin-top: 45px; }
  .contacto2 h1 {
    color: #1f2b45;
    font-size: 51px;
    font-weight: bold;
    margin-bottom: 43px; }
  .contacto2 p {
    font-size: 14px; }
    .contacto2 p span {
      display: block; }
  .contacto2 input[type="text"], .contacto2 input[type="email"], .contacto2 textarea {
    border: none;
    border-bottom: solid 1px #1f2b45;
    font-size: 15px;
    color: #1f2b45;
    background-color: transparent;
    margin-bottom: 6px;
    font-weight: bold;
    padding: 0 10px 30px 10px;
    width: 100%; }
  .contacto2 input::placeholder, .contacto2 textarea::placeholder {
    color: #1f2b45;
    opacity: 1; }
  .contacto2 input[type="submit"], .contacto2 input[type="button"] {
    background-color: #3cc5be;
    color: #fff;
    margin-top: 33px;
    border-radius: 15px;
    border: none;
    float: right;
    padding: 10px 20px 7px 20px; }
  .contacto2 input[type="submit"]:hover, .contacto2 input[type="button"]:hover {
    background-color: #1f2b45; }
  .contacto2 .col-md-5 .tel {
    margin: 15px 0 4px 0;
    color: #1f2b45;
    font-size: 15px;
    font-weight: 600;
    width: 330px;
    }
    .contacto2 .col-md-5 .tel i {
      font-size: 24px;
      float: left;
      margin-bottom: 260px;
      margin-right: 11px;
      margin-top: 3px;
      }
  .contacto2 .col-md-5 .email {
    margin: 15px 0 4px 0;
    color: #1f2b45;
    font-size: 15px;
    font-weight: 600;
    width: 225px;
    }
    .contacto2 .col-md-5 .email i {
      font-size: 20px;
      float: left;
      margin-bottom: 45px;
      margin-right: 11px;
      margin-top: 1px;
      }
    .contacto2 .col-md-5 .email a, .contacto2 .col-md-5 .tel a {
      color: #1f2b45;
      display: inline-block;
      font-weight: 400;
      margin-bottom: 5px;
      }
    .contacto2 .col-md-5 .email a:hover, .contacto2 .col-md-5 .tel a:hover {
      color: #3cc5be; }
  .contacto2 .pad {
    padding-top: 90px;
    }
  .contacto2 .btn {
    font-size: 14px;
    outline: none !important; }
  .contacto2 .dropdown-menu {
    background-color: transparent;
    font-size: 14px; }

footer {
  background-color: #1f2b45;
  padding: 45px 0 60px 0;
  }
  footer ul li a {
    color: #fff;
  }
  footer ul li a:hover {
    color: #3cc5be;
  }
  footer .col1 {
    color: #fff;
    padding-top: 6px; }
  footer .col2 ul {
    text-align: right;
    padding-bottom: 3px; }
    footer .col2 ul li {
      display: inline-block;
      width: 30px;
      height: 20px;
      text-align: center; }
      footer .col2 ul li a {
        display: block;
        border-radius: 33px;
        background-color: #fff;
        color: #1f2b45;
        padding: 3px 6px 3px 6px;
        font-size: 16px; }
      footer .col2 ul li a:hover {
        background-color: #3cc5be;
        color: #fff; }

.carouselhome1 {
  height: 600px;
  position: absolute;
  top: 0;
  height: 100vh;
  width: 100%;
  z-index: 99; }

.slick-vertical .slick-slide {
  height: 90vh !important; }

.slick-dots {
  position: absolute;
  bottom: 0px;
  left: 0;
  right: 0;
  width: 100%;
  text-align: center; }
  .slick-dots li {
    display: inline-block;
    margin-left: 16px; }
    .slick-dots li button {
      border: none;
      padding: 5px;
      background-color: rgba(0, 0, 0, 0.4);
      color: transparent;
      width: 12px;
      height: 12px;
      border-radius: 60px; }
  .slick-dots .slick-active button {
    background-color: #1f2b45; }

#offmenu {
  left: 0; }

header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff;
  z-index: 9999; }
  header ul {
    padding-top: 28px; }
    header ul li {
      display: inline-block;
      margin: 0 15px 0 0; }
      header ul li a {
        color: #1f2b45;
        font-size: 15px; }
      header ul li a:hover {
        color: #3cc5be; }
  header .col3 {
    padding-top: 20px;
    text-align: right; }
  header .ingresar {
    padding: 10px 33px 10px 33px;
    color: #fff;
    font-weight: 600;
    border-radius: 6px;
    background-color: #3cc5be; }
  header .ingresar:hover {
    background-color: #1f2b45; }
  header .btn {
    font-weight: 600;
    margin-right: 15px;
    outline: none !important; }
  header .dropdown-menu {
    min-width: 5rem;
    padding: 0;
    font-weight: 600;
    color: #1f2b45; }
  header .dropdown-item {
    font-weight: 600;
    color: #1f2b45; }

.logomobile {
  display: none; }

.headermobile {
  display: none; }

.fotohome h1 {
  font-size: 51px;
  line-height: 51px; }

.iconomobile {
  display: none; }

.nosotros {
  padding: 50px;
  }
  .nosotros h1 {
    color: #1f2b45;
    font-size: 63px;
    text-align: center;
    font-weight: 600; }
  .nosotros p {
    color: #1f2b45;
    font-size: 16px;
    text-align: left; }
    .nosotros p span {
      display: block; }
  .nosotros h2 {
    color: #1f2b45;
    font-size: 20px;
    text-align: center;
    margin: 40px 0 10px;
    }
  .nosotros h3 {
    color: #1f2b45;
    font-size: 18px;
    font-weight: 600;
    text-align: center; }
  .nosotros h4 {
    color: #1f2b45;
    font-size: 18px;
    font-weight: 600;
    text-align: left; }
  .nosotros .col-md-4 img {
    display: block;
    margin: auto; }

.mapa {
  background-image: url(../img/mapa.jpg);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  position: relative;
  height: 600px; }
  .mapa .paises {
    position: absolute;
    top: 122px;
    right: 0;
    background-color: #fff;
    border-radius: 33px;
    padding: 33px;
    width: 600px; }
    .mapa .paises ul {
      text-align: center; }
      .mapa .paises ul li {
        display: inline-block;
        width: 48%;
        text-align: left;
        padding-bottom: 4px;
        font-weight: 500;
        font-size: 15px; }
        .mapa .paises ul li img {
          margin-right: 4px; }
  .mapa .container {
    position: relative; }

.nomargin {
  margin-bottom: 0 !important; }

.oficinas {
  padding: 15px 0 60px 0; }
  .oficinas h1 {
    color: #1f2b45;
    font-size: 32px;
    text-align: center;
    margin-bottom: 45px; }
  .oficinas h4 {
    color: #1f2b45;
    font-size: 20px;
    text-align: center;
    }
.oficinas div.oficina {
    text-align: center;
}
  .oficinas a {
    width: 276px;
    text-align: center;
    color: #fff;
    border-radius: 15px;
    padding: 12px;
    display: block;
    background-color: #3cc5be;
    font-size: 16px;
    font-weight: 500;
    margin: 45px auto auto auto;
    }
  .oficinas a:hover {
    background-color: #1f2b45; }

.blog {
  padding: 60px 0 60px 0; }
  .blog h1 {
    color: #1f2b45;
    font-weight: bold;
    font-size: 33px;
    border-bottom: solid 3px #1f2b45;
    padding-bottom: 4px;
    margin-bottom: 45px; }
  .blog .link {
    color: #1f2b45;
    font-size: 20px;
    font-weight: bold; }
  .blog .item {
    margin-bottom: 33px; }
    .blog .item p {
      color: #1f2b45;
      font-size: 14px;
      margin-top: 15px; }
    .blog .item img {
      float: left;
      margin-right: 16px;
      max-width: 200px; }
  .blog .datos {
    padding: 15px 0 15px 0;
    border-bottom: solid 1px #273552;
    clear: both;
    }
    .blog .datos ul li {
      display: inline-block;
      margin-right: 14px;
      font-size: 14px;
      color: #1f2b45;
      border-right: solid 1px #1f2b45;
      padding-right: 14px; }
      .blog .datos ul li span {
        font-weight: bold; }
      .blog .datos ul li a {
        background-color: #3cc5be;
        color: #fff;
        padding: 6px 15px 6px 15px;
        border-radius: 15px; }
        .blog .datos ul li a:hover {
            background-color: #1f2b45; }
    .blog .datos ul li:last-child {
      border: none; }
  .blog .container {
    padding-left: 26px; }
  .blog .aside {
    padding-top: 33px;
    padding-left: 33px; }
    .blog .aside .gris {
      background-color: #f2f1f6;
      padding: 20px; }
    .blog .aside h2 {
      color: #3cc5be;
      font-weight: bold;
      font-size: 20px;
      margin-bottom: 15px; }
    .blog .aside .pad {
      padding-top: 33px; }
    .blog .aside a {
      color: #1f2b45;
      font-size: 14px; }
    .blog .aside a:hover {
      color: #3cc5be; }
    .blog .aside .cats li {
      padding-bottom: 4px; }
    .blog .aside .cats a {
      font-weight: bold; }
    .blog .aside .entradas li {
      padding-bottom: 3px; }
      .blog .aside .entradas li a {
        font-weight: 500; }

.login {
  background-color: #f2f1f6;
  padding: 120px 0 150px;
  }
  .login .box {
    width: 450px;
    padding: 20px;
    margin: auto;
    border-radius: 15px;
    background-color: #fff;
    -webkit-box-shadow: 3px 3px 6px 0px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 3px 3px 6px 0px rgba(0, 0, 0, 0.75);
    box-shadow: 3px 3px 6px 0px rgba(0, 0, 0, 0.75); }
    .login .box h1 {
      color: #1f2b45;
      text-align: center;
      font-size: 33px;
      margin-bottom: 15px;
      font-weight: bold; }
    .login .box input[type="email"], .login .box input[type="password"], .login .box input[type="text"] {
      border: none;
      background-size: 20px;
      border-bottom: solid 1px #1f2b45;
      font-size: 15px;
      padding: 6px 6px 14px 6px;
      color: #1f2b45;
      font-weight: bold;
      margin-bottom: 14px;
      width: 100%; }
    .login .box input::placeholder {
      color: #1f2b45;
      opacity: 1; }
    .login .box .pass {
      text-align: right; }
      .login .box .pass a {
        color: rgba(0, 0, 0, 0.4);
        font-weight: bold;
        padding-bottom: 14px; }
      .login .box .pass a:hover {
        color: #1f2b45; }
    .login .box .recordar {
      font-weight: bold;
      color: #1f2b45;
      font-size: 14px;
      padding: 9px 0 9px 0;
      vertical-align: middle;
      -webkit-user-select: none; /* Safari */
      -moz-user-select: none; /* Firefox */
      -ms-user-select: none; /* IE10+/Edge */
      user-select: none; /* Standard */
      }
      .login .box .recordar input[type="checkbox"] {
          margin-right: 4px;
          float: left;
          width: 20px;
          height: 20px;
      }
      .login .box .login-btn {
        text-align: center;
      }
    .login .box input[type="submit"], .login .box input[type="button"], #butlogin {
      background-color: #3cc5be;
      color: #fff;
      border-radius: 9px;
      padding: 10px 15px 10px 15px;
      display: block;
      margin: 10px auto auto auto;
      border: none;
      font-size: 15px;
      }
    .login .box input[type="submit"]:hover, .login .box input[type="button"]:hover, #butlogin:hover {
      background-color: #1f2b45; }
    .login .box .email {
      background-image: url(../img/iconousuario.png);
      background-repeat: no-repeat;
      background-position: 95%; }
    .login .box .contrasena {
      background-image: url(../img/iconocandado.png);
      background-repeat: no-repeat;
      background-position: 95%; }
    .login .box .texto {
      text-align: center;
      font-size: 12px;
      padding: 9px 0 20px 0;
      line-height: 16px; }

@media (max-width: 1024px) {
  header {
    position: relative; }
    header .col-md-4 {
      max-width: 100%;
      flex: auto; }
  header .ingresar {
    display: block;
    width: 145px;
    text-align: center;
    margin-top: 20px; }
  header .col3 {
    padding-top: 20px !important; }
  .logomobile {
    display: block;
    position: absolute;
    top: 0;
    left: 57px; }
  header .col1 img {
    margin-left: 92px; }
  .fotohome {
    background-image: none;
    padding-top: 0;
    }
    .fotohome .col-md-6 {
      max-width: 100%; }
  .headermobile {
    display: block;
    max-height: 380px;
    margin: 22px auto 0;
    }
  header ul {
    padding-left: 69px; }
    header ul li {
      display: block;
      margin-bottom: 15px; }
  header .col3 {
    text-align: left;
    padding-left: 85px; }
  .iconomobile {
    display: block; }
  body.noScrollbar {
    overflow: hidden; }
  body.offset-menu-active {
    position: relative;
    overflow: hidden;
    transform: translate3d(95%, 0, 0);
    -webkit-transform: translate3d(95%, 0, 0);
    -moz-transform: translate3d(95%, 0, 0);
    -o-transform: translate3d(95%, 0, 0); }
    body.offset-menu-active #push {
      left: -90%; }
  #offmenu {
    left: -100%;
    position: absolute;
    top: 0;
    width: 100%;
    position: absolute;
    z-index: 100;
    height: 100%;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box; }
  .offset-menu-animation {
    -webkit-transition: all 400ms ease-out;
    -moz-transition: all 400ms ease-out;
    -o-transition: all 400ms ease-out;
    transition: all 400ms ease-out; }
  .box {
    width: 100%; }
  #push {
    font-size: 33px;
    position: absolute;
    top: 0px;
    left: 14px;
    right: 0;
    margin: 0 auto;
    cursor: pointer;
    z-index: 9999999; }
  #push:hover {
    color: #1f2b45; } }

@media (max-width: 768px) {
  .iconos .col-md-4 {
    max-width: 100%;
    flex: auto; }
  .iconos h1 {
    margin-top: 0; }
  .contacto2 {
    padding: 15px; }
  .contacto {
    padding: 45px 15px 45px 15px; } }

@media (max-width: 560px) {
  .clientes {
    padding: 15px;
    text-align: center; }
    .clientes img {
      width: 100px;
      margin: 15px;
      display: inline-block !important; }
  .fotohome h1 {
    font-size: 35px; }
    .fotohome .barrita {
        display: none
    }
  .fotohome .botonvideo {
        display: none
    }
  .fotohome .botondemo {
    display: block;
    width: 200px;
    margin-bottom: 15px; }
  .franjaazul {
    padding: 45px; }
    .franjaazul .enter {
      display: block; }
  .iconos img {
    width: 145px; }
  .iconos h1 {
    margin-top: 0; }
  .funciones {
    padding: 45px 15px 45px 15px; }
  .funciones h1 {
    font-size: 28px; }
  .servicio {
    padding: 33px 15px 15px 15px; }
    .servicio .fotodesktop {
      display: none; }
    .servicio .fotomobile {
      display: block;
      margin-bottom: 45px; }
    .servicio a {
      display: none; }
    .servicio h2 span {
      display: block; }
  .contacto {
    padding: 45px 15px 45px 15px; }
    .contacto p {
      padding-bottom: 33px; }
  .contacto input[type="submit"], .contacto input[type="button"] {
    float: left; }
  footer .col1 span {
    display: block; }
  footer .col2 ul {
    text-align: left;
    padding-bottom: 15px;
    padding-top: 6px; }
  .contacto .col-md-7 {
    padding-top: 33px; }
  .fotohome {
    padding-bottom: 33px; }
  .nosotros {
    padding: 45px; }
  .nosotros h1 {
    font-size: 36px; }
  .nosotros p span {
    display: inline; }
  .mapa .paises {
    width: 95%;
    margin: auto;
    left: 0;
    right: 0;
    padding: 15px;
    border-radius: 15px;
    height: auto;
    top: 79px; }
    .mapa .paises ul li {
      font-size: 13px; }
  .mapa {
    height: 450px; }
  header .col1 img {
    margin-left: 57px; }
  .blog .item img {
    max-width: 100%;
    margin-bottom: 15px; }
  .blog .datos ul li {
    display: block;
    border: none; }
  .blog .datos ul li:last-child {
    padding-top: 15px; }
  .blog .aside {
    padding: 15px; }
    .blog .aside .gris {
      padding: 20px; }
  .login {
    margin-top: 29px;
    padding-top: 45px; }
  .login .box {
    width: 90%; }
  .login .box .texto {
    font-size: 15px; }
  .login .box h1 {
    font-size: 26px; } }

#nav-icon1, #nav-icon2, #nav-icon3, #nav-icon4 {
  width: 55px;
  height: 36px;
  position: relative;
  margin: 9px 0 0 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
  cursor: pointer; }

#nav-icon1 span, #nav-icon3 span, #nav-icon4 span {
  display: block;
  position: absolute;
  height: 3px;
  width: 33px;
  background: #1f2b45;
  border-radius: 16px;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out; }

#nav-icon1 span:nth-child(1) {
  top: 12px; }

#nav-icon1 span:nth-child(2) {
  top: 22px; }

#nav-icon1 span:nth-child(3) {
  top: 32px; }

#nav-icon1.open span:nth-child(1) {
  top: 28px;
  -webkit-transform: rotate(135deg);
  -moz-transform: rotate(135deg);
  -o-transform: rotate(135deg);
  transform: rotate(135deg); }

#nav-icon1.open span:nth-child(2) {
  opacity: 0;
  left: -60px; }

#nav-icon1.open span:nth-child(3) {
  top: 28px;
  -webkit-transform: rotate(-135deg);
  -moz-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  transform: rotate(-135deg); }

.modal-header {
    height: 0;
    padding: 1rem;
    border: none;
}

.modal1 .pad {
    padding: 0 1rem 1.5rem;
}

    .modal1 .pad h1 {
        color: #1f2b45;
        font-weight: 700;
        text-align: center;
        margin-bottom: 10px;
        font-size: 26px;
    }

    .modal1 .pad p {
        text-align: center;
        color: #3cc5be;
        font-weight: 400;
    }

    .modal1 .pad input[type="text"],
    .modal1 .pad input[type="email"],
    .modal1 .pad textarea {
        border: none;
        margin-bottom: 10px;
        width: 100%;
        border-bottom: solid 1px #1f2b45;
        padding: 10px;
        color: #1f2b45;
        font-size: 15px;
        min-height: 43px;
        max-height: 250px;
    }

    .modal1 .pad input[type="submit"],
    .modal1 .pad input[type="button"] {
        background-color: #3cc5be;
        color: #fff;
        display: block;
        margin: 0.6rem auto auto;
        border-radius: 9px;
        padding: 10px 33px 10px 33px;
        border: none;
        font-size: 16px;
    }

        .modal1 .pad input[type="submit"]:hover,
        .modal1 .pad input[type="button"]:hover {
            background-color: #1f2b45;
        }

.modal2 .pad {
    padding: 0 33px 33px 33px;
}

    .modal2 .pad h1 {
        color: #1f2b45;
        font-weight: 700;
        text-align: center;
        margin-bottom: 10px;
        font-size: 26px;
    }

    .modal2 .pad p {
        color: #9d9d9d;
        font-size: 14px;
    }

    .modal2 .pad strong {
        font-weight: 700;
    }

    .modal2 .pad h2 {
        margin-top: 20px;
        color: #1f2b45;
        margin-bottom: 10px;
        font-size: 16px;
    }

.modal2 .pad2 {
    overflow-x: scroll;
    height: 500px;
}

.modal3 .pad {
    padding: 0 33px 33px 33px;
}

    .modal3 .pad h1 {
        color: #1f2b45;
        font-weight: 700;
        text-align: center;
        margin-bottom: 10px;
        font-size: 26px;
    }

    .modal3 .pad p {
        text-align: center;
        margin-bottom: 33px;
        color: #3cc5be;
        font-weight: 400;
    }

        .modal3 .pad p span {
            font-weight: 700;
        }

    .modal3 .pad input[type="text"],
    .modal3 .pad input[type="email"],
    .modal3 .pad textarea {
        border: none;
        margin-bottom: 10px;
        width: 100%;
        border-bottom: solid 1px #9d9d9d;
        padding: 10px;
        color: #9d9d9d;
    }

    .modal3 .pad input[type="submit"],
    .modal3 .pad input[type="button"] {
        background-color: #3cc5be;
        color: #fff;
        display: block;
        margin: auto;
        border-radius: 9px;
        padding: 10px 33px 10px 33px;
        border: none;
    }

        .modal3 .pad input[type="submit"]:hover,
        .modal3 .pad input[type="button"]:hover {
            background-color: #1f2b45;
        }

.modal3 .pad2 {
    overflow-x: scroll;
    height: 500px;
}

.modal4 .pad {
    padding: 0 33px 33px 33px;
}

    .modal4 .pad h1 {
        color: #1f2b45;
        font-weight: 700;
        text-align: center;
        margin-bottom: 10px;
        font-size: 26px;
    }

        .modal4 .pad h1 span {
            font-weight: 700;
        }

    .modal4 .pad p {
        text-align: center;
        margin-bottom: 33px;
        font-size: 14px;
        color: #9d9d9d;
        font-weight: 400;
    }

        .modal4 .pad p span {
            font-weight: 700;
        }

    .modal4 .pad a {
        color: #9d9d9d;
        text-decoration: underline;
    }

        .modal4 .pad a:hover {
            text-decoration: none;
        }

.modal4 img {
    display: block;
    margin: auto;
}

.modal-dialog {
    margin-top: 145px;
    width: 620px;
    max-width: none;
}

@media (max-width: 600px) {
    .modal-dialog {
        width: auto;
    }
}

footer {
    color: #fff;
}

.validity-modal-msg {
    font-size: 12px;
    position: absolute;
    z-index: 500;
    background-color: #000;
    border: 1px solid #000;
    cursor: pointer;
    opacity: 0.85;
    height: 18px;
    color: white;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    border-radius: 4px;
    padding: 2px 8px;
    box-sizing: content-box;
}

