:root {
  --blanco: #fff;
  --verde1: #579526;
  --negro: #1a1a1a;
  --transparent: #0000;
  --acento-1: #f5f6f6;
  --white: white;
  --gris: #979797;
  --acento-2: #172706;
}

.w-form-formrecaptcha {
  margin-bottom: 8px;
}

h1 {
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1em;
}

h2 {
  text-transform: uppercase;
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1em;
}

p {
  margin-bottom: 10px;
  font-size: .9rem;
  line-height: 1.5em;
}

img {
  max-width: 100%;
  display: inline-block;
}

.slider_hero {
  width: 100%;
  height: 100vh;
}

.navbar {
  background-color: #ddd0;
  width: auto;
  max-width: 100%;
  display: flex;
  position: fixed;
  inset: 0% 0% auto;
}

.cont_texto_hero {
  flex-wrap: wrap;
  align-content: flex-start;
  align-items: flex-start;
  width: 80%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 60px;
  display: flex;
  position: absolute;
  inset: auto 0% 0%;
}

.menu_principal {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  padding-left: 10%;
  padding-right: 10%;
  display: flex;
  position: relative;
}

.h1_hero {
  color: var(--blanco);
  width: 100%;
  margin-bottom: 30px;
  margin-left: -5px;
  padding-left: 0;
  font-family: Open Sans, sans-serif;
  font-size: 4rem;
  font-weight: 800;
  line-height: 1em;
}

.span_titulo {
  color: var(--verde1);
}

.parrafo_hero {
  color: var(--blanco);
  width: 50%;
  margin-right: 20px;
}

.btn_hero {
  background-color: #3898ec00;
  border: 2px solid #fff;
  border-radius: 0;
  padding: 10px 20px;
  font-size: .8rem;
}

.btn_hero:hover {
  background-color: var(--blanco);
  color: var(--negro);
}

.slide-nav {
  bottom: 100px;
  left: auto;
  right: 10%;
}

.left-arrow, .right-arrow {
  display: none;
}

.logotipo_header {
  width: auto;
  height: 60px;
  margin-top: 10px;
  margin-bottom: 10px;
}

.body {
  font-family: Open Sans, sans-serif;
  font-size: 1rem;
  line-height: 1em;
}

.estilo_link_menu {
  color: var(--blanco);
  padding-left: 30px;
  padding-right: 0;
  font-size: .8rem;
  font-weight: 700;
}

.estilo_link_menu:hover, .estilo_link_menu.w--current {
  color: var(--verde1);
}

.estilo_link_menu.esp {
  background-image: url('../images/MEX.webp');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  flex-wrap: nowrap;
  place-content: center;
  align-items: center;
  width: 3.5vh;
  height: 3.5vh;
  margin-left: 30px;
  padding: 0;
  display: flex;
}

.estilo_link_menu.ing {
  background-image: url('../images/USA.webp');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  flex-wrap: nowrap;
  place-content: center;
  align-items: center;
  width: 3.5vh;
  height: 3.5vh;
  margin-left: 10px;
  padding: 0;
  display: flex;
}

.cont_menu {
  align-items: center;
  display: flex;
}

