@font-face {
  font-family: SF Display;
  src: url('../fonts/System-San-Francisco-Display-Bold.ttf') format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: auto;
}

@font-face {
  font-family: SF Display;
  src: url('../fonts/System-San-Francisco-Display-Regular.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: auto;
}

@font-face {
  font-family: SF Display;
  src: url('../fonts/System-San-Francisco-Display-Ultralight.ttf') format("truetype");
  font-weight: 200;
  font-style: normal;
  font-display: auto;
}

:root {
  --light-grey: #f7f7f7;
  --white: white;
  --green: #366;
  --dark-green: #234f50;
  --orange: #cc4024;
  --dark-grey: #4d4d4d;
  --light-green: #3d7a7a;
  --green-60: #3669;
  --magenta: magenta;
  --black: black;
  --light-red: #d75834;
}

.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;
}

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

body {
  background-color: var(--light-grey);
  color: #4d4d4d;
  flex-direction: column;
  align-items: stretch;
  font-family: Lato, sans-serif;
  font-size: 16px;
  line-height: 24px;
  display: flex;
}

h1 {
  margin-top: 20px;
  margin-bottom: 10px;
  font-family: SF Display, sans-serif;
  font-size: 38px;
  font-weight: 700;
  line-height: 44px;
}

h2 {
  letter-spacing: -.2px;
  margin-top: 20px;
  margin-bottom: 10px;
  font-family: SF Display, sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 36px;
}

p {
  margin-bottom: 10px;
}

a {
  color: gray;
  text-decoration: none;
}

.footer-cont {
  grid-column-gap: 40px;
  grid-row-gap: 50px;
  grid-template-rows: auto;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  align-items: flex-start;
  width: 100%;
  max-width: 1440px;
  padding-left: 80px;
  padding-right: 80px;
  display: grid;
  position: relative;
}

.nav {
  z-index: 9999;
  background-color: var(--white);
  height: 80px;
  box-shadow: none;
  justify-content: center;
  align-items: stretch;
  display: flex;
  position: fixed;
  inset: 0% 0% auto;
}

.nav-menu {
  align-self: stretch;
  align-items: stretch;
  font-size: 16px;
  font-weight: 700;
  display: flex;
}

.nav-toggle {
  display: none;
}

.nav-logo {
  flex: none;
  align-items: center;
  display: flex;
  position: absolute;
  left: 80px;
}

.footer {
  background-color: var(--green);
  width: 100%;
  color: var(--white);
  justify-content: center;
  align-items: stretch;
  margin-top: auto;
  padding-top: 80px;
  padding-bottom: 80px;
  display: flex;
}

.nav-logo-img {
  height: 38px;
}

.footer-col {
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: -10px;
  display: flex;
}

.footer-col.footer-col-full {
  width: 100%;
  margin-bottom: 0;
  padding-right: 0%;
}

.footer-logo {
  align-items: center;
  margin-bottom: 10px;
  display: flex;
}

.footer-logo-img {
  object-fit: contain;
  object-position: 0% 50%;
  width: 200px;
  height: 40px;
}

.footer-title {
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 20px;
  font-weight: 600;
}

.footer-link {
  color: #fff9;
  margin-bottom: 10px;
  transition: color .3s cubic-bezier(.215, .61, .355, 1);
}

.footer-link:hover {
  color: #fff;
}

.footer-link.footer-link-bold {
  font-weight: 700;
}

.nav-cont {
  width: 100%;
  max-width: 1440px;
  color: var(--green);
  justify-content: center;
  align-items: center;
  padding-left: 80px;
  padding-right: 80px;
  display: flex;
  position: relative;
}

.footer-legal-text {
  color: #fff9;
  margin-top: 16px;
}

.footer-legal-text.footer-legal-text-link {
  margin-top: 0;
  font-weight: 700;
}

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

.footer-legal-text.footer-legal-text-link.footer-legal-text-link-first {
  margin-top: 14px;
}

.hero {
  height: 50vh;
  min-height: 400px;
  max-height: 640px;
  color: var(--white);
  background-image: url('../images/header-board-grad.png');
  background-position: 50%;
  background-size: cover;
  flex-direction: row;
  justify-content: center;
  display: flex;
}

.hero.hero-small {
  background-image: url('../images/header-building.png');
  background-position: 50%;
  background-size: cover;
  height: 360px;
  min-height: auto;
  max-height: none;
}

