:root {
  --primary: #ff9734;
  --white: #FFFFFF;
  --black: #1f272d;
}

body {
  margin: 0px;
  padding: 0px;
  overflow-x: hidden;
  font-family: 'Open Sans', sans-serif;
  font-size: 16px;
  color: #5b6668;
  /*line-height: 1.2;*/
}

h1,
h2,
h3,
h4,
h5 {
  margin: 0px;
  padding: 0 0 15px;
  font-weight: 700;
  color: #1f272d;
}

h1,
.h1 {
  font-size: 60px;
  line-height: 60px;
  color: var(--white);
  font-weight: 700;
  margin: 0;
}

h2,
.h2 {
  font-size: 45px;
  line-height: normal;
  font-weight: 400;
  color: var(--white);
  margin: 0;
}

h3,
.h3 {
  font-size: 40px;
  line-height: 48px;
  font-weight: 700;
  margin: 0;
}

h4,
.h4 {
  font-size: 22px;
  line-height: 48px;
  font-weight: 700;
  margin: 0;
}

h5,
.h5 {
  font-size: 20px;
  line-height: 48px;
  font-weight: 600;
  margin: 0;
}

p {
  margin: 0px;
  padding-top: 0px;
  padding-bottom: 15px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 400;
  font-size: 18px;
  line-height: 28px;
  color: #5c6668;
}

span {
  font-size: 18px;
  color: var(--primary);
  font-weight: 600;
  text-transform: uppercase;
}

iframe {
  width: 100%;
}

strong,
b {
  font-weight: 700;
}

img {
  height: auto;
  border: none;
  max-width: 100%;
  object-fit: contain;
}

ul {
  margin: 0px;
  padding: 0px;
}

ul li {
  list-style-type: none;
}

a {
  text-decoration: none;
  color: #5c6668;
  transition: .4s;
}

a:hover {
  color: var(--primary);
  cursor: pointer;
  text-decoration: none;
  transition: all ease-in 0.2s;
}

.overflow {
  display: block;
  overflow: hidden;
}

.bg-primary {
  background-color: var(--primary) !important;
}

.bg-secondary {
  background-color: var(--white) !important;
}

section,
.section {
  padding-top: 100px;
  padding-bottom: 100px;
  overflow: hidden;
}

/* Form CSS */
.form-group {
  position: relative;
  max-width: 824px;
  margin: 0 auto;
}

form .form-control,
form .wpcf7-form-control:not(.wpcf7-submit) {
  width: 100%;
  height: auto;
  margin-bottom: 0;
  padding: 17px 20px;
  font-family: 'Open Sans', sans-serif;
  color: #5c6668;
  font-size: 16px;
  font-weight: regular;
  letter-spacing: 0;
  background-color: var(--white) !important;
  -webkit-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border: none;
  border: 1px solid #CACACA;
  box-shadow: none;
  text-overflow: ellipsis;
  overflow: hidden;
  margin-bottom: 14px;
  border-radius: 0;
}

.form-group.active .wpcf7-form-control:not(.wpcf7-submit) {
  border-bottom-color: #F70;
}

.form-group button {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  height: 59px;
  right: 0;
  margin: 0 -1px 0 0;
}

form textarea.form-control {
  height: 153px;
  resize: none;
  overflow-y: auto;
  border-radius: 0;
}

textarea {
  border-radius: 0 !important;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.form-control:focus {
  border-color: #ff9734;
  box-shadow: none;
}

form .form-control:focus,
form .wpcf7-form-control:not(.wpcf7-submit):focus {
  border-color: var(--primary);
  box-shadow: none;
}

select::-ms-expand {
  display: none;
}

::-webkit-input-placeholder {
  /* WebKit, Blink, Edge */
  color: var(--secondary) !important;
  opacity: 1;
}

:-moz-placeholder {
  /* Mozilla Firefox 4 to 18 */
  color: var(--secondary) !important;
  opacity: 1;
}

::-moz-placeholder {
  /* Mozilla Firefox 19+ */
  color: var(--secondary) !important;
  opacity: 1;
}

:-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: var(--secondary) !important;
  opacity: 1;
}

::-ms-input-placeholder {
  /* Microsoft Edge */
  color: var(--secondary) !important;
  opacity: 1;
}

::placeholder {
  /* Most modern browsers support this now. */
  color: var(--secondary) !important;
  opacity: 1;
}

/* Btn CSS */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 204px;
  padding: 22px 20px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 700;
  font-size: 14px;
  color: #fff;
  background: #ff9734;
  text-align: center;
  border-radius: 8px;
  /*border: 4px solid #2BAF4C;
  text-transform: capitalize;*/
  transition: all 0.2s ease;
  position: relative;
  z-index: 0;
  border: none;
}

.btn:focus {
  box-shadow: none;
  outline: none;
}

/* Title CSS */
.title {
  display: block;
  color: #395C6B;
  text-align: center;
}


/*header*/
.top-header {
  background-color: #eff1f5;
}

.top-left a {
  padding-right: 15px;
}

.top-left img {
  margin-right: 10px;
}

.top-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.top-right {
  display: flex;
}

.top-right a {
  border-right: 1px solid #cacdd3;
}

.top-right a {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.top-right a:hover,
.top-right a:focus {
  background-color: #172236;
}

.top-right a:hover img {
  filter: brightness(0) invert(1);
}

.header-bottom .btn:hover {
  color: var(--white);
}

.header-bottom {
  padding: 15px 0 0;
  border-bottom: 1px solid #cacaca;
  position: relative;
}

.logo-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 15px;
}