.slide {
  background-image: linear-gradient(#57952600 46%, #000), url('../images/port1.jpeg');
  background-position: 0 0, 50%;
  background-size: auto, cover;
}

.slide-2 {
  background-image: linear-gradient(#94585800 46%, #000), url('../images/a8a4ca43-6561-47ef-8869-687de435583d.webp');
  background-position: 0 0, 0 0;
  background-size: auto, cover;
}

.slide-3 {
  background-image: linear-gradient(#94585800 46%, #000), url('../images/portada.webp');
  background-position: 0 0, 0 0;
  background-size: auto, cover;
}

.slide-4 {
  background-image: linear-gradient(#94585800 46%, #000), url('../images/port2.webp');
  background-position: 0 0, 0 0;
  background-size: auto, cover;
}

.slider_servicios {
  background-color: #ddd0;
  width: 100%;
  height: 450px;
  display: block;
}

.slide_card {
  background-color: var(--transparent);
  width: 20%;
}

.seccion {
  background-color: var(--acento-1);
  padding: 8rem 10%;
}

.seccion.color-acento1 {
  background-color: var(--acento-1);
}

.seccion.fondo_paralax {
  background-image: linear-gradient(#00000080, #00000080), url('../images/bg5_3.webp');
  background-position: 0 0, 0 0;
  background-size: auto, cover;
  background-attachment: scroll, fixed;
  flex-wrap: wrap;
  place-content: center flex-start;
  padding-bottom: 8rem;
  padding-left: 0%;
  padding-right: 0%;
  display: flex;
}

.seccion.cta {
  background-image: url('../images/bg-4.webp'), linear-gradient(to bottom, var(--verde1), var(--verde1));
  background-position: 0 0, 0 0;
  background-repeat: repeat-y, repeat;
  background-size: cover, auto;
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.seccion.footer {
  background-color: var(--negro);
  color: #333;
  padding: 6rem 0% 0;
}

.seccion.servicios {
  background-image: url('../images/bg5_3.webp');
  background-position: 0 0;
  background-size: auto;
  padding: 5vh 0% 10vh;
}

.seccion.servicios_blanco {
  background-color: var(--acento-1);
  margin-top: 0;
  padding-left: 10%;
}

.seccion.bck_blanco {
  background-color: var(--blanco);
  padding-top: 4rem;
  padding-bottom: 6rem;
}

.cont_seccion {
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.cont_seccion.estirar {
  align-items: stretch;
}

.cont_seccion.estirar.servicios {
  margin-bottom: 10vh;
}

.cont_seccion.footer_datos {
  align-content: flex-start;
  width: 80%;
  margin-top: 0;
  margin-bottom: 5vh;
  padding-top: 0;
}

.cont_seccion.footer {
  width: 80%;
  margin-bottom: 5vh;
}

.cont_seccion.contacto {
  width: 80%;
  margin-top: 10vh;
}

.col35 {
  width: 35%;
}

.col35.verde {
  background-color: var(--verde1);
  margin-right: 0;
  padding-bottom: 10px;
  padding-left: 0;
  position: relative;
}

.col35.centrar-vertical {
  justify-content: center;
  align-items: center;
  display: flex;
}

.col65 {
  flex-wrap: wrap;
  width: 65%;
  padding-left: 50px;
  display: flex;
}

.col65.centrado_vertical {
  align-items: flex-start;
}

.col65.sinmargen {
  padding-left: 0;
}

.image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  margin-top: -10px;
  margin-left: 10px;
  margin-right: 0;
  position: relative;
}

.justificar {
  text-align: justify;
  margin-bottom: 0;
}

.justificar._100 {
  width: 100%;
}

.text-span {
  text-transform: lowercase;
  padding-left: 2px;
  font-size: 1rem;
}

.col50 {
  flex-wrap: wrap;
  width: 50%;
  height: auto;
  display: flex;
}

.col50.quote {
  border-left: 3px solid #d1d1d1;
  margin-top: 40px;
  padding-left: 20px;
  padding-right: 40px;
}

.col50.quote.s-margen {
  padding-right: 0;
}

.col50.quote._100 {
  width: 100%;
  padding-right: 0;
}

.col50.bg_color1 {
  background-color: var(--negro);
  align-content: flex-start;
  align-items: flex-start;
  padding: 3rem 3rem 3rem 10%;
}

.col50.servicios {
  align-content: center;
  align-items: center;
  margin-right: auto;
  padding-right: 0;
}

.col50.servicios.img {
  padding-right: 0;
}

.col30 {
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  width: 30%;
  display: flex;
}

.col30.ficha {
  background-color: var(--blanco);
  text-align: center;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-bottom: 2rem;
  padding: 2rem 3rem;
}

.col30.ficha_portafolio {
  background-color: var(--blanco);
  color: var(--negro);
  align-content: flex-start;
  margin-bottom: 3rem;
  text-decoration: none;
}

.titulo_fichas {
  text-transform: uppercase;
  padding-top: 10px;
  padding-bottom: 30px;
  font-size: 1.1rem;
  font-weight: 700;
}

.caja_icono_material {
  color: var(--verde1);
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  font-family: Material Icons Round, sans-serif;
  font-size: 3rem;
  display: flex;
}

.caja_icono_material.bco {
  color: var(--blanco);
  margin-bottom: 0;
  font-size: 2.5rem;
}

.h1_titulo_seccion {
  text-align: center;
  width: 100%;
  margin-bottom: 1rem;
  font-size: 1.8rem;
}

.h1_titulo_seccion.left {
  text-align: left;
}

.h1_titulo_seccion.left.servicios {
  color: #fff;
  margin-top: auto;
  margin-bottom: auto;
  margin-left: 0%;
  padding: 0 10% 3vh;
}

.h1_titulo_seccion.servicios {
  color: #fff;
  text-align: left;
  flex-wrap: wrap;
  place-content: center flex-start;
  align-items: flex-start;
  width: 100%;
  margin-top: 0;
  margin-bottom: 5vh;
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.cont_ornamenta {
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 3rem;
  display: flex;
}

.cont_ornamenta.left {
  justify-content: flex-start;
}

.cont_ornamenta.left.blanco, .cont_ornamenta.left.verde {
  margin-top: 1rem;
  margin-bottom: 1rem;
}

.cont_ornamenta.left.servicios {
  margin-left: 0%;
  padding-left: 10%;
  padding-right: 10%;
  display: flex;
}

.cont_ornamenta.servicios {
  justify-content: flex-start;
  margin-bottom: 3vh;
}

.linea_ornamenta {
  background-color: var(--verde1);
  width: 5rem;
  height: .2rem;
}

.linea_ornamenta.balnco {
  background-color: var(--blanco);
}

.linea_ornamenta.verde {
  background-color: var(--verde1);
}

.cuadro_ornamneta {
  border: 4px solid #000;
  width: .8rem;
  height: .8rem;
  margin-left: 13px;
  margin-right: 13px;
}

.cuadro_ornamneta.margen {
  border-color: var(--negro);
  margin-left: 0;
}

.cuadro_ornamneta.margen.blanco {
  border-color: #fff;
}

.imagen_lista {
  object-fit: cover;
  width: 100%;
}

.cont_seccion_lista_imagen {
  flex-wrap: wrap;
  display: flex;
}

.cont_seccion_quote {
  color: var(--white);
  text-align: right;
  flex-flow: column wrap;
  justify-content: center;
  align-items: flex-end;
  width: 40%;
  max-width: 1280px;
  margin-bottom: 0;
  margin-left: auto;
  margin-right: 10vw;
  padding-left: 0%;
  display: flex;
}

.texto_sobre_quote {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1em;
}

.texto_quote {
  margin-top: 1rem;
  margin-bottom: 1rem;
  font-size: 4rem;
  font-weight: 700;
  line-height: 1em;
}

.texto_ayuda {
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.2em;
}

.valor {
  color: var(--verde1);
  margin-top: 0;
  margin-bottom: 0;
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.1em;
}

.cont_valor {
  flex-flow: wrap;
  align-content: center;
  align-items: center;
  display: flex;
}

.titulo_fondo_color_principal {
  background-color: var(--verde1);
  color: var(--white);
  text-transform: uppercase;
  align-items: center;
  width: 100%;
  height: auto;
  margin-top: 1rem;
  margin-bottom: 1rem;
  padding-top: .5rem;
  padding-bottom: .6rem;
  padding-left: 1rem;
  font-weight: 700;
  line-height: 1.2em;
  display: flex;
}

.bco {
  color: #fff;
  margin-bottom: 2rem;
}

.h1_seccion {
  color: #fff;
  font-size: 1.7rem;
}

.text-span-2 {
  font-size: 1.3rem;
}

.img_portafolio {
  object-fit: cover;
  object-position: 50% 50%;
  background-image: url('../images/p-imss.webp');
  background-position: 0 0;
  background-size: auto;
  width: 100%;
  max-width: none;
  height: auto;
}

.img_portafolio:hover {
  backface-visibility: visible;
  mix-blend-mode: normal;
}

.text-block {
  margin-bottom: 1rem;
  padding-top: 0;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.1em;
}

.cont_img_portafolio {
  border-bottom: 4px solid var(--verde1);
  object-fit: fill;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  height: 15rem;
  display: flex;
  overflow: hidden;
}

.cont_description_portafolio {
  margin: 2rem;
}

.text-block-2 {
  color: var(--verde1);
  font-style: italic;
  font-weight: 400;
}

.parrafo_portafolio {
  margin-top: 1rem;
  margin-bottom: 0;
}

.text-block-3 {
  color: var(--blanco);
  text-transform: uppercase;
  width: 100%;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1em;
}

.paragraph-3 {
  color: var(--blanco);
  margin-top: 1rem;
}

.button {
  background-color: var(--negro);
  text-align: center;
  text-transform: uppercase;
  width: 100%;
  padding-top: 1rem;
  padding-bottom: 1rem;
  font-weight: 700;
}

.titulo_footer {
  color: var(--blanco);
  text-transform: uppercase;
  width: 100%;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1em;
}

.image-2 {
  width: 60%;
  height: auto;
}

.link-block {
  width: 100%;
  margin-bottom: 2rem;
}

.link_secciones {
  color: var(--gris);
  -webkit-text-stroke-color: #fff;
  width: 100%;
  margin-top: 1vh;
  margin-bottom: 1vh;
  font-size: .8rem;
  text-decoration: none;
  display: block;
}

.linea_punteada {
  border-style: none none dashed;
  border-width: 1px;
  border-color: black black var(--gris);
  background-color: var(--transparent);
  width: 100%;
  height: .2rem;
  text-decoration: none;
}

.redes {
  width: 40%;
  height: auto;
  margin-right: auto;
  display: flex;
}

.red__social {
  opacity: 1;
  flex-flow: row;
  place-content: center;
  align-items: flex-start;
  margin-left: 0;
  margin-right: .7vw;
  padding-left: 0;
  padding-right: 0;
  display: block;
}

.red__social:hover {
  background-color: var(--verde1);
}

.img_red_social {
  border: 1px solid #979797;
  width: 2.2vw;
  max-width: none;
  height: auto;
  margin-right: 0;
  padding: .3vh .3vw;
}

.img_red_social:hover {
  filter: none;
}

.cover {
  background-image: url('../images/bg5_3.webp');
  background-position: 0 0;
  background-size: auto;
  flex-wrap: wrap;
  height: 30vh;
  margin-bottom: auto;
  padding-top: 20vh;
  padding-left: 10vw;
  padding-right: 10vw;
  display: flex;
}

.titulo_servicio {
  text-align: left;
  width: 100%;
  margin-top: 0;
  margin-bottom: 2vh;
  font-size: 1.8rem;
}

.img_servicios {
  object-fit: contain;
  width: 90%;
  margin-left: auto;
}

.img_servicios.izq {
  margin-left: 0;
  margin-right: auto;
}

.paragraph-4 {
  margin-bottom: 5vh;
}

.card {
  backface-visibility: hidden;
  perspective: 2000px;
  color: var(--negro);
  flex-wrap: wrap;
  align-content: flex-end;
  align-items: flex-end;
  width: 100%;
  height: auto;
  min-height: 50vh;
  padding: 0 0;
  display: flex;
  position: relative;
  transform: none;
}

.card-front {
  background-color: var(--transparent);
  object-fit: cover;
  object-position: 50% 50%;
  width: 100%;
  height: auto;
  min-height: 50vh;
  padding: 0 0;
  display: block;
  position: absolute;
  inset: 0%;
}

.card-back {
  background-color: var(--blanco);
  backface-visibility: hidden;
  transform-style: preserve-3d;
  flex-wrap: wrap;
  align-content: center;
  width: 100%;
  height: auto;
  min-height: 50vh;
  padding: 2vh 2vw;
  display: flex;
  position: absolute;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.titulo_card {
  color: var(--negro);
  text-align: center;
  width: 100%;
  height: auto;
  margin-bottom: 2vh;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1.2em;
}

.parafo_card {
  text-align: center;
  margin-bottom: 0;
}

.boton_ficha {
  border: 2px solid var(--negro);
  color: var(--negro);
  background-color: #0000;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 50%;
  margin: 2vh auto 5vh;
  padding: 1vh 1vw;
  font-size: .7rem;
  display: flex;
}

.boton_ficha:hover {
  color: var(--blanco);
  background-color: #000;
}

.slide-nav-2 {
  display: none;
}

.cont_datos {
  border: .2px solid var(--gris);
  color: var(--gris);
  flex-wrap: wrap;
  place-content: center space-around;
  align-items: center;
  width: 30%;
  height: 13vh;
  margin-top: 0;
  padding: 2vh 0 2vh 2vw;
  font-size: .8rem;
  display: flex;
}

.text_datos {
  width: 100%;
  margin: auto 0 auto auto;
}

.text_titulo {
  color: var(--blanco);
  align-items: flex-start;
  width: 100%;
  margin-bottom: 1vh;
  margin-left: auto;
  margin-right: 0;
  font-size: 1.1rem;
  font-weight: 700;
  display: flex;
}

.textos_footer {
  width: 80%;
  margin: auto 0 auto auto;
}

.icono {
  color: var(--verde1);
  align-items: center;
  width: 100%;
  height: 100%;
  margin-top: auto;
  margin-bottom: auto;
  font-family: Material Icons Round, sans-serif;
  font-size: 3rem;
  display: flex;
}

.cont_icono {
  flex-wrap: wrap;
  align-items: flex-start;
  width: 20%;
  height: 100%;
  margin-top: auto;
  margin-bottom: auto;
  padding-top: 10px;
  padding-bottom: 10px;
  display: block;
}

.footer_strip {
  background-image: url('../images/footer-strip.webp');
  background-position: 50%;
  background-repeat: repeat-x;
  background-size: auto;
  height: 2.2vh;
  margin-top: 0;
}

.footer_strip.color {
  background-image: linear-gradient(to bottom, var(--verde1), var(--verde1));
}

.legales {
  color: var(--gris);
  padding: 4vh 10%;
}

.text_legales {
  text-align: center;
  font-size: .8rem;
}

.text-span-3 {
  color: var(--verde1);
  text-decoration: none;
}

.cont_clientes {
  flex-wrap: wrap;
  place-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.cont_logo {
  filter: grayscale();
  flex-wrap: wrap;
  place-content: stretch center;
  width: 20%;
  height: auto;
  display: flex;
}

.cont_logo:hover {
  filter: none;
}

.img_logo {
  width: 100%;
}

.slider {
  background-color: var(--transparent);
  height: auto;
}

.slide-nav-3 {
  top: 27vh;
}

.left-arrow-2, .right-arrow-2 {
  display: none;
}

.mapa {
  align-items: center;
  width: 40%;
  margin-left: 10vw;
  display: flex;
}

.whats-card {
  z-index: 99999;
  -webkit-text-stroke-color: #000;
  background-color: #0dc977;
  border: 2px #ffd20a;
  border-radius: 100px;
  flex-wrap: wrap;
  place-content: center;
  align-items: center;
  width: 4vw;
  height: 4vw;
  margin-left: 0;
  padding: 5px 0;
  text-decoration: none;
  display: flex;
  position: fixed;
  bottom: 20px;
  left: auto;
  right: 3vw;
}

.img_whats {
  flex: 0 auto;
  align-self: auto;
  width: 50%;
  height: auto;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
}

.select_tipo {
  color: gray;
  background-color: #fff;
  border-radius: 0;
  height: auto;
  min-height: 3vw;
  padding: 1vw;
  font-family: Open Sans, sans-serif;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.5em;
}

._50div-form2 {
  color: #fff;
  width: 49%;
  margin-left: 0%;
  margin-right: 0%;
  font-size: 16px;
}

.imput_form {
  background-color: #ffffff4d;
  height: auto;
  min-height: 60px;
  font-size: 19px;
}

.imput_form.style_form {
  color: gray;
  background-color: #fff;
  border: 1px solid #e7e7e7;
  border-radius: 0;
  width: 100%;
  min-height: 3vw;
  padding: 1vw;
  font-family: Open Sans, sans-serif;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.5em;
  box-shadow: 0 1px 3px #dadada;
}

.cont_btn_form {
  width: 100%;
  display: none;
}

.texto_error_style {
  font-size: .9rem;
  font-weight: 700;
}

.input_mensaje {
  color: #8a8a8a;
  background-color: #fff;
  border-radius: 0;
  min-height: 10vw;
  margin-bottom: 20px;
  font-family: Open Sans, sans-serif;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.3rem;
}

.submit-button-2 {
  color: #fff;
  letter-spacing: 0;
  text-transform: uppercase;
  background-color: #5bca4e;
  border: 2px #33d7f0;
  border-radius: 0;
  width: 100%;
  margin-top: 0;
  margin-bottom: 4vw;
  margin-left: auto;
  padding-top: 1vw;
  padding-bottom: 1vw;
  font-family: Droid Sans, sans-serif;
  font-size: 1.1rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3rem;
  display: block;
}

.submit-button-2:hover {
  color: #fff;
  background-color: #1a1a1a;
  border: 0 #1a1a1a;
}

.success_message {
  color: #fff;
  text-align: center;
  background-color: #5bca4e;
  margin-top: 1vw;
  padding: 1vw;
  font-size: .9rem;
}

.formualrio {
  flex-flow: wrap;
  justify-content: space-between;
  width: 100%;
  height: auto;
  display: flex;
}

.texto_check_style {
  color: #fff;
  font-size: .9rem;
  font-weight: 700;
}

.contenerdor_formulario {
  background-color: #ddd;
  border-radius: 12px;
  flex-flow: wrap;
  justify-content: space-between;
  width: 50%;
  height: auto;
  margin: 0 0 8vw auto;
  padding: 1vw 1vw 2vw;
  display: flex;
}

.cont_embed_alertas {
  width: 100%;
  font-size: 1rem;
  line-height: 1.3rem;
  display: block;
}

.error_message {
  color: #fff;
  text-align: center;
  background-color: #fc5e5e;
  margin-top: 1vw;
  padding: 1vw;
  font-size: 1.3vw;
  line-height: 1.3em;
}

.embed_codigo_captcha {
  border-radius: 0;
  width: 100%;
  font-size: 1rem;
}

.parafo_contacto {
  flex-wrap: nowrap;
  width: 100%;
  display: flex;
}

.col_40 {
  width: 40%;
}

.image-3 {
  width: 100%;
}

.form-block {
  flex-flow: wrap;
  justify-content: space-between;
  width: 100%;
  height: auto;
  display: flex;
}

@media screen and (max-width: 991px) {
  .cont_texto_hero {
    width: 90%;
  }

  .menu_principal {
    padding-left: 5%;
    padding-right: 5%;
  }

  .slide-nav {
    bottom: 5px;
    left: 5%;
    right: auto;
  }

  .estilo_link_menu.esp {
    margin-top: 20px;
    margin-bottom: 20px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .estilo_link_menu.ing {
    margin-top: 20px;
    margin-bottom: 20px;
    margin-left: 30px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .link_marca {
    z-index: 100;
    padding-left: 0;
  }

  .cont_menu {
    z-index: 99;
    background-color: #000;
    width: 40vw;
    height: 100vh;
    padding-top: 140px;
  }

  .slide-2, .slide-3, .slide-4 {
    background-position: 0 0, 50%;
  }

  .menu-button {
    padding-right: 0;
  }

  .menu-button.w--open {
    background-color: #c8c8c800;
  }

  .icon {
    color: var(--blanco);
    font-size: 2.3rem;
    font-weight: 300;
  }

  .seccion {
    padding-left: 5%;
    padding-right: 5%;
  }

  .seccion.servicios_blanco {
    padding-left: 5%;
  }

  .cont_seccion {
    align-content: flex-start;
    align-items: stretch;
  }

  .cont_seccion.estirar.servicios {
    flex-flow: row-reverse wrap;
  }

  .col35.verde {
    width: 100%;
  }

  .col35.centrar-vertical {
    justify-content: flex-end;
  }

  .col65.centrado_vertical {
    width: 100%;
    margin-top: 4rem;
    padding-left: 0;
  }

  .col50 {
    width: 100%;
  }

  .col50.bg_color1 {
    width: 100%;
    padding: 3rem 5%;
  }

  .col50.servicios, .col30.ficha, .col30.ficha_portafolio {
    width: 48%;
  }

  .cont_seccion_quote {
    width: 90%;
    margin-left: 10vw;
    padding-left: 0%;
  }

  .image-2 {
    width: 80%;
  }

  .img_red_social {
    width: 3.2vw;
  }

  .img_servicios {
    width: 100%;
  }

  .cont_datos {
    flex-wrap: wrap;
    align-content: flex-start;
    height: auto;
    padding: 2vh 1vw;
  }

  .textos_footer {
    margin-left: 0;
  }

  .icono {
    text-align: center;
    justify-content: flex-start;
    margin-right: auto;
    font-size: 2.5rem;
  }

  .cont_icono {
    width: 80%;
    height: auto;
    margin-bottom: 2vh;
  }

  .slide-nav-3 {
    top: 17vh;
  }

  .mapa {
    width: 60%;
    margin-bottom: 5vh;
    margin-left: 20vw;
    margin-right: 20vw;
  }

  .whats-card {
    width: 5vw;
    height: 5vw;
    left: auto;
    right: 3vw;
  }

  .img_whats {
    height: auto;
  }

  .select_tipo {
    font-size: .8rem;
  }

  ._50div-form2 {
    width: 100%;
    margin-left: 0%;
  }

  .imput_form.style_form {
    font-size: .8rem;
  }

  .cont_btn_form {
    display: none;
  }

  .texto_error_style {
    font-size: .8rem;
  }

  .input_mensaje {
    min-height: 30vw;
    font-size: .8rem;
  }

  .submit-button-2 {
    font-size: .8rem;
    line-height: 1.2rem;
  }

  .success_message {
    font-size: 2vw;
    line-height: 1em;
  }

  .texto_check_style {
    font-size: .8rem;
  }

  .contenerdor_formulario {
    width: 100%;
    margin-bottom: 8vw;
    padding: 2vw 2vw 1vw;
  }

  .cont_embed_alertas {
    font-size: .63rem;
    line-height: 1.2rem;
  }

  .error_message {
    line-height: 1em;
  }

  .embed_codigo_captcha {
    font-size: .8rem;
    line-height: 1em;
  }

  .col_40 {
    width: 100%;
    margin-bottom: 5vh;
  }
}

@media screen and (max-width: 767px) {
  .h1_hero {
    font-size: 3.7rem;
  }

  .cont_menu {
    width: 50vw;
  }

  .cont_seccion.estirar.servicios.izq {
    flex-wrap: wrap-reverse;
  }

  .col35.centrar-vertical {
    justify-content: flex-start;
    width: 100%;
  }

  .col65.sinmargen {
    width: 100%;
    margin-bottom: 2rem;
  }

  .col50, .col50.servicios, .col50.servicios.img, .col30.ficha {
    width: 100%;
  }

  .col30.ficha_portafolio {
    justify-content: flex-start;
    width: 100%;
  }

  .image-2, .redes {
    width: 100%;
  }

  .red__social {
    margin-right: 1vw;
  }

  .img_red_social {
    width: 4vw;
  }

  .img_servicios {
    margin-bottom: 5vh;
  }

  .cont_datos {
    justify-content: center;
    width: 100%;
    margin-bottom: 2vh;
    padding-top: 2vh;
    padding-bottom: 2vh;
    display: flex;
  }

  .cont_datos._50 {
    flex-wrap: nowrap;
    align-content: flex-start;
    align-items: flex-start;
    width: 48%;
  }

  .textos_footer {
    width: 70%;
    margin-top: 0;
    margin-left: 3vw;
  }

  .cont_icono {
    align-content: center;
    align-items: center;
    width: 10vw;
    margin-bottom: auto;
    display: flex;
  }

  .mapa {
    width: 70%;
    margin-left: 15vw;
    margin-right: 15vw;
  }

  .whats-card {
    width: 6vw;
    height: 6vw;
  }

  .select_tipo, .imput_form.style_form {
    font-size: .7rem;
    line-height: 1rem;
  }

  .texto_error_style {
    font-size: 1rem;
    line-height: 1.4em;
  }

  .input_mensaje {
    min-height: 40vw;
    font-size: .7rem;
    line-height: 1rem;
  }

  .submit-button-2 {
    padding-top: 2vw;
    padding-bottom: 2vw;
    font-size: .8rem;
    line-height: 1.4rem;
  }

  .success_message {
    font-size: 2.5vw;
  }

  .texto_check_style {
    font-size: 1rem;
    line-height: 1.4em;
  }

  .contenerdor_formulario {
    margin-left: 0;
    margin-right: 0;
  }

  .cont_embed_alertas {
    font-size: .8rem;
  }

  .embed_codigo_captcha {
    font-size: .7rem;
    line-height: 1rem;
  }
}

@media screen and (max-width: 479px) {
  .main {
    display: block;
    overflow: hidden;
  }

  .h1_hero {
    font-size: 2.1rem;
  }

  .parrafo_hero {
    width: 100%;
  }

  .slide-nav {
    bottom: 5px;
    left: 5%;
    right: auto;
  }

  .cont_menu {
    width: 80vw;
  }

  .icon {
    font-size: 2rem;
  }

  .slider_servicios {
    height: auto;
  }

  .slide_card {
    width: 100%;
    height: auto;
  }

  .seccion {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }

  .seccion.servicios_blanco {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }

  .cont_seccion.contacto {
    width: 90%;
  }

  .col50.quote {
    width: 100%;
    padding-left: 10px;
    padding-right: 0;
  }

  .col30 {
    width: 100%;
  }

  .col30.footer {
    margin-bottom: 5vh;
  }

  .h1_titulo_seccion.servicios {
    padding-top: 12vh;
    padding-left: 5vw;
    padding-right: 5vw;
    font-size: 1.3rem;
  }

  .cont_seccion_quote {
    margin-left: 5%;
    margin-right: 5%;
  }

  .texto_quote {
    font-size: 3rem;
  }

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

  .red__social {
    width: 8vw;
    height: auto;
    margin-left: 0;
    margin-right: 4vw;
  }

  .img_red_social {
    width: auto;
    height: auto;
  }

  .cover {
    height: 20vh;
  }

  .card {
    width: 100%;
    height: 70vh;
    min-height: 70vh;
    display: block;
  }

  .card-front {
    height: auto;
    min-height: 70vh;
  }

  .card-back {
    place-content: center;
    align-items: center;
    height: auto;
    min-height: 70vh;
    margin-top: auto;
    margin-bottom: auto;
  }

  .parafo_card {
    flex-wrap: wrap;
    align-items: center;
    line-height: 1.1em;
    display: block;
  }

  .boton_ficha {
    flex-wrap: nowrap;
    align-content: flex-start;
    margin-bottom: 0;
  }

  .icon-2, .icon-3 {
    margin-top: auto;
    margin-bottom: auto;
  }

  .cont_datos._50 {
    width: 100%;
    padding-right: 3vw;
  }

  .text_datos {
    text-align: center;
  }

  .text_titulo, .icono {
    justify-content: center;
  }

  .cont_icono {
    justify-content: center;
    width: 30%;
    margin-bottom: 2vh;
  }

  .cont_logo {
    width: 50%;
  }

  .slide-nav-3 {
    top: auto;
    bottom: -30px;
  }

  .mapa {
    width: 100%;
    margin-left: 5vw;
    margin-right: 5vw;
  }

  .whats-card {
    width: 9vw;
    height: 9vw;
    margin-right: 2px;
    display: flex;
    left: auto;
    right: 1vw;
  }

  .img_whats {
    align-self: auto;
    height: auto;
  }

  .select_tipo {
    font-size: .9rem;
    line-height: 1.1rem;
  }

  .imput_form.style_form {
    padding-top: 2vw;
    padding-bottom: 2vw;
    font-size: .9rem;
    line-height: 1.1rem;
  }

  .cont_btn_form {
    font-size: .4rem;
    line-height: 1rem;
    display: none;
  }

  .texto_error_style {
    font-size: 1rem;
    line-height: 1.5em;
  }

  .input_mensaje {
    min-height: 80vw;
    font-size: .9rem;
    line-height: 1.1rem;
  }

  .submit-button-2 {
    margin-left: 0;
    padding-top: 5vw;
    padding-bottom: 5vw;
    font-size: 1rem;
    line-height: 1rem;
    display: block;
    overflow: visible;
  }

  .success_message {
    margin-top: 2vw;
    padding: 5vw;
    font-size: 4vw;
  }

  .texto_check_style {
    font-size: 1rem;
    line-height: 1.2em;
  }

  .contenerdor_formulario {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding: 5vw 2vw;
  }

  .cont_embed_alertas {
    font-size: .8rem;
    line-height: 1rem;
  }

  .error_message {
    margin-top: 5vw;
    padding: 5vw;
  }

  .embed_codigo_captcha {
    font-size: .7rem;
    line-height: 1.1rem;
  }
}