.hero.hero-small.hero-about {
  background-image: url('../images/header-canary.png');
}

.hero.hero-small.hero-test {
  background-image: url('../images/header-pen.png');
}

.hero.hero-small.hero-contact {
  background-image: url('../images/header-park.png');
}

.hero-cont {
  flex-direction: column;
  justify-content: center;
  width: 100%;
  max-width: 1440px;
  padding-left: 80px;
  padding-right: 80px;
  display: flex;
  position: relative;
}

.hero-cont.hero-cont-small {
  align-items: center;
}

.hero-header {
  margin-top: 8px;
  margin-bottom: 8px;
  font-size: 84px;
  line-height: 84px;
}

.hero-header.hero-header-title {
  font-size: 124px;
  line-height: 124px;
}

.social {
  background-color: var(--green);
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  margin-bottom: 0;
  margin-left: 2px;
  margin-right: 2px;
  transition: background-color .3s cubic-bezier(.215, .61, .355, 1);
  display: flex;
}

.social:hover {
  background-color: var(--dark-green);
}

.hero-socials {
  background-color: var(--white);
  height: 64px;
  margin-right: -4px;
  padding-top: 4px;
  padding-left: 2px;
  padding-right: 2px;
  display: flex;
  position: absolute;
  inset: auto 80px 0% auto;
}

.social-img {
  filter: invert();
  width: 30px;
  height: 30px;
}

.hero-clients {
  grid-column-gap: 2vw;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: column;
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding: 30px 80px;
  display: grid;
}

.hero-client {
  object-fit: contain;
  width: 100%;
  height: 54px;
}

.section {
  flex-direction: row;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  margin: 120px auto;
  display: flex;
}

.section.section-flex {
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  max-width: 1440px;
  margin-top: 140px;
  margin-bottom: 140px;
  padding-left: 80px;
  padding-right: 80px;
}

.section.section-flex.section-hidden {
  display: flex;
}

.section.section-flex.section-flex-service {
  align-items: center;
  margin-bottom: 0;
  display: none;
}

.section.section-flex.section-flex-service.section-flex-tests-last {
  margin-bottom: 140px;
}

.section.section-flex.section-flex-smalltopmargin {
  margin-top: 120px;
}

.section.section-cta {
  flex-direction: column;
  align-items: center;
  margin-top: 90px;
  margin-bottom: 90px;
  padding-left: 0;
  padding-right: 0;
}

.section.section-contact {
  align-items: center;
}

.section.section-vertical {
  flex-direction: column;
  align-items: center;
  max-width: 1440px;
  padding-left: 80px;
  padding-right: 80px;
}

.section.section-static {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-direction: row;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  max-width: 1440px;
  padding-left: 80px;
  padding-right: 80px;
  display: flex;
  overflow: visible;
}

.section-home-text {
  width: 50%;
}

.section-home-text-block {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 720px;
  margin-right: auto;
  padding: 140px 80px 100px 120px;
  display: flex;
  position: relative;
}

.section-home-text-block.section-home-text-block-last {
  min-height: 50vh;
}

.link-home-service {
  opacity: .3;
  color: var(--green);
  font-size: 24px;
  font-weight: 400;
  line-height: 36px;
}

.link-home-service.w--current {
  opacity: 1;
}

.h1-large {
  color: var(--green);
  letter-spacing: -1px;
  margin-top: 0;
  font-size: 56px;
  line-height: 60px;
}

.h1-large.h1-large-home {
  margin-bottom: 24px;
}

.heading-sub {
  color: gray;
  letter-spacing: 5px;
  text-transform: uppercase;
  margin-bottom: 4px;
  font-family: Montserrat, sans-serif;
  font-size: 18px;
  line-height: 24px;
}

.p-single {
  width: 100%;
  max-width: 420px;
  margin-bottom: 40px;
}

.heading-line {
  background-color: var(--orange);
  width: 60px;
  height: 3px;
  margin-bottom: 20px;
}

.h2-home {
  color: var(--green);
  margin-top: 0;
  margin-bottom: 4px;
}

.h2-home.h2-home-welcome {
  font-size: 28px;
}

.section-home-number {
  color: var(--green);
  font-family: SF Display, sans-serif;
  font-size: 124px;
  font-weight: 700;
  line-height: 96px;
  position: absolute;
  inset: 140px auto auto 0;
}

.section-home-number.section-home-number-last {
  top: 140px;
}