.header-bottom .btn::before {
  position: absolute;
  height: 13px;
  width: 13px;
  bottom: 0;
  right: 0;
  content: "";
  background-color: var(--black);
  transition: all ease-in 0.4s;
  z-index: -1;
}

.header-bottom .btn-primary {
  border: none;
}

.header-bottom .btn {
  border-radius: 0px;
}

.header-menu .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header ul {
  display: flex;
  align-items: center;
}

.header li {
  margin-right: 36px;
  font-weight: 700;
}

.header li a {
  display: inline-block;
  padding: 27px 0 22px;
  border-bottom: 5px solid transparent;
}

header .btn {
  padding: 15px 22px;
  min-width: auto;
}

.header-menu a {
  color: #222222;
  font-size: 14px;
}

.telefono-right {
  display: flex;
  align-items: center;
}

.telefono-right img {
  padding-right: 10px;
}

.phone-number {
  display: grid;
}

.header li a:hover {
  border-bottom-color: #ff9734;
}

.phone-number span {
  color: #5c6668;
  font-size: 15px;
}

.phone-number a {
  font-size: 15px;
  font-weight: 700;
}

.navbar-toggler {
  background-color: var(--primary);
  display: none;
  box-shadow: none !important;
}

.navbar-toggler:hover {
  background-color: var(--black);
}

.navbar-toggler .navbar-toggler-icon {
  background-image: url("data:image/svg+xml;charset=utf8,%3Csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath stroke='rgba(255, 255, 255, 1)' stroke-width='2' stroke-linecap='round' stroke-miterlimit='10' d='M4 8h24M4 16h24M4 24h24'/%3E%3C/svg%3E");
}

.navbar-toggler.active .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e");
  background-position: 7px 7px;
}

.sticky.stickyHeader {
  position: fixed !important;
  top: 0;
  left: 0;
  background-color: #000;
  box-shadow: 0px 0px 50px #00000029;
  animation: slide-down 0.7s;
  z-index: 11;
  width: 100%;
  background-color: var(--white);
}

