@font-face {
  font-family: Lovelo;
  src: url('../fonts/Lovelo-Black.otf') format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: auto;
}

:root {
  --black: black;
  --light-grey: #d6d6d6;
  --grey: #858585;
  --dark-grey: #333;
  --white: white;
  --medium-sea-green: #2ac176;
  --medium-grey: #a1a1a1;
}

h1 {
  margin-top: 20px;
  margin-bottom: 10px;
  font-size: 38px;
  font-weight: 700;
  line-height: 44px;
}

h2 {
  color: #323232;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 20px;
  font-family: Oswald, sans-serif;
  font-size: 32px;
  font-weight: 600;
  line-height: 43px;
}

h3 {
  margin-top: 0;
  margin-bottom: 10px;
  font-size: 24px;
  font-weight: 700;
  line-height: 30px;
}

h4 {
  color: #323232;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 6px;
  font-family: Oswald, sans-serif;
  font-size: 14px;
  font-weight: 600;
  line-height: 24px;
}

h5 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
}

h6 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 700;
  line-height: 18px;
}

p {
  color: #969696;
  margin-top: 0;
  margin-bottom: 5px;
  font-family: Lekton, sans-serif;
  line-height: 26px;
}

.button {
  color: #fff;
  text-align: center;
  background-color: #2ac176;
  border-radius: 3px;
  padding: 10px 15px 8px;
  font-family: Lekton, sans-serif;
  text-decoration: none;
  transition: all .5s;
  display: inline-block;
}

.button:hover {
  background-color: #333;
}

.button.btn-news {
  width: 100%;
  margin-top: 8px;
  display: block;
}

.button.btn-news.c-btn {
  margin-top: 15px;
}

.button.btn-pj {
  margin-right: 8px;
}

.nav-section {
  text-align: center;
  padding-top: 50px;
  padding-bottom: 30px;
  position: relative;
}

.cneter {
  text-align: center;
}

.tagline {
  color: #969696;
  padding-top: 25px;
  padding-bottom: 25px;
  font-family: Lekton, sans-serif;
  font-size: 14px;
  display: block;
}

.tagline.port {
  color: var(--black);
  margin-bottom: 20px;
  padding-top: 0;
  padding-bottom: 0;
  font-family: Montserrat, sans-serif;
  line-height: 26px;
}

.tagline.port.inside {
  margin-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
}

.tagline.port.inside.hidden-desktop {
  display: none;
}

.tagline.port.ft {
  margin-top: 10px;
}

.tagline.main {
  display: none;
}

.nav-link {
  color: #adadad;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin: 15px;
  padding-bottom: 0;
  font-family: Oswald, sans-serif;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  transition: all .5s;
  display: inline-block;
}

.nav-link:hover {
  color: #3b3b3b;
}

.nav-link.w--current {
  color: #3b3b3b;
  border-bottom-color: #2ac176;
}

.content {
  position: relative;
}

.portfolio-section {
  background-color: #f0f0f0;
  padding-top: 80px;
  padding-bottom: 80px;
}

.div-portfolio {
  margin-left: 180px;
  margin-right: 180px;
}

.portfolio-img {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  margin-bottom: 60px;
  padding-left: 30px;
  padding-right: 30px;
}

.small-footer {
  padding-top: 30px;
  padding-bottom: 30px;
}

.text-div {
  text-align: center;
  background-color: #fff;
  border-bottom: 1px solid #e8e8e8;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  padding: 20px 5px;
}

.text-div.tm {
  z-index: 1;
  margin-left: 5px;
  margin-right: 5px;
  position: relative;
}

.img-port {
  width: 100%;
  position: relative;
  overflow: hidden;
}

.portfolio-overlay {
  z-index: 1;
  background-color: #0000;
  width: 100%;
  height: 100%;
  transition: all .3s;
  position: absolute;
  overflow: visible;
}

.portfolio-overlay:hover {
  background-color: #fdd400cc;
}

.portfolio-overlay.photo2:hover {
  background-color: #4c4d4ff2;
}

.portfolio-overlay.photo3:hover {
  background-color: #de5947f2;
}

.portfolio-overlay.photo4:hover {
  background-color: #ffddc1f2;
}

.portfolio-overlay.photo5:hover {
  background-color: #f4504ef2;
}

.portfolio-overlay.photo6:hover {
  background-color: #ffb700e0;
}

.portfolio-overlay.photo7:hover {
  background-color: #bebebef2;
}

.portfolio-overlay.photo8 {
  border-radius: 0;
}

.portfolio-overlay.photo8:hover {
  background-color: #018bc6e6;
}

