:root {
  --paragraphs: #313435;
  --heading: #181818;
  --accent: #272727;
  --background: #e6e6e6;
  --white: white;
  --border: #101b2233;
  --paragraphs-dark: #dadada;
  --info-text: #778697;
}

.w-layout-grid {
  grid-row-gap: 16px;
  grid-column-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

body {
  color: var(--paragraphs);
  letter-spacing: .13px;
  flex-direction: column;
  align-items: center;
  padding: 14px;
  font-family: Barlow, sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 170%;
  display: flex;
}

h1 {
  color: var(--heading);
  letter-spacing: -1.4px;
  margin-top: 0;
  margin-bottom: 28px;
  font-size: 70px;
  font-weight: 500;
  line-height: 100%;
}

h2 {
  color: var(--heading);
  letter-spacing: -1.4px;
  margin-top: 0;
  margin-bottom: 26px;
  font-size: 58px;
  font-weight: 500;
  line-height: 107%;
}

h3 {
  color: var(--heading);
  letter-spacing: -1.4px;
  margin-top: 0;
  margin-bottom: 22px;
  font-size: 46px;
  font-weight: 500;
  line-height: 110%;
}

h4 {
  color: var(--heading);
  letter-spacing: -1.2px;
  margin-top: 0;
  margin-bottom: 20px;
  font-size: 36px;
  font-weight: 500;
  line-height: 115%;
}

h5 {
  color: var(--heading);
  letter-spacing: -.8px;
  margin-top: 0;
  margin-bottom: 18px;
  font-size: 26px;
  font-weight: 500;
  line-height: 120%;
}

h6 {
  color: var(--heading);
  letter-spacing: -.2px;
  margin-top: 0;
  margin-bottom: 16px;
  font-size: 18px;
  font-weight: 500;
  line-height: 130%;
}

p {
  margin-bottom: 28px;
}

a {
  color: var(--heading);
  text-decoration: underline;
}

ul, ol {
  margin-top: 0;
  margin-bottom: 28px;
  padding-left: 34px;
}

li {
  padding-top: 3px;
  padding-bottom: 3px;
  padding-left: 7px;
}

strong {
  color: var(--heading);
  font-weight: 600;
}

em {
  font-style: italic;
}

blockquote {
  border-left: 1px solid var(--accent);
  margin-bottom: 28px;
  margin-left: 15px;
  padding: 2px 24px;
  font-size: 20px;
  font-style: italic;
  line-height: 165%;
}

figure {
  margin-top: 36px;
  margin-bottom: 36px;
}

figcaption {
  text-align: center;
  letter-spacing: .08px;
  margin-top: 12px;
  font-size: 16px;
  line-height: 160%;
}

.rich-text-block a {
  box-shadow: inset 0 -1px 0 0 var(--heading);
  color: var(--heading);
  text-decoration: none;
  transition: box-shadow .25s cubic-bezier(.215, .61, .355, 1);
  display: inline-block;
}

.rich-text-block a:hover {
  box-shadow: inset 0 -30px 0 0 var(--accent);
}

.section-hero-a {
  z-index: 10;
  background-color: var(--background);
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  min-height: 85vh;
  margin-bottom: 14px;
  display: flex;
  position: relative;
}

.navbar {
  background-color: var(--white);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  max-width: 1280px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  position: absolute;
  top: 28px;
  left: 28px;
  right: 28px;
  box-shadow: 0 10px 70px #101b2214;
}

.navbar.copy {
  position: fixed;
}

.nav-block {
  background-color: var(--accent);
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  display: flex;
}

.nav {
  justify-content: center;
  align-items: center;
  display: flex;
}

.logo {
  filter: invert();
  height: 55px;
}

.brand {
  justify-content: center;
  align-items: center;
  margin-left: 18px;
  margin-right: 18px;
  padding: 10px;
  display: flex;
}

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

.nav-link {
  opacity: 1;
  color: var(--white);
  text-align: center;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 27px 20px;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
  transition: opacity .25s cubic-bezier(.215, .61, .355, 1);
  display: flex;
}

.nav-link:hover {
  opacity: .65;
}

.nav-link.w--current {
  color: var(--white);
}

.nav-button {
  background-color: var(--heading);
  justify-content: center;
  align-items: center;
  margin-left: 15px;
  padding: 27px 35px;
  text-decoration: none;
  display: flex;
}

.text-button {
  color: var(--heading);
  text-align: center;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
}

.text-button.white {
  color: var(--white);
}

.icon-button {
  object-fit: contain;
  width: 4px;
  max-width: none;
  height: 8px;
  margin-left: 8px;
}

.icon-button.white {
  filter: invert();
}

.menu-button {
  position: relative;
}

.hero-a {
  z-index: 20;
  width: 100%;
  max-width: 1200px;
}

.background-video {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.heading-hero {
  color: var(--white);
  max-width: 730px;
  font-size: 4rem;
}

.heading-hero.dark {
  color: var(--heading);
}

.grid-hero-services {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  margin-top: 80px;
}

.text-hero-service {
  color: var(--white);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
}

.text-hero-service.white {
  color: var(--white);
}

.link-hero-service {
  width: 100%;
  text-decoration: none;
  position: relative;
}

.description {
  z-index: 50;
  background-color: var(--accent);
  width: 100%;
  position: absolute;
  overflow: hidden;
}

.line-block {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 3px;
  display: flex;
  position: relative;
}

.line-1px {
  background-color: var(--white);
  width: 100%;
  height: 1px;
}

.line-1px.dark {
  background-color: var(--heading);
}

.line-1px.opacity {
  background-color: var(--white);
  opacity: .73;
}

.line-full {
  background-color: var(--white);
  width: 100%;
  position: absolute;
  inset: 0%;
}

.line-full.dark {
  background-color: var(--heading);
}

.paragraph-description {
  margin-bottom: 0;
}

.paragraph-description.white {
  color: var(--white);
}

.description-block {
  border: 1px solid var(--background);
  width: 100%;
  padding: 20px 32px 25px;
}

.hero-service {
  justify-content: space-between;
  align-items: center;
  padding-bottom: 12px;
  display: flex;
}

.icon-arrow-a {
  filter: grayscale();
  width: 10px;
  max-width: none;
  height: 10px;
}

.icon-arrow {
  flex-direction: column;
  flex: none;
  justify-content: center;
  align-items: center;
  width: 10px;
  height: 10px;
  margin-left: 12px;
  display: flex;
  position: relative;
  overflow: hidden;
}

.icon-arrow-b {
  width: 10px;
  max-width: none;
  height: 10px;
  position: absolute;
  transform: translate(-120%, 120%);
}

.section {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 14px;
  padding: 110px 50px;
  display: flex;
  position: relative;
}

.section.background {
  background-color: var(--accent);
}

.section.background.white {
  background-color: var(--white);
}

.section.background.small {
  padding-bottom: 60px;
  padding-left: 0;
}

.content {
  width: 100%;
  max-width: 1200px;
}

.content.slim {
  max-width: 770px;
}

.grid-2-columns {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  grid-template-rows: auto;
  width: 100%;
  position: relative;
}

.grid-2-columns.grid-1 {
  grid-template-columns: 1fr;
}

.block-right {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 45px 3% 45px 5%;
  display: flex;
}

.button {
  background-color: var(--white);
  color: var(--white);
  justify-content: center;
  align-items: center;
  padding: 23px 35px;
  text-decoration: none;
  display: flex;
}

.button.dark {
  background-color: var(--heading);
}

.button.accent {
  background-color: var(--white);
}

.paragraph {
  color: var(--heading);
  max-width: 500px;
  margin-bottom: 36px;
}

.paragraph.white {
  color: var(--white);
}

.paragraph.white.bigger {
  max-width: 750px;
  font-size: 1.3rem;
}

.subtitle {
  justify-content: flex-start;
  align-items: center;
  margin-bottom: 8px;
  display: flex;
}

.line-subtitle {
  background-color: var(--heading);
  color: var(--white);
  width: 27px;
  height: 1px;
}

.line-subtitle.white {
  background-color: var(--white);
}

.text-subtitle {
  color: var(--heading);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-left: 12px;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
}

.text-subtitle.white {
  color: var(--white);
}

.heading {
  max-width: 700px;
}

.heading.white {
  color: var(--white);
}

.stats {
  background-color: var(--accent);
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  padding: 10px;
  display: flex;
}

.stats.full {
  background-color: var(--background);
  padding: 18px;
}

.heading-stats {
  max-width: 220px;
  margin-bottom: 0;
}

.numbers-stats {
  color: var(--heading);
  letter-spacing: -1.4px;
  margin-bottom: 12px;
  font-size: 58px;
  font-weight: 500;
  line-height: 100%;
}

.numbers-stats.full {
  font-size: 70px;
}

.icon-stats-block {
  background-color: var(--background);
  margin-bottom: auto;
  margin-left: auto;
  padding: 14px;
}

.icon-stats-block.black {
  background-color: var(--heading);
}

.stats-block {
  margin: 18px;
}

.icon {
  filter: brightness(0%) grayscale() invert();
  object-fit: contain;
  width: 37px;
  height: 37px;
  display: block;
}

.block-left {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 45px 10% 45px 0%;
  display: flex;
}

.image-block {
  width: 100%;
  position: relative;
}

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

.image-absolute {
  object-fit: cover;
  width: 54%;
  height: 60%;
  position: absolute;
  inset: auto -3% -3% auto;
  box-shadow: 0 35px 120px #101b2240;
}

.section-full {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 14px;
  display: flex;
  position: relative;
}

.grid-full {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  background-color: var(--heading);
  grid-template-rows: auto;
  width: 100%;
}

.block-full {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 160px 17%;
  display: flex;
}

.block {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  max-width: 550px;
  display: flex;
}

.image-bg-services {
  background-image: linear-gradient(270deg, var(--heading), transparent 30%), url('../images/IMG-20241109-WA0071_1.avif');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  width: 100%;
  min-height: 500px;
}

.grid-3-columns-full {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  width: 100%;
}

.image-gallery {
  object-fit: cover;
  width: 100%;
  height: 30vw;
}

.block-heading-text {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.grid-4-columns {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  width: 100%;
}

.block-heading {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 24px;
  display: flex;
}

.block-heading.top {
  margin-bottom: 40px;
}

.block-heading-button {
  margin-bottom: 30px;
  margin-left: 25px;
}

.expertise {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.expertise.full {
  background-color: var(--background);
  padding: 13% 15%;
}

.heading-expertise {
  letter-spacing: -.4px;
  max-width: 210px;
}

.icon-expertise-block {
  background-color: var(--heading);
  margin-bottom: 22px;
  padding: 14px;
}

.icon-expertise-block.white {
  background-color: var(--heading);
}

.paragraph-expertise {
  color: var(--heading);
  max-width: 270px;
  margin-bottom: 0;
}

.image-bg-testimonials {
  background-image: linear-gradient(270deg, var(--heading), transparent 30%), url('../images/IMG-20241109-WA0060_1IMG-20241109-WA0060.webp');
  background-position: 0 0, 50%;
  background-size: auto, cover;
  min-height: 670px;
}

.paragraph-testimonials {
  color: var(--paragraphs-dark);
  max-width: 500px;
  margin-bottom: 36px;
  font-size: 20px;
  font-style: italic;
  line-height: 170%;
}

.testimonials {
  justify-content: flex-start;
  align-items: center;
  display: flex;
}

.logo-testimonials {
  object-fit: contain;
  height: 50px;
  margin-right: 28px;
}

.info-testimonials {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.name-testimonials {
  color: var(--white);
  margin-bottom: 3px;
}

.position-testimonials {
  color: var(--info-text);
  font-size: 14px;
  line-height: 130%;
}

.collection-list-project {
  grid-column-gap: 30px;
  grid-row-gap: 55px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.link-image-project {
  width: 100%;
  margin-bottom: 25px;
  transition: opacity .35s cubic-bezier(.215, .61, .355, 1);
  display: block;
}

.link-image-project:hover {
  opacity: .8;
}

.image-project {
  object-fit: cover;
  width: 100%;
  height: 450px;
}

.image-project.large {
  height: 660px;
}

.link-block-project {
  width: 100%;
  text-decoration: none;
  display: block;
}

.block-project {
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 20px;
  display: flex;
}

.heading-project {
  max-width: 310px;
  margin-bottom: -5px;
}

.heading-project.large {
  max-width: 480px;
}

.text-project-type {
  color: var(--info-text);
  letter-spacing: 0;
  margin-bottom: 8px;
  font-size: 14px;
  line-height: 130%;
}

.empty-state {
  background-color: var(--background);
  padding: 14px 20px;
}

.empty-state.white {
  background-color: var(--white);
}

.text-message {
  color: var(--heading);
  font-size: 16px;
  line-height: 130%;
}

.grid-2-columns-full {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto;
  width: 100%;
}

.image-bg-banner {
  background-image: url('../images/IMG-20241109-WA0046_1IMG-20241109-WA0046.webp');
  background-position: 50%;
  background-size: cover;
}

.block-banner {
  background-color: var(--accent);
  background-image: url('../images/Untitled-design-78.png');
  background-position: 100%;
  background-repeat: no-repeat;
  background-size: contain;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 80px 17%;
  display: flex;
}

.heading-banner {
  max-width: 700px;
  margin-bottom: 38px;
}

.heading-banner.white {
  color: var(--white);
}

.section-footer {
  background-color: var(--accent);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: auto;
  padding: 110px 50px 82px;
  display: flex;
}

.grid-footer {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 2.5fr 1fr 1fr 1fr;
  width: 100%;
}

.block-footer {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  display: flex;
}

.logo-footer {
  filter: invert();
  height: 70px;
  margin-bottom: 32px;
}

.paragraph-footer {
  color: var(--paragraphs-dark);
  max-width: 350px;
}

.heading-footer {
  color: var(--white);
  text-align: left;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-top: 3px;
  margin-bottom: 32px;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
}

.link-footer {
  color: var(--paragraphs-dark);
  padding-top: 7px;
  padding-bottom: 7px;
  font-size: 18px;
  font-weight: 500;
  line-height: 130%;
  text-decoration: none;
  transition: color .25s cubic-bezier(.215, .61, .355, 1);
}

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

.grid-social {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-flow: column;
}

.icon-social {
  width: 20px;
  max-width: none;
  height: 20px;
}

.link-social {
  transition: opacity .25s cubic-bezier(.215, .61, .355, 1);
}

.link-social:hover {
  opacity: .5;
}

.block-hero-a {
  z-index: 20;
  background-image: linear-gradient(#0000, #000c);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 140px 50px 50px;
  display: flex;
  position: relative;
}

.block-accent {
  background-color: var(--accent);
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 160px 17%;
  display: flex;
}

.section-top {
  z-index: 10;
  background-color: var(--paragraphs-dark);
  flex-direction: row;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  margin-bottom: 14px;
  padding: 200px 50px 110px;
  display: flex;
  position: relative;
}

.collection-list-project-page {
  grid-column-gap: 30px;
  grid-row-gap: 80px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.text-field {
  border-style: none none solid;
  border-width: 1px;
  border-color: black black var(--white);
  background-color: var(--white);
  color: var(--heading);
  height: 52px;
  margin-bottom: 0;
  padding: 12px 20px;
  font-size: 18px;
  line-height: 130%;
  transition: border-color .35s cubic-bezier(.215, .61, .355, 1);
}

.text-field:focus {
  border-bottom-color: var(--accent);
}

.text-field::placeholder {
  color: #101b2280;
}

.form {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.form-block {
  margin-top: 5px;
  margin-bottom: 5px;
}

.textarea {
  border-style: none none solid;
  border-width: 1px;
  border-color: black black var(--white);
  background-color: var(--white);
  color: var(--heading);
  min-width: 100%;
  max-width: 100%;
  min-height: 150px;
  max-height: 350px;
  margin-bottom: 14px;
  padding: 12px 20px;
  font-size: 18px;
  line-height: 130%;
  transition: border-color .35s cubic-bezier(.215, .61, .355, 1);
}

.textarea:focus {
  border-bottom-color: var(--accent);
}

.textarea::placeholder {
  color: #101b2280;
}

.submit-button {
  background-color: var(--heading);
  color: var(--white);
  text-align: center;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 23px 35px;
  font-size: 14px;
  font-weight: 600;
  line-height: 130%;
  transition: color .35s cubic-bezier(.215, .61, .355, 1), background-color .35s cubic-bezier(.215, .61, .355, 1);
}

.submit-button:hover {
  background-color: var(--accent);
  color: var(--heading);
}

.success-message {
  background-color: #95daaa;
  padding: 24px;
}

.error-message {
  text-align: center;
  background-color: #ffaeae;
  margin-top: 16px;
  padding: 22px;
}

.image-bg-map {
  background-image: url('../images/pexels-ketan-kumawat-215630-724963_1.avif');
  background-position: 50%;
  background-size: cover;
  min-height: 670px;
}

.link-contact {
  width: 100%;
  text-decoration: none;
}

.contact {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  display: flex;
}

.text-contact {
  color: var(--white);
  text-align: right;
  margin-left: auto;
  font-size: 18px;
  font-weight: 500;
  line-height: 130%;
}

.icon-contact {
  filter: invert();
  width: 18px;
  max-width: none;
  height: 18px;
  margin-right: 8px;
}

.info-contact {
  align-items: center;
  margin-right: 20px;
  display: flex;
}

.grid-contacts {
  grid-column-gap: 0px;
  grid-row-gap: 20px;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  width: 100%;
}

.section-top-img {
  z-index: 10;
  background-color: var(--background);
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
  width: 100%;
  min-height: 70vh;
  margin-bottom: 14px;
  display: flex;
  position: relative;
}

.block-top-img {
  z-index: 20;
  background-image: linear-gradient(#0000, #000c);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 250px 50px 20px;
  display: flex;
  position: relative;
}

.background-image {
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  inset: 0%;
}

.grid-stats-full {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
}

.image-bg-about {
  background-image: url('../images/pexels-ketan-kumawat-215630-724963_1.avif');
  background-position: 50%;
  background-size: cover;
  min-height: 670px;
}

.grid-4-columns-full {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  width: 100%;
}

.grid-4-columns-full._3collums {
  grid-template-columns: 1fr 1fr 1fr;
}

.grid-image-about {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  width: 100%;
  height: 740px;
}

.image-bg-about-a1 {
  background-image: url('../images/IMG-20241109-WA0060_1IMG-20241109-WA0060.webp');
  background-position: 50%;
  background-size: cover;
}

.image-bg-about-a1.commercial {
  background-image: url('../images/IMG-20241218-WA0027_1.avif');
}

.image-bg-about-a2 {
  background-image: url('../images/IMG-20241109-WA0040_1IMG-20241109-WA0040.webp');
  background-position: 50%;
  background-size: cover;
}

.image-bg-about-a2.commercial {
  background-image: url('../images/IMG-20241109-WA0032_1.avif');
}

.image-bg-about-a3 {
  background-image: url('../images/IMG-20241109-WA0001_1.avif');
  background-position: 50%;
  background-size: cover;
}

.image-bg-about-a3.commercial {
  background-image: url('../images/IMG-20241109-WA0037_1IMG-20241109-WA0037.webp');
}

.image-bg-about-a4 {
  background-image: url('../images/IMG-20241109-WA0030_1.avif');
  background-position: 50%;
  background-size: cover;
}

.image-bg-about-a4.residential {
  background-image: url('../images/IMG-20241109-WA0024_1IMG-20241109-WA0024.webp');
}

.grid-project-page {
  grid-column-gap: 14px;
  grid-row-gap: 14px;
  grid-template-rows: auto;
  grid-template-columns: 1fr 1.5fr;
  width: 100%;
  margin-bottom: 14px;
  position: relative;
}

.project-content {
  background-color: var(--background);
  padding: 200px 15% 75px;
}

.image-project-page {
  object-fit: cover;
  width: 100%;
  height: 98vh;
  position: sticky;
  top: 14px;
}

.utility-page-wrap {
  background-color: var(--background);
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 60vh;
  margin-bottom: 14px;
  padding: 200px 50px 110px;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 310px;
  display: flex;
}

.utility-page-form {
  grid-column-gap: 12px;
  grid-row-gap: 12px;
  flex-direction: column;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  place-items: stretch stretch;
  width: 100%;
  display: grid;
}

.div-block {
  align-items: stretch;
  margin-top: 32px;
  display: flex;
}

.text-span {
  font-weight: 600;
}

.bold-text, .bold-text-2 {
  font-weight: 700;
}

.section-divider-bae_divider_1733110259766, .section-divider-bae_divider_1733110386815 {
  color: #fff;
  transform-style: preserve-3d;
  width: 100%;
  height: 90px;
  position: absolute;
  top: auto;
  bottom: -1px;
  left: 0;
  overflow: hidden;
  transform: rotateX(0)rotateY(180deg)rotateZ(180deg);
}

.section-divider-bae_divider_1733175302449 {
  z-index: 0;
  color: #fff;
  transform-style: preserve-3d;
  width: 100%;
  height: 70px;
  position: absolute;
  top: -1px;
  bottom: auto;
  left: 0;
  overflow: hidden;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.section-full-copy {
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-bottom: 14px;
  display: none;
  position: relative;
}

@media screen and (max-width: 991px) {
  body {
    padding: 10px;
  }

  h1 {
    font-size: 60px;
  }

  h2 {
    font-size: 48px;
  }

  h3 {
    font-size: 38px;
  }

  h4 {
    font-size: 30px;
  }

  h5 {
    font-size: 24px;
  }

  .section-hero-a {
    margin-bottom: 10px;
  }

  .brand {
    margin-left: 10px;
    margin-right: 10px;
  }

  .nav-menu {
    background-color: var(--background);
  }

  .nav-link {
    padding: 20px 10px;
  }

  .nav-button {
    margin-left: 0;
    padding: 20px 10px;
  }

  .menu-button {
    background-color: var(--accent);
    color: var(--heading);
    padding: 20px;
    font-size: 22px;
    line-height: 100%;
    transition: color .25s cubic-bezier(.215, .61, .355, 1), background-color .25s cubic-bezier(.215, .61, .355, 1);
  }

  .menu-button.w--open {
    background-color: var(--heading);
    color: var(--white);
  }

  .grid-hero-services {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .section {
    margin-bottom: 10px;
    padding: 90px 30px;
  }

  .grid-2-columns {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
  }

  .numbers-stats {
    font-size: 48px;
  }

  .numbers-stats.full {
    font-size: 58px;
  }

  .section-full {
    margin-bottom: 10px;
  }

  .block-full {
    padding: 120px 14%;
  }

  .grid-3-columns-full {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .grid-4-columns {
    grid-column-gap: 20px;
    grid-row-gap: 60px;
    grid-template-columns: 1fr 1fr;
  }

  .block-heading.top {
    margin-bottom: 30px;
  }

  .collection-list-project {
    grid-column-gap: 20px;
  }

  .image-project {
    height: 350px;
  }

  .image-project.large {
    height: 500px;
  }

  .grid-2-columns-full {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .block-banner {
    padding: 70px 14%;
  }

  .section-footer {
    padding-top: 90px;
    padding-bottom: 62px;
  }

  .block-hero-a {
    padding-bottom: 30px;
    padding-left: 30px;
    padding-right: 30px;
  }

  .block-accent {
    padding: 120px 14%;
  }

  .section-top {
    margin-bottom: 10px;
    padding: 180px 30px 90px;
  }

  .collection-list-project-page {
    grid-column-gap: 20px;
    grid-row-gap: 60px;
  }

  .section-top-img {
    min-height: 50vh;
    margin-bottom: 10px;
  }

  .block-top-img {
    padding-bottom: 15px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .grid-stats-full {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
  }

  .grid-4-columns-full {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    grid-template-columns: 1fr 1fr;
  }

  .grid-image-about {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    grid-template-columns: 1fr 1fr;
    height: 900px;
  }

  .grid-project-page {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    grid-template-columns: 1fr;
    margin-bottom: 10px;
  }

  .project-content {
    padding: 90px 14% 55px;
  }

  .image-project-page {
    height: 80vh;
    position: static;
  }

  .utility-page-wrap {
    min-height: 70vh;
    margin-bottom: 10px;
    padding: 180px 30px 90px;
  }

  .section-full-copy {
    margin-bottom: 10px;
  }
}

@media screen and (max-width: 767px) {
  h1 {
    font-size: 52px;
  }

  h2 {
    font-size: 40px;
  }

  h3 {
    font-size: 32px;
  }

  h4 {
    font-size: 26px;
  }

  h5 {
    font-size: 22px;
  }

  .grid-hero-services {
    grid-template-columns: 1fr;
    margin-top: 50px;
  }

  .description {
    display: none;
  }

  .section {
    padding-top: 70px;
    padding-bottom: 70px;
  }

  .grid-2-columns {
    grid-row-gap: 60px;
    grid-template-columns: 1fr;
  }

  .block-right {
    padding: 0 7%;
  }

  .numbers-stats.full {
    font-size: 40px;
  }

  .block-left {
    padding: 0 7%;
  }

  .grid-full {
    grid-template-columns: 1fr;
  }

  .block-full {
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .image-bg-services {
    background-image: linear-gradient(to top, var(--heading), transparent 30%), url('../images/img_3.jpg');
    background-position: 0 0, 50%;
    background-size: auto, cover;
    min-height: 500px;
  }

  .grid-3-columns-full {
    grid-template-columns: 1fr;
  }

  .image-gallery {
    height: 40vw;
  }

  .block-heading {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
  }

  .block-heading-button {
    margin-left: 0;
  }

  .image-bg-testimonials {
    background-image: linear-gradient(to top, var(--heading), transparent 30%), url('../images/img_4.jpg');
    background-position: 0 0, 50%;
    background-size: auto, cover;
    min-height: 500px;
  }

  .collection-list-project {
    grid-template-columns: 1fr;
  }

  .link-image-project {
    margin-bottom: 20px;
  }

  .image-project {
    height: 450px;
  }

  .heading-project {
    max-width: none;
  }

  .text-project-type {
    margin-bottom: 6px;
  }

  .grid-2-columns-full {
    grid-template-columns: 1fr;
  }

  .image-bg-banner {
    height: 300px;
  }

  .block-banner {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .section-footer {
    padding: 70px 14% 50px;
  }

  .grid-footer {
    grid-row-gap: 50px;
    grid-template-columns: 1fr;
  }

  .heading-footer {
    margin-bottom: 16px;
  }

  .block-accent {
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .section-top {
    padding-top: 170px;
    padding-bottom: 70px;
  }

  .collection-list-project-page {
    grid-row-gap: 55px;
    grid-template-columns: 1fr;
  }

  .form {
    grid-template-columns: 1fr;
  }

  .image-bg-map {
    min-height: 500px;
  }

  .grid-contacts {
    grid-row-gap: 30px;
  }

  .image-bg-about {
    min-height: 400px;
  }

  .grid-image-about {
    height: 700px;
  }

  .project-content {
    padding-top: 70px;
    padding-bottom: 40px;
  }

  .utility-page-wrap {
    padding-top: 170px;
    padding-bottom: 70px;
  }
}

@media screen and (max-width: 479px) {
  body {
    padding: 6px;
  }

  h1 {
    font-size: 42px;
  }

  h2 {
    font-size: 34px;
  }

  h3 {
    font-size: 28px;
  }

  h4 {
    font-size: 23px;
  }

  h5 {
    font-size: 20px;
  }

  h6 {
    font-size: 17px;
  }

  .section-hero-a {
    margin-bottom: 6px;
  }

  .navbar {
    top: 24px;
    left: 22px;
    right: 22px;
  }

  .nav-block {
    padding-right: 7px;
  }

  .nav-link {
    background-color: var(--heading);
  }

  .menu-button {
    background-color: var(--border);
    padding-bottom: 20px;
  }

  .menu-button.w--open {
    background-color: var(--background);
  }

  .icon-menu {
    filter: invert();
  }

  .heading-hero {
    font-size: 34px;
  }

  .section {
    margin-bottom: 6px;
    padding: 55px 16px;
  }

  .section.background.small {
    padding-bottom: 80px;
  }

  .numbers-stats {
    font-size: 40px;
  }

  .numbers-stats.full {
    font-size: 36px;
  }

  .section-full {
    margin-bottom: 6px;
  }

  .block-full {
    padding-top: 65px;
    padding-bottom: 65px;
  }

  .image-bg-services {
    background-image: linear-gradient(0deg, var(--heading), transparent 30%), url('../images/IMG-20241109-WA0071_1.avif');
    min-height: 350px;
  }

  .grid-3-columns-full {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
  }

  .image-gallery {
    height: 40vh;
  }

  .grid-4-columns {
    grid-row-gap: 50px;
    grid-template-columns: 1fr;
  }

  .block-heading.top {
    margin-bottom: 20px;
  }

  .expertise.full {
    padding-left: 10%;
    padding-right: 10%;
  }

  .heading-expertise, .paragraph-expertise {
    max-width: none;
  }

  .image-bg-testimonials {
    background-image: linear-gradient(0deg, var(--heading), transparent 30%), url('../images/IMG-20241109-WA0030_1.avif');
  }

  .image-project, .image-project.large {
    height: 350px;
  }

  .grid-2-columns-full {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
  }

  .image-bg-banner {
    height: 250px;
  }

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

  .paragraph-footer {
    margin-bottom: 10px;
  }

  .block-accent {
    padding-top: 65px;
    padding-bottom: 65px;
  }

  .block-accent._4 {
    padding-left: 5%;
  }

  .section-top {
    background-color: #18181800;
    margin-bottom: 6px;
    padding-bottom: 55px;
    padding-left: 16px;
    padding-right: 16px;
  }

  .text-field {
    border-bottom-color: var(--heading);
  }

  .image-bg-map {
    min-height: 400px;
  }

  .text-contact {
    font-size: 16px;
  }

  .section-top-img {
    margin-bottom: 6px;
  }

  .block-top-img {
    padding-bottom: 6px;
    padding-left: 20px;
    padding-right: 10px;
  }

  .grid-stats-full {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
    grid-template-columns: 1fr;
  }

  .image-bg-about {
    min-height: 350px;
  }

  .grid-4-columns-full {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
    grid-template-columns: 1fr;
  }

  .grid-4-columns-full._3collums {
    grid-template-columns: 1fr;
  }

  .grid-image-about {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
  }

  .grid-project-page {
    grid-column-gap: 6px;
    grid-row-gap: 6px;
    margin-bottom: 6px;
  }

  .project-content {
    padding: 55px 8% 20px;
  }

  .image-project-page {
    height: 70vh;
  }

  .utility-page-wrap {
    margin-bottom: 6px;
    padding: 150px 16px 55px;
  }

  .paragraph-2 {
    font-size: 1.2rem;
  }

  .section-divider-bae_divider_1733110259766 {
    height: 50px;
  }

  .section-divider-bae_divider_1733110386815 {
    height: 34px;
  }

  .section-divider-bae_divider_1733175302449 {
    height: 42px;
  }

  .section-full-copy {
    margin-bottom: 6px;
  }
}

#w-node-e35e4e79-1266-7d53-01dd-20fb71a18d0e-c9b5d1fb {
  grid-area: 2 / 2 / 3 / 3;
}

#Message.w-node-_8b8621dc-09df-292f-d2ba-e39b8e47637e-c9b5d200, #w-node-b4141052-95f1-638b-739d-5973369eda70-c9b5d200 {
  grid-area: span 1 / span 2 / span 1 / span 2;
}

#w-node-_53255d6a-bdd3-0d0b-71f4-fcc53478e345-c9b5d201 {
  grid-area: span 2 / span 2 / span 2 / span 2;
}

#w-node-_3bbdd4ff-270b-cef1-f67e-5479f9c783cb-c9b5d201 {
  grid-area: span 2 / span 1 / span 2 / span 1;
}

#w-node-_53255d6a-bdd3-0d0b-71f4-fcc53478e345-c9b5d209 {
  grid-area: span 2 / span 2 / span 2 / span 2;
}

#w-node-_3bbdd4ff-270b-cef1-f67e-5479f9c783cb-c9b5d209 {
  grid-area: span 2 / span 1 / span 2 / span 1;
}

@media screen and (max-width: 991px) {
  #w-node-e35e4e79-1266-7d53-01dd-20fb71a18d0e-c9b5d1fb {
    grid-area: span 1 / span 1 / span 1 / span 1;
  }
}

@media screen and (max-width: 767px) {
  #w-node-_9ed600c0-5f38-2aab-d429-11eac23a6307-c9b5d1fa {
    order: -9999;
  }

  #Message.w-node-_8b8621dc-09df-292f-d2ba-e39b8e47637e-c9b5d200, #w-node-b4141052-95f1-638b-739d-5973369eda70-c9b5d200 {
    grid-area: span 1 / span 1 / span 1 / span 1;
  }
}