@keyframes slide-down {
  0% {
    opacity: 0;
    transform: translateY(-100%);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

/*banner*/
.banner-title .small-title {
  display: inline-block;
  text-transform: uppercase;
  padding-bottom: 45px;
  color: var(--primary);
  font-size: 18px;
  font-family: 'Open Sans', sans-serif;
  font-weight: 700;
}

.banner .btn-primary::before {
  width: 0;
  height: 0;
}

.banner .btn-primary:hover::before {
  width: 100%;
  height: 100%;
}

.small-title:before {
  display: inline-block;
  width: 0;
  height: 0;
  content: '';
  border-bottom: 14px solid transparent;
  border-right: 10px solid transparent;
  border-left: 14px solid #FF9734;
}

.banner {
  background: url("../images/banner-img.png") no-repeat 100% 50% /cover;
  padding: 175px 0 95px 0;
}

.banner h1 {
  padding-bottom: 24px;
}

.banner-title p {
  padding-bottom: 56px;
  font-weight: 400;
  color: var(--white);
  font-size: 18px;
  max-width: 555px;
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  padding: 23px 37px;
  border: 1px solid var(--primary);
  border-radius: 0;
  background: #ff9734 !important;
  border: none;
  text-transform: uppercase;
}

.btn-primary:hover,
.btn-primary:focus {
  color: #fff;
  border-color: var(--black);
}

.btn-primary img {
  padding-left: 13px;
}

.down-arrow {
  padding: 86px 0 0 0;
}

/*LIDER CONSTRUCCIONES*/
.construcciones {
  padding-top: 80px 0 120px;
}

.construcciones .row {
  margin: 0 -20px;
  align-items: center;
}

.construcciones [class*="col-"] {
  padding: 0 20px;
}

.images-block {
  position: relative;
}

.images-block-one {
  position: absolute;
  background-color: var(--white);
  padding: 20px;
  box-shadow: 0px 0 18px 0px rgba(0, 0, 0, 0.08);
  width: 310px;
  left: -50px;
  bottom: -35px;
}

.title-box span {
  font-size: 14px;
  font-weight: 700;
}

.title-box h3 {
  padding-top: 10px;
}

.title-box p {
  font-weight: 700;
  padding-top: 0;
  border-bottom: 1px solid #cacaca;
  padding-bottom: 50px;
  color: #1f272d;
}

.soluciones-title {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 42px;
}

.soluciones-title img {
  margin-right: 20px;
}

.right-info P:last-child {
  padding-bottom: 0;
}

.btn-white.btn {
  background-color: var(--white);
  color: var(--black);
  border: 2px solid #d5d5d5;
  border-radius: 0;
  margin-top: 45px;
}

.btn.btn-white:hover img {
  filter: brightness(0) invert(1);
}

.construcciones .btn::before {
  position: absolute;
  height: 13px;
  width: 13px;
  bottom: 0;
  right: 0;
  content: "";
  background-color: var(--primary);
  transition: all ease-in 0.4s;
  z-index: -1;
}

.btn-white.btn:hover {
  color: var(--white);
  border: 2px solid var(--primary);
}

.btn-white img {
  padding-left: 13px;
}

/*PROYECTOS Y DISENO*/
.diseno {
  position: relative;
  text-align: center;
  background-image: url("../images/banner-background.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}

.diseno span {
  font-size: 14px;
  color: var(--white);
  font-weight: 700;
}

.diseno h2 {
  padding-top: 15px;
  line-height: 54px;
}

.diseno .btn-primary {
  margin-top: 25px;
  min-width: auto;
  padding: 15px 22px;
}

.diseno .btn::before {
  position: absolute;
  height: 13px;
  width: 13px;
  bottom: 0;
  right: 0;
  content: "";
  background-color: var(--black);
  transition: all ease-in 0.4s;
  z-index: -1;
}

.btn:hover::before {
  width: 100%;
  height: 100%;
}

/*nuestros servicios*/
.servicios .Nuestros {
  padding: 0 0 40px;
}

.Nuestros {
  text-align: center;
  padding: 50px 64px 48px;
}

.Nuestros span {
  font-size: 14px;
  font-weight: 700;
}

.Nuestros h3 {
  padding: 15px 0 25px;
}

.Nuestros p {
  max-width: 690px;
  margin: 0 auto;
}

.servicios {
  background-image: url("../images/background-two.png");
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  padding: 80px 0 0 0;
}

.servicios .row {
  margin: 0 -15px;
}

.servicios [class*="col-"] {
  padding: 0 15px;
}

.servicios-wrap {
  height: 100%;
}

.servicios .container {
  position: relative;
  z-index: 1;
}

.servicios::before {
  position: absolute;
  height: 41%;
  left: 0;
  right: 0;
  bottom: 0;
  content: "";
  background-color: var(--white);
}

.servicios .col-lg-4 {
  padding-bottom: 30px;
  position: relative;
}

.servicios-wrap:before {
  position: absolute;
  height: 8px;
  background-color: #ff9734;
  content: "";
  top: -8px;
  left: 15px;
  right: 15px;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  transition: .4s;
}

.servicios-wrap:hover:before {
  opacity: 1;
  visibility: visible;
}

.servicios-block {
  position: relative;
  background-color: #172236;
  padding: 48px 32px 62px;
  background-image: url("../images/hove-images.png");
  background-size: cover;
  background-repeat: no-repeat;
  box-shadow: 0px 0 18px 0px rgba(0, 0, 0, 0.08);
  overflow: hidden;
  height: 100%;
  transition: .4s;
}

.servicios-block::after {
  position: absolute;
  height: 100%;
  width: 100%;
  background-color: rgb(255, 255, 255, 1);
  content: "";
  bottom: 0;
  left: 0;
  transition: .4s;
}

.service-info {
  position: relative;
  z-index: 1;
}

.service-info h4 {
  line-height: 30px;
}

.servicios-block:hover::after {
  background-color: rgb(23, 34, 54, 0.4);
}

.servicios-block:hover,
.servicios-block:hover p,
.servicios-block:hover h4 {
  color: var(--white);
}

.servicios-block:hover .images-block-two {
  background-color: rgb(255, 255, 255, 0.25);
}

.images-block-two {
  background-color: var(--primary);
  border-radius: 100px;
  width: 70px;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .4s;
}

.servicios-block h4 {
  border-bottom: 1px solid #cacaca;
  padding: 26px 0 25px;
  transition: .4s;
}

.servicios-block p {
  margin-top: 30px;
  font-size: 16px;
  transition: .4s;
}

/*galería de imagenes*/
.imagenes {
  padding-bottom: 39px;
}

.owl-carousel {
  display: block;
}

.owl-carousel.owl-drag .owl-item {
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-user-select: unset;
  -moz-user-select: unset;
  -ms-user-select: unset;
  user-select: unset;
}

.owl-carousel .owl-prev,
.owl-carousel .owl-next,
.owl-carousel .owl-dot {
  cursor: pointer;
}

.owl-carousel .owl-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 45px;
  text-align: center;
}

.owl-carousel .owl-dots .owl-dot {
  background: transparent;
}

.owl-carousel .owl-dot.active {
  width: 100px;
  height: 30px;
  display: block;
  background: #FADD54;
}

.owl-carousel button.owl-dot {
  display: inline-block;
  vertical-align: middle;
  width: 20px;
  height: 20px;
  margin: 0 10px;
  text-indent: -999px;
  cursor: pointer;
  outline: none;
  transition: all ease .4s;
  pointer-events: auto;
  border: 1px solid var(--primary);
}

.owl-carousel button.owl-dot.active {
  width: 20px;
  height: 20px;
  background-color: var(--primary);
}

.owl-carousel .owl-nav {
  text-align: center;
}

.owl-carousel .item img:frist-child {
  width: 100%;
}

.Nuestros .owl-carousel {
  max-width: 1790px;
}

.owl-carousel .owl-nav button {
  position: absolute;
  top: 50%;
  left: 0;
  display: inline-block;
  vertical-align: middle;
  width: 51px;
  height: 60px;
  margin: 0 -23px;
  background-color: #FF9734;
  outline: none;
  border-radius: 6px;
  transition: all ease .4s;
  transform: translateY(-50%);
}

.owl-carousel .owl-nav button.owl-next {
  left: auto;
  right: 0;
  transform: rotate(180deg);
  margin-top: -29px;
}

.owl-carousel .owl-nav button.owl-next,
.owl-carousel .owl-nav button.owl-prev {
  border: 2px solid var(--primary);
}

.owl-carousel .owl-nav button {
  width: 54px;
  height: 54px;
  border-radius: 3px;
}

.owl-carousel .owl-nav button:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: '';
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url("../images/form1011.png");
  background-repeat: no-repeat;
  background-position: center;

}

.owl-carousel .owl-nav button:hover:before {
  background-image: url("../images/form1010.png");
}

.Nuestros a:hover img {
  filter: brightness(0) invert(1);
}

.Nuestros .owl-carousel {
  max-width: 1790px;
  margin: 0 auto;
}

.Nuestros .hover-item {
  text-align: initial;
  padding-left: 30px;
  position: absolute;
  bottom: 45px;
  width: 100%;
}

.Nuestros .hover-item h5 {
  border-bottom: 1px solid #c0bcb7;
  padding-bottom: 36px;
  margin-bottom: 36px;
}

.Nuestros .hover-item a {
  font-size: 14px;
  color: #FFFFFF;
  text-transform: uppercase;
  font-weight: 700;
}

.Nuestros .hover-item a:hover {
  color: var(--primary);
}

.Nuestros .hover-item h5 {
  font-size: 20px;
  color: #FFFFFF;
  line-height: 24px;
}

.Nuestros .hover-item a img {
  padding-left: 13px;
}

.owl-carousel .owl-nav button:hover {
  background-color: var(--white);
  border: 2px solid var(--primary);
}

.Nuestros .item:hover {
  background-color: rgba(23, 34, 54, 0.6);
}

.item {
  position: relative;
  overflow: hidden;
}

.Nuestros .item::after {
  position: absolute;
  top: -61px;
  right: -48px;
  bottom: 0;
  width: 90px;
  height: 100px;
  content: "";
  z-index: 1;
  background-color: #FF9734;
  transform: rotate(45deg);
  transition: all ease .4s;
  opacity: 0;
  visibility: hidden;
}

.Nuestros .item:hover::after {
  opacity: 1;
  visibility: visible;
}

.item:before:hover {
  color: #FF9734;
}

.Nuestros .item::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  z-index: 0;
  background-color: transparent;
  transition: all ease .4s;
}

.Nuestros .item:hover::before {
  background-color: rgba(23, 34, 54, 0.4);
}

.hover-item {
  position: relative;
  z-index: 1;
}

.owl-stage {
  margin: 0 auto;
}

.owl-drag .disabled {
  display: none;
}

.slider-no-current {
  display: none;
  padding-top: 46px;
}

.current-no:after {
  content: "/"
}

/*contacto*/
.contacto span {
  font-size: 14PX;
  font-weight: 700;
  color: #FF9734;
}

.contacto h3 {
  font-size: 40px;
  font-weight: 700;
  padding: 20px 0 40px;
}

textarea {
  resize: none;
  color: #8F9596;
}

textarea.form-control {
  font-size: 16px;
  font-weight: 400;
  color: #8F9596;
}

.map-section {
  padding: 30px;
  box-shadow: 0px 0 18px 0px rgba(0, 0, 0, 0.08);
}

.Dejanos {
  padding-top: 50px;
}

#contact .col-lg-6 .row {
  margin: 0 -7px;
}