.portfolio-overlay.photo9 {
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.portfolio-overlay.photo9:hover {
  background-color: #f2f2f2f2;
}

.port-wrapper {
  border-radius: 0;
  position: relative;
  overflow: hidden;
}

.ico {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
  display: block;
  position: relative;
  top: 40%;
}

.contact-section {
  color: #333;
  background-color: #323232;
  position: relative;
  overflow: hidden;
}

.con {
  color: #fff;
  margin-bottom: 20px;
  font-weight: 600;
}

.cont {
  color: #d6d6d6;
  font-family: Montserrat, sans-serif;
  line-height: 26px;
}

.newsleter-wrapper {
  margin-top: 25px;
}

.newssleter-field {
  text-align: center;
  text-transform: none;
  border-style: none;
  border-radius: 3px;
  font-size: 13px;
}

.newssleter-field.c-from {
  text-align: left;
}

.newssleter-field.c-from.c-area {
  padding-bottom: 120px;
}

.news-wrapper {
  display: block;
}

.map-wrapper {
  margin-top: 24px;
}

.map {
  height: 200px;
}

.open-contact {
  z-index: 10;
  text-align: center;
  background-color: #2ac176;
  border-radius: 10px;
  width: auto;
  height: 45px;
  margin-top: 20px;
  margin-right: 20px;
  padding: 11px 20px 0;
  transition: all .5s;
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  overflow: visible;
}

.row-section {
  margin-top: 70px;
  margin-bottom: 70px;
}

.plus {
  float: left;
}

.overlay {
  z-index: 2;
  background-color: #000000b3;
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  inset: 0;
}

.sucsess {
  text-align: center;
  background-color: #2ac176;
  border-radius: 5px;
  padding-top: 15px;
  padding-bottom: 15px;
}

.succ {
  color: #fff;
  margin-bottom: 0;
  line-height: 26px;
}

.error {
  text-align: center;
  border-radius: 5px;
  margin-top: 18px;
}

.err {
  color: #d96262;
  margin-bottom: 0;
  line-height: 26px;
}

.client-block {
  text-align: center;
  background-color: #fff;
  margin-left: 3px;
  margin-right: 3px;
  padding: 60px;
}

.row-clinet {
  margin-top: 6px;
}

.col-left {
  text-align: right;
}

.soc-ico {
  text-align: center;
  background-color: #f0f0f0;
  width: 50px;
  height: 50px;
  margin-left: 5px;
  margin-right: 10px;
  padding-top: 9px;
}

.soc-ico.right {
  margin-right: 0;
}

.team-wrapper {
  text-align: center;
  margin-left: 5px;
  margin-right: 5px;
  position: relative;
  overflow: visible;
}

.team-overlay {
  width: 100%;
  height: 100%;
  transition: all .5s;
  position: absolute;
}

.team-overlay:hover {
  background-color: #000000bd;
}

.social-team {
  position: relative;
  top: 45%;
}

.team {
  position: static;
  overflow: hidden;
}

.team:hover {
  background-color: #ffffffe6;
}

.contact-form {
  margin-left: 8px;
  margin-right: 8px;
}

.c-h4 {
  margin-bottom: 20px;
}

.web-link {
  color: var(--light-grey);
  text-decoration: none;
  transition: all .5s;
}

.web-link:hover {
  color: #9e9e9e;
}

.web-link.dark {
  color: var(--grey);
  font-size: 12px;
  font-weight: 500;
  line-height: 24px;
  overflow: visible;
}

.web-link.dark:hover {
  color: var(--dark-grey);
}

.web-link.dark.smaller {
  font-size: 9px;
  line-height: 18px;
}

.photo-ctn {
  margin-bottom: 10px;
  margin-left: 6px;
  margin-right: 6px;
  position: relative;
}

.link-caption {
  color: #fff;
  background-color: #2ac176;
  padding: 10px 15px;
  text-decoration: none;
  transition: all .5s;
  position: absolute;
  bottom: 0;
  right: 0;
}

.link-caption:hover {
  background-color: #323232;
}

.prj-photo {
  width: 100%;
}

.pj {
  margin-bottom: 20px;
}

.image {
  width: 100%;
}

.heading {
  text-transform: none;
  font-family: Montserrat, sans-serif;
}

.heading-2 {
  text-align: center;
  text-transform: none;
  margin-top: -73px;
  margin-bottom: 30px;
  font-family: Montserrat, sans-serif;
}

.heading-2.margin {
  margin-top: 0;
}

.heading-2.margin.h3 {
  font-weight: 600;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.link {
  color: var(--dark-grey);
  text-align: left;
  font-size: 12px;
  font-weight: 400;
  text-decoration: none;
}

.link:hover {
  color: var(--grey);
}

.footer {
  text-align: right;
  margin-top: 10px;
}

.footer-text {
  padding-top: 0;
  padding-bottom: 19px;
}

.heading-3, .heading-4, .heading-5, .heading-6, .heading-7, .heading-8, .heading-9, .heading-10, .columns {
  display: none;
}

.text-block.left {
  text-align: center;
  margin-left: 0;
  padding-left: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
}

.text-block-2.right {
  text-align: center;
  margin-bottom: 0;
  margin-left: 0;
  font-size: 16px;
  line-height: 26px;
}

.column-header {
  margin-bottom: 60px;
}

.column-header.no-bottom-space {
  margin-bottom: 0;
}

.bold-text {
  letter-spacing: 0%;
}

.bold-text.right-push {
  padding-left: 0;
}

.bold-text.left-push {
  padding-left: 5px;
}

.right-push {
  padding-right: 5px;
}

.button-2 {
  background-color: #2ac176;
  border-radius: 5px;
  margin-top: 20px;
  margin-right: 20px;
  position: absolute;
  top: 0;
  right: 0;
}

.text-block-3 {
  float: left;
  text-decoration: none;
}

.text-block-3.reverse-text {
  color: var(--white);
  padding-top: 1px;
  padding-left: 15px;
  font-size: 16px;
}

.div-header {
  text-align: center;
  margin-top: 60px;
  margin-bottom: 60px;
}

.paragraph {
  color: var(--black);
  margin-bottom: 0;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 16px;
}

.link-dark {
  color: var(--black);
  text-decoration: none;
}

.link-dark:hover {
  opacity: .7;
}

html.w-mod-js [data-ix="move-up"] {
  opacity: 0;
  transform: translate(0, -100px);
}

html.w-mod-js [data-ix="display-none-on-load"] {
  height: 0;
}

html.w-mod-js [data-ix="opacity-0"] {
  opacity: 0;
  display: none;
}

html.w-mod-js [data-ix="move-uper"] {
  opacity: 0;
  transform: translate(0, -79px);
}

@media screen and (max-width: 991px) {
  .tagline.port.inside.hidden-desktop {
    display: block;
  }

  .tagline.port.inside.hidden-mobile {
    display: none;
  }

  .div-portfolio {
    margin-left: 24px;
    margin-right: 24px;
  }

  .portfolio-img {
    padding-left: 20px;
    padding-right: 20px;
  }

  .ico {
    top: 235px;
  }

  .ico.ipad {
    top: 411px;
  }

  .ico.ipad-m {
    top: 286px;
  }

  .client-block {
    padding: 30px;
  }

  .social-team {
    top: 83px;
  }

  .contact-form {
    margin-left: 0;
  }

  .col-space {
    margin-bottom: 30px;
  }

  .heading-2 {
    margin-top: 0;
  }
}

@media screen and (max-width: 767px) {
  .portfolio-section {
    padding-top: 50px;
    padding-bottom: 25px;
  }

  .div-portfolio {
    margin-left: 10px;
    margin-right: 10px;
  }

  .portfolio-img {
    padding-left: 20px;
    padding-right: 20px;
  }

  .ico {
    top: 173px;
  }

  .ico.ipad {
    top: 291px;
  }

  .ico.ipad-m {
    top: 220px;
  }

  .client-block {
    margin-bottom: 6px;
  }

  .row-clinet {
    margin-top: 0;
  }

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

  .social-team {
    top: 187px;
  }

  .contact-form {
    margin-right: 0;
  }

  .col-center {
    text-align: center;
  }

  .footer {
    text-align: center;
    padding-top: 25px;
  }

  .div-block {
    padding-top: 25px;
  }

  .text-block, .text-block-2 {
    text-align: center;
  }

  .div-header {
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 479px) {
  .nav-link {
    display: block;
  }

  .portfolio-section {
    padding-bottom: 25px;
  }

  .div-portfolio {
    margin-left: 10px;
    margin-right: 10px;
  }

  .portfolio-img {
    padding-left: 20px;
    padding-right: 20px;
  }

  .ico {
    top: 77px;
  }

  .ico.ipad {
    top: 139px;
  }

  .ico.ipad-m {
    top: 104px;
  }

  .row-section {
    margin-top: 30px;
    margin-bottom: 30px;
  }

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

  .social-team {
    top: 91px;
  }

  .photo-ctn {
    margin-left: 0;
    margin-right: 0;
  }

  .link-caption {
    font-size: 12px;
  }

  .col-center {
    text-align: center;
  }
}


@font-face {
  font-family: 'Lovelo';
  src: url('../fonts/Lovelo-Black.otf') format('opentype');
  font-weight: 600;
  font-style: normal;
  font-display: auto;
}