.section-home-img {
  object-fit: cover;
  object-position: 0% 50%;
  width: 50vw;
  max-width: none;
  min-height: 540px;
  margin-bottom: 140px;
  display: block;
}

.section-home-text-sticky {
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
  max-width: 720px;
  margin-left: auto;
  padding: 60px 6% 60px 80px;
  display: flex;
  position: sticky;
  inset: 25vh 50% 25vh auto;
}

.section-flexchild {
  flex-direction: column;
  align-self: center;
  align-items: flex-start;
  width: 50%;
  padding-left: 100px;
  padding-right: 100px;
  display: flex;
}

.section-flexchild.section-flexchild-full {
  align-items: center;
  padding-left: 0;
  padding-right: 0;
}

.section-flexchild.section-flexchild-aboutdesc {
  align-items: flex-end;
  padding-left: 0;
}

.testimonial-title-cont {
  flex-direction: row;
  align-items: center;
  padding-bottom: 30px;
  display: flex;
}

.testimonial-title-img {
  object-fit: cover;
  border-radius: 50%;
  width: 80px;
  height: 80px;
  margin-right: 20px;
  display: none;
}

.testimonial-title-name {
  font-weight: 700;
}

.link-home {
  color: var(--green);
  font-weight: 700;
}

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

.link-home.link-home-dark.link-hidden {
  display: none;
}

.link-line {
  background-color: var(--orange);
  width: 40%;
  height: 3px;
  margin-top: 2px;
}

.link-line.link-line-dark {
  background-color: var(--dark-grey);
}

.section-wrapper {
  background-color: var(--white);
  width: 100%;
}

.section-wrapper.section-cta {
  background-color: var(--light-green);
  color: var(--white);
}

.hero-clients-bg {
  background-color: var(--white);
  width: 100%;
}

.section-home-text-blocks {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 720px;
  margin-right: auto;
  display: flex;
  position: relative;
}

.link-nav {
  border-top: 0 solid #0000;
  border-bottom: 0px solid var(--orange);
  height: 80px;
  color: var(--green);
  letter-spacing: .2px;
  align-items: center;
  margin-left: 20px;
  margin-right: 20px;
  padding-top: 8px;
  padding-bottom: 8px;
  font-weight: 700;
  transition: border-width .3s cubic-bezier(.215, .61, .355, 1), color .3s cubic-bezier(.215, .61, .355, 1);
  display: flex;
  position: relative;
}

.link-nav:hover {
  border-top-width: 4px;
  border-bottom-width: 4px;
}

.link-nav.w--current {
  color: var(--green);
  border-top-width: 4px;
  border-bottom-width: 4px;
}

.nav-search-toggle {
  flex-direction: column;
  flex: none;
  justify-content: flex-start;
  align-items: center;
  width: 48px;
  height: 48px;
  padding-top: 8px;
  transition: transform .3s cubic-bezier(.215, .61, .355, 1);
  display: flex;
  overflow: hidden;
}

.nav-search-toggle:hover {
  transform: scale(1.1);
}

.nav-search-img {
  width: 32px;
  height: 32px;
  padding: 6px;
}

.nav-search {
  justify-content: flex-end;
  align-items: center;
  display: flex;
  position: absolute;
  right: 80px;
}

.search {
  flex: none;
  align-items: center;
  margin-bottom: 0;
  display: flex;
  overflow: hidden;
}

.search-input {
  width: 160px;
  height: 32px;
  color: var(--green);
  background-color: #0000;
  border: 1px solid #0000;
  border-bottom-color: #ffffff4d;
  margin-bottom: 0;
  margin-left: 12px;
  padding: 0;
  font-size: 16px;
  line-height: 32px;
  transition: border-color .3s;
}

.search-input:hover {
  border-bottom-color: var(--green);
}

.search-input:focus {
  border-color: transparent transparent var(--green);
}

.search-input::placeholder {
  color: var(--green-60);
}

.search-button {
  display: none;
}

.cta-tagline {
  text-align: center;
  max-width: 100%;
  margin-top: 0;
  font-size: 36px;
  line-height: 54px;
}

.nav-close-img {
  width: 32px;
  height: 32px;
  padding: 6px;
}

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

.block-home-service {
  align-items: center;
  display: flex;
}

.block-home-service-tick {
  height: 20px;
  margin-right: 10px;
}