#contact .col-lg-6 .row [class*="col-"] {
  padding: 0 7px;
}

.Dejanos .container>.row {
  margin: 0 -20px;
  align-items: center;
}

.Dejanos .container>.row>[class*="col-"] {
  padding: 0 20px;
}

.Dejanos .btn-primary {
  margin-top: 20px;
}

.Dejanos .row {
  align-items: center;
}

.Dejanos .btn-primary {
  padding: 23px 63px;
}

.btn::before {
  position: absolute;
  height: 13px;
  width: 13px;
  bottom: 0;
  right: 0;
  content: "";
  background-color: var(--black);
  transition: all ease-in 0.4s;
  z-index: -1;
}

/* Map */
#map {
  height: 510px;
}

/*Conoce las*/
.clientes {
  background: url(../images/client-back-image.png) no-repeat 50% 50% /cover;
  text-align: center;
  padding: 80px 0 50px;
}

.clientes h3 {
  padding-bottom: 60px;
}

.cliente {
  background-color: #fff;
  padding: 60px 40px;
  box-shadow: 0px 0 18px 0px rgba(0, 0, 0, 0.08);
}

.cliente h6 {
  font-size: 20px;
  font-weight: 700;
  color: #1F272D;
  margin: 30px auto 16px;
}

.cliente p {
  font-size: 16px;
  color: #5C6668;
  margin-bottom: 12px;
}

/*footer*/
.footer {
  background-color: #172236;
  padding-top: 56px;
}

.footer-links {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 50px;
}

.contacts {
  display: flex;
}

.contacts li {
  padding: 0 15px;
  border-right: 1px solid #353e4f;
}

.contacts li:last-child {
  border-right: none;
}

.contacts .icon:hover {
  color: #FF9734;
}

.contacts li a {
  display: inline-block;
  font-size: 16px;
  font-weight: 400;
  color: var(--white);
  padding: 9px 0;
}

.contacts img {
  padding-right: 10px;
}

.socials {
  display: flex;
}

.socials a {
  margin-left: 16px;
}

.socials a:first-child {
  margin-left: 0;
}

svg path {
  transition: .2s;
}

.socials a:hover svg path,
.socials a:hover svg circle {
  fill: #FF9734;
}

.copy-right {
  border-top: 1px solid #353E4F;
  padding-top: 40px;
}

.copy-right {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 40px;
}

.copy-right p {
  font-size: 15px;
  font-weight: 400;
  padding-bottom: 0;
  color: var(--white);
}

.copy-right span {
  font-size: 15px;
  font-weight: 400;
  color: #808793;
  padding-left: 5px;
  text-transform: none;
}

@media (min-width: 1400px) {
  .container {
    max-width: 1170px;
  }
}

/*Responsive CSS*/
@media (max-width: 1199px) {
  body {
    font-size: 14px;
  }

  .logo {
    max-width: 160px;
  }

  .btn {
    font-weight: 600;
  }

  .btn-primary {
    padding: 18px 30px;
  }

  .header li {
    margin-right: 25px;
  }

  .header li a {
    padding: 25px 0 20px;
  }

  .banner {
    padding: 155px 0 85px 0;
  }

  .banner-title .small-title {
    padding-bottom: 35px;
    font-size: 16PX;
  }

  h1,
  .h1 {
    font-size: 55px;
    line-height: 60px;
  }

  .banner-title p {
    padding: 30px 0;
    font-size: 16px;
  }

  .down-arrow {
    padding-top: 75px;
  }

  .title-box span {
    font-size: 12px;
  }

  .construcciones p {
    font-size: 16px;
  }

  .title-box p {
    padding-bottom: 32px;
  }

  .soluciones-title {
    padding-top: 32px;
  }

  .construcciones .btn-white.btn {
    margin-top: 40px;
  }

  .construcciones p {
    line-height: 22px;
  }

  .diseno {
    padding: 80px 0;
  }

  .diseno h2,
  .h2 {
    font-size: 38px;
    line-height: 44px;
  }

  .construcciones h3,
  .h3 {
    font-size: 30px;
    line-height: 32px;
  }

  .Nuestros h3 {
    padding-bottom: 25px;
  }

  .servicios-block p {
    font-size: 16px;
  }

  section,
  .section {
    padding-top: 80px;
  }

  h3,
  .h3 {
    font-size: 38px;
  }

  .owl-carousel .owl-nav button {
    width: 48px;
    height: 48px;
  }

  .Nuestros .hover-item h5 {
    padding-bottom: 20px;
    margin-bottom: 20px;
  }

  .Dejanos {
    padding-top: 40px;
  }

  .contacto h3 {
    font-size: 38px;
    padding: 15px 0 30px;
  }

  form .form-control,
  form .wpcf7-form-control:not(.wpcf7-submit) {
    padding: 15px 18px;
    margin-bottom: 10px;
  }

  section,
  .section {
    padding-bottom: 80px;
  }

  .clientes {
    padding: 50px 0 50px;
  }

  .cliente {
    padding: 55px 50px;
  }

  .clientes h3 {
    padding-bottom: 40px;
  }

  .cliente p {
    margin-bottom: 12px;
  }

  .cliente h6 {
    margin: 20px auto;
  }

  .footer-links {
    padding-bottom: 45px;
  }

  .copy-right {
    padding: 25px 0;
  }

  .footer-links {
    display: inline-flex;
    flex-wrap: wrap;
  }

  .footer-links .logo-two {
    width: 50%;
    order: 1;
  }

  .footer-links .socials {
    width: 50%;
    order: 2;
    justify-content: flex-end;
  }

  .footer-links .contacts {
    width: 100%;
    order: 3;
    padding-top: 25px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .contacts .icon {
    display: flex;
  }
}


@media (max-width: 991px) {
  .btn {
    min-width: 185px;
  }

  .top-right a {
    height: 40px;
  }

  .btn.btn-primary {
    margin-top: 20px;
  }

  .logo {
    max-width: 150px;
  }

  .btn-primary {
    padding: 16px 28px;
  }

  .header li a {
    padding: 20px 0 15px;
  }

  .banner {
    padding: 80px 0 75px 0;
  }

  .banner-title .small-title {
    padding-bottom: 25px;
  }

  h1,
  .h1 {
    font-size: 48px;
    line-height: 52px;
  }

  .banner-title p {
    padding: 20px 0;
  }

  .down-arrow {
    padding-top: 65px;
  }

  .header-bottom {
    border: none;
  }

  .navbar-toggler {
    display: flex;
    margin-left: 10px;
  }

  .open-menu .navbar-toggler {
    z-index: 9;
  }

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

  .header-menu .container {
    position: fixed;
    top: 0;
    left: -310px;
    width: 274px;
    height: 100%;
    padding-top: 8px;
    padding-bottom: 30px;
    background-color: #fff;
    transition: all ease-in 0.3s;
    overflow-y: auto;
    z-index: 1;
  }

  .top-header {
    background-color: transparent;
  }

  .top-header {
    padding: 25px 0 0;
  }

  body.open-menu {
    overflow: hidden;
  }

  .open-menu .header-menu .container {
    left: 0;
  }

  .header-menu .container {
    display: block;
    padding: 15px;
    max-width: 100%;
  }

  .header-menu ul {
    display: block;
  }

  .header-menu ul li {
    margin: 0;
    padding: 0;
  }

  .header-menu ul li a {
    margin: 10px 0 0px;
    border-bottom-width: 2px;
    padding: 0 0 6px;
  }

  .telefono-right {
    padding-top: 25px;
  }

  .construcciones .images-block img {
    width: 100%;
  }

  .construcciones h3,
  .h3 {
    font-size: 28px;
    line-height: 28px;
  }

  .construcciones .btn {
    padding: 12px 18px;
  }

  .images-block-one {
    padding: 15px;
    width: 290px;
    left: -15px;
    bottom: -20px;
  }

  .title-box h3 {
    padding-top: 8px;
  }

  .title-box p {
    padding-bottom: 28px;
  }

  .soluciones-title {
    padding-top: 28px;
  }

  .construcciones .btn-white.btn {
    margin-top: 38px;
  }

  .diseno h2 {
    padding-top: 12px;
  }

  .diseno h2,
  .h2 {
    font-size: 30px;
    line-height: 36px;
  }

  .diseno .btn-primary {
    margin-top: 30px;
  }

  .diseno .btn-primary {
    padding: 18px 32px;
  }

  .construcciones {
    padding-top: 50px;
  }

  .images-block-two {
    justify-content: center;
    margin: 0 auto;
  }

  .Nuestros {
    padding-bottom: 30px;
  }

  .service-info {
    text-align: center;
  }

  .Nuestros h3 {
    font-size: 35px;
    padding-bottom: 18px;
  }

  .servicios .container {
    margin: 0 auto;
  }

  .servicios-block {
    padding: 20px;
  }

  .servicios-block h4 {
    padding: 25px 0 20px;
  }

  .servicios-block p {
    margin-top: 25px;
    padding-bottom: 0;
  }

  .servicios-block {
    box-shadow: 0px 0 18px 0px rgba(0, 0, 0, 0.10);
  }

  section,
  .section {
    padding-top: 60px;
  }

  h3,
  .h3 {
    font-size: 34px;
  }

  .owl-carousel .owl-nav button {
    width: 45px;
    height: 45px;
  }

  .Nuestros .hover-item h5 {
    padding-bottom: 15px;
    margin-bottom: 10px;
    font-size: 18px;
  }

  .Nuestros .hover-item {
    bottom: 30px;
  }

  .Dejanos {
    padding-top: 20px;
  }

  .contacto {
    padding-top: 30px;
  }

  .contacto h3 {
    font-size: 36px;
    padding: 10px 0 25px;
  }

  section,
  .section {
    padding-bottom: 60px;
  }

  .clientes {
    padding: 50px 0 50px;
  }

  .clientes h3,
  .h3 {
    font-size: 30px;
    line-height: 35px;
    padding-bottom: 35px;
  }

  .cliente p {
    line-height: 24px;
  }

  .cliente h6 {
    font-size: 18px;
    margin: 20px auto;
  }

  .cliente {
    padding: 45px 30px;
  }

  .copy-right {
    padding: 18px 0;
  }

  .footer-links {
    padding-bottom: 25px;
  }

  .footer-links .contacts {
    padding-top: 20px;
  }

  .footer {
    padding: 50px 0 0;
  }

  .contacts li:nth-child(2) {
    border: none;
  }

  .map-section {
    padding: 25px;
  }

  #map {
    height: 410px;
  }

  .contacts li a {
    padding: 0;
  }

  .contacts li {
    margin-top: 10px;
  }

  .header-menu a {
    display: flex;
    align-items: center;
  }

  .top-left a {
    padding: 0;
    margin-bottom: 12px;
    word-break: break-all;
    text-align: left;
  }

  .top-left img {
    margin-right: 10px;
  }

  .top-right {
    justify-content: start;
    padding-top: 5px;
  }

  .top-right a {
    border: 1px solid;
    width: 30px;
    height: 30px;
    margin-right: 10px;
  }
}