.section-flexchild-third {
  background-color: var(--white);
  border-radius: 24px;
  flex-direction: column;
  align-items: flex-start;
  width: 32%;
  margin-top: 80px;
  padding-left: 40px;
  padding-right: 40px;
  display: flex;
  box-shadow: 0 32px 64px #0000000d;
}

.p-tight {
  width: 100%;
  max-width: 420px;
  color: var(--dark-grey);
  margin-top: 0;
  margin-bottom: 20px;
}

.service-logo-img {
  width: 120px;
  height: 120px;
  margin-left: auto;
  margin-right: auto;
}

.service-logo {
  background-color: var(--light-grey);
  border-radius: 50%;
  margin: -100px auto 50px;
  padding: 40px;
  box-shadow: 0 16px 32px #00000014;
}

.service-desc {
  max-width: 420px;
  margin-right: auto;
  padding-right: 70px;
}

.section-service-test {
  background-color: var(--white);
  width: 400px;
  color: var(--dark-grey);
  flex-direction: column;
  justify-content: flex-start;
  align-self: stretch;
  margin-left: 5px;
  margin-right: 5px;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.section-service-test.test-collection-item {
  flex-flow: column;
  align-self: flex-start;
  max-width: 400px;
  margin-left: 0;
  margin-right: 0;
}

.section-service-test-img {
  object-fit: cover;
  align-self: stretch;
  width: 120px;
  max-width: none;
  height: 160px;
  display: none;
}

.section-service-test-top {
  background-color: var(--light-green);
  height: 140px;
  color: var(--white);
  flex: none;
  align-items: center;
  display: flex;
}

.section-service-test-info {
  flex-direction: column;
  flex: 1;
  justify-content: center;
  align-items: flex-start;
  padding: 20px 30px;
  display: flex;
}

.test-name.test-name-bold {
  font-weight: 700;
}

.test-name.test-name-inline {
  display: inline;
}

.test-para {
  width: 100%;
  margin-bottom: 0;
}

.test-para.test-para-services {
  margin-bottom: 20px;
}

.test-content {
  padding: 40px 30px;
}

.test-content.test-content-full {
  flex-direction: column;
  flex: 1;
  justify-content: space-between;
  align-items: flex-start;
  display: flex;
}

.cta-button {
  background-color: var(--white);
  color: var(--light-green);
  text-align: center;
  margin-top: 30px;
  padding: 30px;
  font-size: 20px;
  font-weight: 700;
  line-height: 20px;
  transition: color .3s cubic-bezier(.215, .61, .355, 1), background-color .3s cubic-bezier(.215, .61, .355, 1);
}

.cta-button:hover {
  background-color: var(--dark-green);
  color: var(--white);
}

.section-contact-cont {
  background-color: var(--white);
  width: 480px;
  padding: 60px;
}

.form-button {
  background-color: var(--light-green);
  flex: none;
  margin-left: 10px;
  margin-right: 10px;
  padding: 20px;
  font-weight: 700;
  line-height: 16px;
  transition: background-color .3s cubic-bezier(.215, .61, .355, 1);
}

.form-button:hover {
  background-color: var(--dark-green);
}

.form-field {
  border: 1px solid var(--light-grey);
  background-color: var(--light-grey);
  margin-bottom: 20px;
  padding: 12px;
  transition: background-color .3s cubic-bezier(.215, .61, .355, 1);
}

.form-field:hover {
  background-color: var(--white);
}

.form-field:focus {
  border-width: 1px;
  border-color: var(--light-grey);
  background-color: var(--white);
}

.form-label {
  height: 0;
  overflow: hidden;
}

.form-submit {
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
  margin-top: 30px;
  margin-left: -10px;
  margin-right: -10px;
  display: flex;
}

.recaptcha {
  margin-bottom: 20px;
  margin-left: 10px;
  margin-right: 10px;
}

.contact-desc {
  width: 360px;
  margin-left: 80px;
}

.contact-socials {
  height: 64px;
  margin-left: -2px;
  margin-right: 0;
  padding-top: 0;
  padding-left: 0;
  padding-right: 0;
  display: flex;
}

.client-grid {
  grid-row-gap: 24px;
  grid-template-rows: auto auto auto auto auto;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  margin-bottom: 40px;
}

.client-logo.client-logo-fh {
  padding-left: 5px;
  padding-right: 5px;
}

.test-collection-list {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-wrap: wrap;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: row;
  justify-content: center;
  place-items: stretch stretch;
  display: grid;
}

.service-tests {
  grid-column-gap: 20px;
  grid-row-gap: 40px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr 1fr;
  grid-auto-columns: 1fr;
  grid-auto-flow: row;
  width: 100%;
  display: flex;
}

.service-tests-wrapper {
  margin-left: -5px;
  margin-right: -5px;
  display: none;
}

.section-home-img-wrapper {
  width: 100%;
  overflow: hidden;
}

.about-image {
  width: 300px;
  display: block;
  position: absolute;
  transform: rotate(1.5deg);
}

.about-img-wrapper {
  background-color: #fff;
  justify-content: center;
  align-items: center;
  width: 420px;
  height: 420px;
  display: flex;
  position: relative;
  box-shadow: 0 32px 64px #0000000d;
}

.section-flexchild-content {
  position: relative;
}

.about-quotes {
  opacity: .04;
  filter: brightness(0%);
  width: 120px;
  position: absolute;
  inset: -20px auto auto -80px;
}

.about-quotes.about-quotes-bottom {
  inset: auto -80px -20px auto;
  transform: rotate(180deg);
}

.search-link-text {
  opacity: .6;
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 20px;
}

.search-title {
  color: var(--green);
  margin-top: 0;
  margin-bottom: 4px;
}

.search-item {
  max-width: 480px;
}

.search-result-wrapper {
  flex-direction: column;
  align-items: center;
  width: 100%;
  display: flex;
}

.search-result-list {
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  justify-items: stretch;
  margin-top: 60px;
  display: grid;
}

.search-empty {
  text-align: center;
  flex-direction: column;
  align-items: center;
  margin-top: 30px;
  margin-bottom: 30px;
  display: flex;
}

.search-empty-text {
  margin-bottom: 6px;
}

.search-item-link {
  width: 100%;
}

.testimonial-title-job-text {
  display: inline;
}

.hero-homeback {
  width: 100%;
}

.hero-header-line {
  background-color: var(--orange);
  width: 60px;
  height: 3px;
  margin-bottom: 20px;
  display: none;
}

.p-home-test {
  margin-top: 0;
  margin-bottom: 18px;
}

@media screen and (min-width: 1440px) {
  .test-collection-list {
    grid-template-columns: 1fr 1fr 1fr;
  }
}

@media screen and (max-width: 991px) {
  body {
    font-size: 14px;
    line-height: 21px;
  }

  .footer-cont {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr 1fr 1fr;
    grid-auto-columns: 1fr;
    justify-content: space-between;
    display: grid;
  }

  .nav-menu {
    background-color: var(--light-grey);
    flex-direction: column;
    align-items: flex-start;
    padding-left: 80px;
    padding-right: 80px;
    display: none;
    position: absolute;
    top: 80px;
    left: 0;
    right: 0;
    overflow: hidden;
  }

  .nav-toggle {
    cursor: pointer;
    justify-content: center;
    align-items: center;
    width: 80px;
    height: 80px;
    display: flex;
    position: absolute;
    inset: 0% 52px 0% auto;
  }

  .nav-logo {
    position: static;
  }

  .footer {
    font-size: 13px;
  }

  .nav-cont {
    justify-content: space-between;
    align-items: stretch;
  }

  .hero-header.hero-header-title {
    text-align: center;
    font-size: 100px;
    line-height: 100px;
  }

  .hero-socials {
    padding-top: 0;
    padding-bottom: 4px;
    position: absolute;
    top: 0;
  }

  .hero-clients {
    padding-top: 24px;
    padding-bottom: 24px;
    transform: translate(0);
  }

  .hero-client {
    height: 40px;
  }

  .section.section-flex.section-flex-service {
    flex-direction: column;
    align-items: stretch;
    margin-top: 100px;
  }

  .section.section-flex.section-flex-service.section-flex-tests-last {
    margin-bottom: 100px;
  }

  .section.section-flex.section-flex-about {
    flex-direction: column;
  }

  .section.section-flex.section-flex-home {
    flex-direction: column;
    margin-top: 120px;
    margin-bottom: 120px;
  }

  .section.section-flex.section-flex-smalltopmargin {
    flex-flow: column;
    margin-top: 100px;
  }

  .section.section-contact {
    flex-direction: column-reverse;
  }

  .section.section-home-welcome {
    flex-direction: column;
    margin-top: 90px;
    margin-bottom: 80px;
    padding-left: 80px;
    padding-right: 80px;
  }

  .section-home-text {
    width: 100%;
  }

  .section-home-text-block {
    width: 28%;
    margin-right: 0;
    padding: 0;
  }

  .section-home-text-block.section-home-text-block-last {
    min-height: auto;
  }

  .heading-sub {
    font-size: 14px;
    line-height: 20px;
  }

  .h2-home.h2-home-welcome {
    font-size: 24px;
    line-height: 32px;
  }

  .section-home-number {
    opacity: .2;
    top: -40px;
    left: -40px;
  }

  .section-home-number.section-home-number-last {
    top: -40px;
  }

  .section-home-img {
    display: none;
  }

  .section-home-text-sticky {
    width: 100%;
    margin-left: 0;
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
    position: static;
  }

  .section-flexchild, .section-flexchild.section-flexchild-full {
    width: 100%;
  }

  .section-flexchild.section-flexchild-full.section-flexchild-full-grid {
    margin-bottom: 90px;
  }

  .section-flexchild.section-flexchild-aboutdesc {
    align-items: center;
    width: 100%;
    margin-bottom: 100px;
    padding-left: 100px;
  }

  .section-flexchild.section-flexchild-gridtest {
    align-items: center;
    max-width: 480px;
    padding-left: 0;
    padding-right: 0;
  }

  .section-wrapper.section-cta {
    padding-left: 80px;
    padding-right: 80px;
  }

  .section-home-text-blocks {
    flex-direction: row;
    justify-content: space-between;
    max-width: none;
  }

  .link-nav {
    flex: none;
    align-self: auto;
    height: auto;
    margin-left: 0;
    margin-right: 0;
    font-size: 24px;
    font-weight: 400;
    line-height: 32px;
  }

  .link-nav:hover {
    border-top-width: 0;
    border-bottom-width: 0;
  }

  .link-nav.w--current {
    border-top-width: 0;
    border-bottom-width: 0;
    font-weight: 700;
  }

  .link-nav.link-nav-first {
    margin-top: 30px;
  }

  .link-nav.link-nav-last {
    margin-bottom: 30px;
  }

  .nav-search, .block-home-service {
    display: none;
  }

  .section-flexchild-third {
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    margin-top: 160px;
  }

  .section-flexchild-third.section-flexchild-third-first {
    margin-top: 80px;
  }

  .p-tight.p-tight-hori {
    margin-right: 20px;
  }

  .service-desc {
    width: 100%;
    max-width: none;
    margin-bottom: 60px;
    padding-right: 0;
    display: flex;
  }

  .section-service-test {
    width: 100%;
    max-width: 400px;
  }

  .section-service-test.section-servicetest-item {
    width: 400px;
    max-width: 48%;
    margin-left: auto;
    margin-right: auto;
  }

  .section-service-test-img {
    width: 100px;
  }

  .section-service-test-top, .test-content.test-content-full {
    width: 100%;
  }

  .form-submit {
    justify-content: center;
  }

  .contact-desc {
    text-align: center;
    flex-direction: column;
    align-items: center;
    margin-bottom: 72px;
    margin-left: 0;
    display: flex;
  }

  .client-grid {
    margin-bottom: 28px;
  }

  .test-collection-list {
    grid-template-columns: 1fr 1fr;
    grid-auto-flow: row;
  }

  .service-tests {
    flex-direction: row;
    justify-content: center;
    align-items: center;
  }

  .service-tests-wrapper {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }

  .nav-toggle-bar {
    background-color: var(--green);
    width: 24px;
    height: 2px;
    padding: 0;
    position: absolute;
  }

  .service-desc-title {
    flex: none;
    margin-right: 60px;
  }

  .service-richtext {
    column-count: 2;
    column-rule-style: none;
    column-rule-width: 0px;
    column-gap: 24px;
  }
}

@media screen and (max-width: 767px) {
  .footer-cont {
    grid-column-gap: 20px;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr 1fr;
    grid-auto-columns: 1fr;
    place-items: start;
    padding-left: 60px;
    padding-right: 60px;
    display: grid;
  }

  .nav-menu {
    padding-left: 60px;
    padding-right: 60px;
  }

  .nav-toggle {
    right: 32px;
  }

  .nav-cont {
    padding-left: 60px;
    padding-right: 60px;
  }

  .hero {
    height: 360px;
    min-height: auto;
    max-height: none;
  }

  .hero.hero-small {
    height: 240px;
  }

  .hero-cont {
    padding-left: 60px;
    padding-right: 60px;
  }

  .hero-header {
    font-size: 64px;
    line-height: 64px;
  }

  .hero-header.hero-header-title {
    font-size: 72px;
    line-height: 72px;
  }

  .social.social-hero {
    width: 40px;
    height: 40px;
  }

  .hero-socials {
    height: 44px;
    padding-bottom: 4px;
    top: -20px;
    right: 60px;
  }

  .social-img.social-img-hero {
    width: 24px;
    height: 24px;
  }

  .hero-clients {
    grid-column-gap: 20px;
    grid-template-rows: auto auto;
    padding-left: 60px;
    padding-right: 60px;
  }

  .section {
    margin-top: 100px;
    margin-bottom: 100px;
  }

  .section.section-flex {
    padding-left: 60px;
    padding-right: 60px;
  }

  .section.section-flex.section-flex-about {
    margin-top: 100px;
    margin-bottom: 120px;
  }

  .section.section-contact, .section.section-vertical {
    padding-left: 60px;
    padding-right: 60px;
  }

  .section.section-home-welcome {
    margin-top: 70px;
    padding-left: 60px;
    padding-right: 60px;
  }

  .section.section-static {
    padding-left: 60px;
    padding-right: 60px;
  }

  .section-home-text-block {
    width: 100%;
    padding-left: 100px;
  }

  .section-home-number {
    font-size: 96px;
    top: -6px;
    left: 0;
  }

  .section-home-number.section-home-number-last {
    top: -6px;
  }

  .section-flexchild.section-flexchild-aboutdesc {
    padding-left: 40px;
    padding-right: 40px;
  }

  .section-wrapper.section-cta {
    padding-left: 60px;
    padding-right: 60px;
  }

  .section-home-text-blocks {
    flex-direction: column;
  }

  .cta-tagline {
    margin-bottom: 4px;
    font-size: 28px;
    line-height: 42px;
  }

  .nav-color.nav-color-home {
    height: 100px;
  }

  .service-desc {
    flex-direction: column;
  }

  .section-service-test.section-servicetest-item {
    max-width: 100%;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
  }

  .section-service-test-img {
    width: 120px;
  }

  .cta-button {
    padding-top: 24px;
    padding-bottom: 24px;
    font-size: 18px;
  }

  .section-contact-cont {
    width: 100%;
    max-width: 480px;
    padding: 50px 50px 40px;
  }

  .contact-desc {
    width: 100%;
    max-width: 300px;
  }

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

  .service-tests {
    flex-direction: column;
  }

  .service-tests-wrapper {
    margin-left: 0;
    margin-right: 0;
  }

  .about-image {
    max-width: 70%;
  }

  .about-img-wrapper {
    width: 360px;
    height: 360px;
  }
}

@media screen and (max-width: 479px) {
  .footer-cont {
    grid-template-columns: 1fr;
    padding-left: 40px;
    padding-right: 40px;
  }

  .nav-menu {
    padding-left: 40px;
    padding-right: 40px;
  }

  .nav-toggle {
    right: 12px;
  }

  .nav-cont {
    padding-left: 40px;
    padding-right: 40px;
  }

  .footer-legal-text {
    line-height: 22px;
  }

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

  .text-break {
    display: inline-block;
  }

  .hero {
    background-position: 70%;
    justify-content: flex-start;
    align-items: flex-end;
    height: 240px;
    margin-left: 0;
    margin-right: 0;
    position: relative;
  }

  .hero.hero-small {
    align-items: center;
    height: 200px;
    margin-left: 0;
    margin-right: 0;
  }

  .hero.hero-small.hero-about {
    align-items: center;
    margin-left: 0;
    margin-right: 0;
  }

  .hero.hero-home {
    margin-left: 40px;
    margin-right: 40px;
  }

  .hero-cont.hero-cont-home {
    background-color: var(--white);
    width: auto;
    color: var(--green);
    align-items: flex-start;
    margin-bottom: -100px;
    padding-top: 8px;
    padding-left: 0;
    padding-right: 40px;
    position: static;
  }

  .hero-header {
    margin-top: 10px;
    margin-bottom: 0;
    font-size: 22px;
    font-weight: 400;
    line-height: 22px;
  }

  .hero-header.hero-header-title {
    margin-top: 0;
    font-size: 54px;
    font-weight: 700;
    line-height: 54px;
  }

  .social {
    width: 48px;
    height: 48px;
  }

  .hero-socials {
    right: 0;
  }

  .social-img {
    width: 28px;
    height: 28px;
  }

  .hero-clients {
    grid-column-gap: 20px;
    grid-row-gap: 14px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .section {
    margin-top: 60px;
    margin-bottom: 60px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .section.section-flex {
    padding-left: 40px;
    padding-right: 40px;
  }

  .section.section-flex.section-flex-service {
    margin-top: 64px;
  }

  .section.section-flex.section-flex-smalltopmargin {
    margin-bottom: 100px;
  }

  .section.section-cta {
    margin-top: 60px;
    margin-bottom: 60px;
  }

  .section.section-contact {
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .section.section-vertical, .section.section-home-welcome, .section.section-static {
    padding-left: 40px;
    padding-right: 40px;
  }

  .section-home-text-block {
    padding-left: 60px;
  }

  .h1-large.h1-large-home {
    font-size: 48px;
    line-height: 56px;
  }

  .section-home-number {
    font-size: 80px;
    line-height: 80px;
    top: -6px;
    left: -12px;
  }

  .section-home-text-sticky {
    padding-bottom: 32px;
  }

  .section-flexchild.section-flexchild-aboutdesc {
    margin-bottom: 96px;
    padding-left: 0;
    padding-right: 0;
  }

  .section-wrapper.section-cta {
    padding-left: 40px;
    padding-right: 40px;
  }

  .p-tight.p-tight-hori {
    width: auto;
  }

  .service-logo-img {
    width: 100px;
    height: 100px;
  }

  .service-logo {
    width: 180px;
    height: 180px;
  }

  .section-service-test.section-servicetest-item {
    margin-bottom: 24px;
  }

  .section-service-test-img {
    flex: none;
    max-width: 35%;
    max-height: 200px;
  }

  .section-service-test-top {
    height: 160px;
  }

  .section-contact-cont {
    max-width: none;
    padding: 60px 40px 72px;
  }

  .form-submit {
    width: 100%;
  }

  .contact-desc {
    max-width: 380px;
    margin-bottom: 60px;
    padding-left: 40px;
    padding-right: 40px;
  }

  .client-grid {
    grid-column-gap: 12px;
    grid-row-gap: 14px;
  }

  .client-logo.client-logo-fh {
    padding-left: 2px;
    padding-right: 2px;
  }

  .service-tests {
    flex-direction: column;
  }

  .about-img-wrapper {
    width: 300px;
    height: 300px;
  }

  .about-quotes {
    width: 80px;
    top: -24px;
    left: -20px;
  }

  .about-quotes.about-quotes-bottom {
    bottom: -16px;
    right: -20px;
  }

  .service-desc-text {
    flex-direction: column;
  }

  .hero-homeback {
    background-color: var(--white);
    width: 100%;
    padding-bottom: 120px;
  }

  .hero-header-line {
    width: 50%;
    height: 2px;
    margin-top: 2px;
    margin-bottom: 0;
    display: block;
  }

  .contact-form {
    flex-direction: column;
    align-items: center;
    display: flex;
  }

  .service-richtext {
    column-count: 1;
  }
}

#w-node-_8e419623-272e-d3b8-5194-e69905388372-122d19b9 {
  place-self: center;
}

#w-node-edcfe715-d047-02d8-42f2-c2e8ce53071c-4311550d {
  order: 0;
  place-self: stretch center;
}

@media screen and (max-width: 991px) {
  #w-node-bfa57366-2a18-ce35-7a0f-403108a9cbfb-6ad956a6 {
    grid-area: span 1 / span 3 / span 1 / span 3;
  }
}

@media screen and (max-width: 479px) {
  #w-node-bfa57366-2a18-ce35-7a0f-403108a9cbfb-6ad956a6 {
    grid-column: span 1 / span 1;
  }
}


@font-face {
  font-family: 'SF Display';
  src: url('../fonts/System-San-Francisco-Display-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: auto;
}
@font-face {
  font-family: 'SF Display';
  src: url('../fonts/System-San-Francisco-Display-Regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: auto;
}
@font-face {
  font-family: 'SF Display';
  src: url('../fonts/System-San-Francisco-Display-Ultralight.ttf') format('truetype');
  font-weight: 200;
  font-style: normal;
  font-display: auto;
}