@media (max-width: 767px) {
  .top-header .container {
    display: block;
    align-items: center;
  }

  .top-header .top-left {
    text-align: center;
  }

  .top-right a img {
    max-width: 16px;
  }

  .top-right a:hover {
    border-color: #000;
  }

  .btn-primary {
    padding: 14px 24px;
  }

  .navbar-toggler {
    padding: 2px 6px;
  }

  .logo img {
    max-width: 110px;
  }

  .banner {
    padding: 115px 0 70px 0;
  }

  .banner-title .small-title {
    padding-bottom: 15px;
  }

  h1,
  .h1 {
    font-size: 42px;
    line-height: 47px;
  }

  .banner-title p {
    padding: 0 0 5px;
  }

  p {
    font-size: 16px;
    line-height: 24px;
  }

  .down-arrow {
    padding-top: 45px;
  }

  .banner {
    padding: 50px 0 50px;
  }

  .construcciones .title-box {
    padding-top: 60px;
  }

  .construcciones h3,
  .h3 {
    font-size: 25px;
    line-height: 1.2;
  }

  .title-box h3 {
    padding-top: 6px;
  }

  .title-box p {
    padding-bottom: 20px;
  }

  .title-box p {
    padding-top: 0;
  }

  .soluciones-title {
    padding-top: 20px;
  }

  .diseno {
    padding: 50px 0;
  }

  .diseno h2 {
    padding-top: 10px;
  }

  .diseno h2,
  .h2 {
    font-size: 28px;
    line-height: 34px;
  }

  .diseno .btn-primary {
    padding: 14px 22px;
  }

  .servicios-block h4 {
    padding: 10px 0 10px;
  }

  .servicios-block p {
    margin-top: 10px;
    padding-bottom: 0;
  }

  .Nuestros h3 {
    font-size: 30px;
    padding: 5px 0 10px;
  }

  .Nuestros p {
    padding-bottom: 6px;
  }

  .Nuestros {
    padding-left: 20px;
    padding-right: 20px;
  }

  section,
  .section {
    padding-top: 40px;
  }

  .map-section {
    padding: 15px;
  }

  .Nuestros h3 {
    font-size: 26px;
  }

  .owl-carousel .owl-nav button.owl-next {
    margin-top: -23px;
  }

  .owl-carousel .owl-nav button {
    margin: 0;
  }

  .owl-carousel .owl-nav button {
    width: 35px;
    height: 35px;
  }

  .copy-right {
    padding: 15px 0;
    flex-direction: column;
    justify-content: center;
    text-align: center;
  }

  .contacto h3 {
    font-size: 30px;
    padding: 0 0 20px;
  }

  section,
  .section {
    padding-bottom: 50px;
  }

  #map {
    height: 350px;
  }

  .clientes h3,
  .h3 {
    font-size: 24px;
    line-height: 30px;
    padding-bottom: 30px;
  }

  .cliente h6 {
    font-size: 16px;
    margin: 18px auto;
  }

  .copy-right p {
    padding-bottom: 8px;
  }

  .designby img {
    max-width: 100px;
  }

  .clientes {
    padding: 50px 0px;
  }

  .cliente {
    padding: 20px 20px;
  }

  .cliente p {
    margin-bottom: 6px;
  }

  .owl-carousel .owl-dots {
    padding-top: 35px;
  }

  .owl-carousel button.owl-dot,
  .owl-carousel button.owl-dot.active {
    width: 13px;
    height: 13px;
    margin: 0 5px;
  }

  .owl-carousel .owl-dots {
    padding-top: 25px;
  }

  .footer-links .contacts {
    padding-top: 18px;
  }

  .footer-links {
    padding-bottom: 20px;
  }

  .footer-links .logo-two {
    width: 25%;
  }

  .contacts li {
    border: none;
  }

  .btn {
    min-width: 130px;
  }

  .servicios {
    padding-top: 50px;
  }

  .servicios .Nuestros {
    padding: 0 0 32px;
  }

  .Nuestros {
    text-align: center;
    padding: 40px 20px 48px;
  }

  .imagenes {
    padding-bottom: 25px;
  }

  form .form-control,
  form .wpcf7-form-control:not(.wpcf7-submit) {
    padding: 10px 16px;
    font-size: 14px;
  }

  .form-control {
    padding: 10px 16px;
    height: 115px;
  }

  textarea.form-control {
    font-size: 14px;
  }

  .Dejanos .btn-primary {
    padding: 14px 45px;
  }

  header .btn {
    padding: 14px 20px;
  }
}


@media (max-width: 575px) {
  .logo img {
    max-width: 90px;
  }

  .navbar-toggler-icon {
    width: 22px;
    height: 22px;
  }

  .navbar-toggler.active .navbar-toggler-icon {
    background-position: 6px 5px;
  }

  .btn-primary {
    padding: 12px 20px;
  }

  .banner {
    background-position: 80% 50%;
  }

  .banner-title .small-title {
    padding-bottom: 15px;
  }

  h1,
  .h1 {
    font-size: 36px;
    line-height: 40px;
  }

  .images-block-one img {
    width: 180px;
  }

  .images-block-one {
    left: 0px;
    width: 219px;
    bottom: 0;
  }

  .construcciones .title-box {
    padding-top: 30px;
  }

  .title-box h3 {
    padding-top: 4px;
    font-size: 24px;
  }

  .title-box p {
    font-size: 13px;
  }

  .title-box p {
    padding-bottom: 15px;
  }

  .construcciones {
    padding-bottom: 50px;
  }

  .construcciones p {
    font-size: 14px;
  }

  .construcciones .btn-white.btn {
    margin-top: 30px;
  }

  .soluciones-title {
    padding-top: 15px;
  }

  .diseno h2 {
    padding-top: 8px;
  }

  .diseno .btn-primary {
    padding: 16px 26px;
  }

  .diseno .btn-primary {
    margin-top: 16px;
  }

  .images-block-one {
    padding: 8px;
  }

  .Nuestros h3 {
    font-size: 24px;
    line-height: 30px;
  }

  h4 {
    font-size: 20px;
  }

  .Nuestros {
    padding-bottom: 20px;
  }

  section,
  .section {
    padding-top: 30px;
  }

  .contacto h3 {
    font-size: 24px;
    padding: 5px 0 22px;
    line-height: 28px;
  }

  #map {
    height: 300px;
  }

  .clientes h3,
  .h3 {
    font-size: 20px;
    line-height: 24px;
    padding-bottom: 24px;
  }

  .cliente {
    padding: 25px 20px;
  }

  .clientes .cliente p {
    padding-bottom: 8px;
  }

  .cliente h6 {
    margin: 14px auto;
  }

  .owl-carousel .owl-dots {
    padding-top: 30px;
  }

  .footer-links {
    padding-bottom: 16px;
  }

  .footer-links .logo-two {
    width: auto;
  }

  .footer-links .logo-two img {
    max-width: 100px;
  }

  .footer-links .contacts {
    padding-top: 20px;
    flex-direction: column;
    align-items: center;
  }

  .socials svg {
    height: 22px;
    width: 22px;
  }

  .copy-right {
    padding: 12px 0;
  }

  .contacts .icon {
    margin: 0;
  }

  .contacts li {
    padding: 0;
  }

  .contacts li a {
    padding: 0;
  }

  .copy-right span {
    display: block;
  }

  .down-arrow img {
    max-width: 20px;
  }

  .diseno span {
    font-size: 13px;
  }

  .construcciones .btn-white.btn {
    width: 100%;
    justify-content: center;
  }

  .images-block-two {
    width: 50px;
    height: 50px;
  }

  .images-block-two img {
    max-width: 26px;
  }

  .servicios .col-lg-4 {
    padding-bottom: 20px;
  }

  .Nuestros {
    padding-top: 30px;
  }

  .imagenes {
    padding-bottom: 15px;
  }

  .Nuestros h3 {
    padding: 5px 0 10px;
  }

  .footer-links .socials {
    width: 25%;
    justify-content: start;
    width: auto;
  }

  header .btn {
    padding: 14px 20px;
  }

  .Dejanos .btn {
    width: 100%;
  }

  .diseno h2,
  .h2 {
    font-size: 26px;
    line-height: 32px;
  }

  .contacts li+li {
    margin-top: 10px;
  }

  .contacts li {
    margin: 0;
  }
}

@media (max-width: 400px) {
  .contacts {
    flex-direction: column;
    align-items: center;
  }

  .contacts .icon {
    margin: 0;
  }

  .contacts li a {
    padding: 0;
  }

  .contacts .icon {
    flex-direction: column;
    align-items: center;
  }

  .contacts img {
    padding-right: 0;
    margin-bottom: 5px;
  }

  .contacts li+li {
    margin-top: 18px;
  }
}

@media (max-width: 320px) {
  .logo {
    max-width: 100px;
  }

  .header .btn-primary {
    padding: 10px 12px;
  }

  h1,
  .h1 {
    font-size: 28px;
    line-height: 38px;
  }

  .banner {
    padding: 50px 0 50px 0;
  }

  .down-arrow {
    padding-top: 45px;
  }

  .top-left {
    text-align: center;
  }

  .navbar-toggler {
    margin-left: 6px;
    padding: 1px 4px;
  }

  .header-bottom .btn:hover::before {
    height: 100%;
    width: 100%;
  }

  .header .btn-primary {
    padding: 8px 8px;
    font-size: 12px;
    min-width: 10px;
  }

  .images-block-one {
    width: 210px;
  }

  .title-box h3 {
    padding-top: 4px;
  }

  .title-box p {
    padding-bottom: 10px;
  }

  .title-box p {
    padding-top: 5px;
  }

  .construcciones h3,
  .h3 {
    font-size: 26px;
    line-height: 28px;
  }

  .soluciones-title {
    padding-top: 10px;
  }

  .construcciones .btn-white.btn {
    margin-top: 25px;
  }

  .diseno span {
    font-size: 12px;
  }

  .diseno h2 {
    padding-top: 8px;
  }

  .diseno h2,
  .h2 {
    font-size: 20px;
  }

  .Nuestros {
    padding-bottom: 25px;
  }

  .Nuestros h3 {
    font-size: 20px;
    padding-top: 5px;
    line-height: 1.2;
  }

  .servicios .col-lg-4 {
    padding-bottom: 20px;
  }

  .service-info h4 {
    font-size: 20px;
  }

  section,
  .section {
    padding-top: 20px;
  }

  .contacto h3 {
    font-size: 28px;
    padding: 10px 0 16px;
  }

  .Dejanos {
    padding-top: 10px;
  }

  #map {
    height: 300px;
  }

  .clientes {
    padding: 50px 0;
  }

  .cliente {
    padding: 16px 16px;
  }

  .clientes h3,
  .h3 {
    font-size: 14px;
    line-height: 16px;
    padding-bottom: 16px;
  }

  .cliente h6 {
    margin: 10px auto;
  }

  .clientes .cliente p {
    padding-bottom: 2px;
  }

  .cliente p {
    font-size: 14px;
  }

  .owl-carousel .owl-dots {
    padding-top: 14px;
  }

  .contacts .icon {
    margin: 1px;
  }

  .contacts li a {
    font-size: 14px;
  }

  .footer-links {
    padding-bottom: 10px;
  }

  .copy-right span {
    display: block;
  }

  .footer-links .logo-two {
    width: 30%;
  }

  .footer-links .contacts {
    padding-top: 10px;
  }
}

#wspModal .modal-content {
  border-radius: 8px;
  border: none !important;
}

#wspModal .modal-content .btn_popup {
  background: #51c045;
  width: 100%;
  color: #fff;
  padding: 12px 20px;
  font-size: 18px;
  border-radius: 10px;
  border: none
}

#wspModal .modal-content form .form-group:last-child {
  margin-bottom: 0
}

#wspModal .modal-body {
  background: #f3f3f5;
  padding: 30px 25px;
  margin-bottom: 30px;
}

#wspModal .modal-body .form-control {
  background: #fff;
  font-size: 17px;
}

#wspModal .modal-content .btn:hover,
.modal-content .btn:focus {
  background: #41b035;
}

#wspModal .modal-header {
  background: #51c045;
  border: none;
  text-align: center;
  display: block;
  border-radius: 8px 8px 0 0;
  position: relative
}

#wspModal .modal-header h5 {
  color: #fff;
  padding-bottom: 0;
  font-size: 22px;
  font-weight: 400;
  text-transform: uppercase
}

#wspModal .modal-header h5 img {
  margin-right: 10px;
}

#wspModal .close {
  position: absolute;
  top: -14px;
  right: -10px;
  z-index: 1;
  opacity: 1 !important
}

#wspModal .close_modal {
  border: none;
  border-radius: 50%;
  position: absolute;
  top: -18px;
  right: -13px;
}

#wspModal .modal-backdrop.show {
  opacity: .8;
}

#wspModal .form-group:after {
  display: block;
  clear: both;
  content: "";
}

#wspModal .form-control {
  height: 54px;
  padding: 10px 24px;
  color: #7f7f7f;
  font-weight: 300;
  font-size: 18px;
  border-color: #f0f0f0;
  border-radius: 10px;
  margin-bottom: 0;
  appearance: none;
  transition: all ease .4s;
  margin: 10px 0;
}

#wspModal .form-control:focus {
  border-color: #f0f0f0;
  box-shadow: none;
}

#wspModal .form-control::placeholder {
  color: #7f7f7f;
}

#wspModal textarea.form-control {
  height: 125px;
  resize: none;
  margin-bottom: 50px;
}

#wspModal .modal.show .modal-dialog {
  max-width: 500px !important;
}

.converse-menu-title{
  color: #fff !important;
  text-transform: none !important;
  font-weight: normal !important;
  font-size: 14px !important;
}
.converse-menu-icon{
  color: #fff !important;
}