/*
 Theme Name:   JPR
 Description:  JPR Theme
 Author:       Tom Greaves
 Author URI:   http://www.brandammo.co.uk
 Version:      1.0.0
*/
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:wght@300;400&display=swap");
@import url("https://use.typekit.net/mnc5wfa.css");
.cta,
button.wpforms-submit {
  background: none !important;
  color: #FFF !important;
  font-size: 17px;
  display: inline-block;
  border: 1px solid #E0DDA4 !important;
  border-width: 1px 0 0 1px !important;
  padding: 10px 15px;
}

.img-wrap {
  position: relative;
  overflow: hidden;
}
.img-wrap .img-inset {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 130%;
  background-size: cover;
  background-position: center;
  transform-origin: center;
  transform: scale(1);
}

body {
  background: #232330;
  color: #fff;
  font-family: "Open Sans", sans-serif;
  font-weight: 300;
  padding: 0;
  margin: 0;
  font-size: 15px;
  color: #D2D2D2;
}

h1,
h2,
h3,
h4,
h5 {
  font-family: museo, serif;
  font-weight: 500;
  font-style: normal;
  color: #fff;
}

h1,
h2 {
  font-size: 4.5vw;
  margin: 0;
}
@media (max-width: 768px) {
  h1,
  h2 {
    font-size: 40px;
  }
}

h4 {
  font-size: 22px;
}

.title-wrap div {
  overflow: hidden;
}

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

p {
  font-size: 15px;
  line-height: 1.6;
  color: #D2D2D2;
}

#body-classes {
  max-width: 100vw;
  overflow: hidden;
}

#sections {
  display: grid;
  grid-auto-flow: row;
  gap: clamp(40px, 20vh, 200px);
  margin-bottom: 15vw;
  max-width: 100vw;
  overflow: hidden;
}
@media (max-width: 768px) {
  #sections {
    gap: 80px;
  }
}
#sections > * {
  max-width: 100vw;
}

.grecaptcha-badge {
  display: none !important;
}

header {
  position: fixed;
  top: 0px;
  z-index: 9999;
  width: 100%;
}
header .logo {
  position: absolute;
  top: 60px;
  left: 80px;
  display: block;
  width: 250px;
}
@media (max-width: 768px) {
  header .logo {
    top: 20px;
    left: 20px;
    width: 200px;
    background: rgba(35, 35, 48, 0.95) !important;
  }
}
header .logo svg {
  display: block;
}
header .short-menu {
  position: absolute;
  top: 40px;
  right: 50px;
  align-items: center;
  display: flex;
}
@media (max-width: 768px) {
  header .short-menu {
    top: 10px;
    right: 10px;
  }
}
header .short-menu ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
}
@media (max-width: 768px) {
  header .short-menu ul {
    display: none;
  }
}
header .short-menu a {
  color: #fff;
  text-decoration: none;
  font-size: 17px;
  letter-spacing: 0.05em;
}
header .side-label {
  position: fixed;
  top: 50%;
  left: 100%;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 6px;
  transform: rotate(-90deg) translateY(-230px);
  transform-origin: center;
  white-space: nowrap;
  color: #fff;
}
@media (max-width: 768px) {
  header .side-label {
    display: none;
  }
}
header .icon-cross {
  position: fixed;
  bottom: 70px;
  right: 70px;
}

.burger-menu {
  position: relative;
  width: 60px;
  height: 60px;
  z-index: 50;
  display: block;
  margin-left: 20px;
}
.burger-menu:hover {
  cursor: pointer !important;
}
.burger-menu:hover svg polygon {
  fill-opacity: 1 !important;
}
.burger-menu span {
  background: #fff;
  display: block;
  width: 50%;
  height: 2px;
  z-index: 1;
  position: absolute;
  transform-origin: center;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  transition: background 0.25s ease;
}
.burger-menu span:first-of-type {
  top: 35%;
}
.burger-menu span:last-of-type {
  top: 65%;
}

#menu-overlay {
  position: fixed;
  top: 0px;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 100;
  justify-content: center;
  align-items: center;
  display: none;
}
@media (max-width: 768px) {
  #menu-overlay {
    top: 0px;
    height: 100vh;
  }
}
#menu-overlay .grid {
  display: grid;
  grid-template-columns: max-content auto;
  gap: 80px;
  padding: 100px 0px 0 80px;
  width: 100vw;
  box-sizing: border-box;
}
@media (max-width: 768px) {
  #menu-overlay .grid {
    grid-template-columns: 1fr;
    grid-template-rows: auto max-content;
    padding: 30px 40px;
    gap: 30px;
    height: 100%;
    max-width: 100%;
  }
}
#menu-overlay .social {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 30px 0 0;
  margin: 30px 0 0;
  display: flex;
  gap: 17px;
  justify-content: space-between;
  align-items: center;
}
@media (max-width: 768px) {
  #menu-overlay .social {
    padding: 20px 0 0;
    margin: 20px 0 0;
  }
}
#menu-overlay .social .link {
  display: flex;
  gap: 30px;
}
#menu-overlay .social .link a {
  color: #232330;
  font-size: 25px;
}
#menu-overlay .social .copy {
  font-size: 11px;
  color: #fff;
}
@media (max-width: 768px) {
  #menu-overlay .company {
    grid-column: 1;
    grid-row: 2;
  }
}
#menu-overlay .company .logo {
  max-width: 250px;
  height: auto;
  display: block;
}
@media (max-width: 768px) {
  #menu-overlay .company .logo {
    max-width: 150px;
  }
}
#menu-overlay .company .logo svg {
  display: block;
  width: 100%;
  height: auto;
}
#menu-overlay .company .logo #hexs > * {
  transform-origin: center;
}
#menu-overlay .company .info {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
#menu-overlay .company .info a {
  color: #fff;
  text-decoration: none;
  display: block;
}
#menu-overlay .company .info a:before {
  font-family: "Font Awesome 6 Pro";
  font-weight: 900;
  margin-right: 10px;
}
#menu-overlay .company .info a[href*=tel]:before {
  content: "\f095";
}
#menu-overlay .company .info a[href*=mailto]:before {
  content: "\f0e0";
}
#menu-overlay .menu {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
@media (max-width: 768px) {
  #menu-overlay .menu {
    display: grid;
    grid-template-columns: 1fr;
    align-items: center;
    text-align: center;
    padding-top: 100px;
  }
}
#menu-overlay .menu ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (max-width: 768px) {
  #menu-overlay .menu ul {
    gap: 20px;
  }
}
#menu-overlay .menu ul li {
  overflow: hidden;
  position: relative;
}
@media (max-width: 768px) {
  #menu-overlay .menu ul li {
    padding-left: 0px;
  }
}
#menu-overlay .menu ul li:before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 30px;
  padding-top: 35px;
  transform-origin: center;
  clip-path: polygon(50% 0, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
  opacity: 0;
  transform: translate(0, -50%) scale(0.8);
}
@media (max-width: 768px) {
  #menu-overlay .menu ul li:before {
    transform: translate(-7px, -55%) scale(0.5);
  }
}
#menu-overlay .menu ul li a {
  font-size: 40px;
  font-weight: 100;
  color: #fff;
  text-decoration: none;
  display: block;
  font-family: museo, serif;
  font-weight: 300;
  font-style: normal;
  color: #fff;
}
@media (max-width: 768px) {
  #menu-overlay .menu ul li a {
    font-size: 27px;
  }
}

#menu-overlay .menu-short-menu-container,
#footer .menu-short-menu-container {
  padding: 40px 0;
}
#menu-overlay .menu-short-menu-container ul,
#footer .menu-short-menu-container ul {
  list-style-type: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 20px;
}
#menu-overlay .menu-short-menu-container ul a,
#footer .menu-short-menu-container ul a {
  color: #232330;
  padding: 10px 20px;
  display: inline-block;
  text-decoration: none;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
  font-size: 16px;
  clip-path: polygon(0% 0%, 100% 0, 100% calc(100% - 10px), calc(100% - 10px) 100%, 0% 100%);
}
#menu-overlay .end-column .menu-short-menu-container,
#footer .end-column .menu-short-menu-container {
  padding-top: 0;
}
#menu-overlay .social,
#footer .social {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  padding: 30px 0 0;
  margin: 30px 0 0;
  display: flex;
  gap: 17px;
  justify-content: space-between;
  align-items: center;
}
#menu-overlay .social .link,
#footer .social .link {
  display: flex;
  gap: 30px;
}
#menu-overlay .social .link a,
#footer .social .link a {
  font-size: 25px;
}
#menu-overlay .social .copy,
#footer .social .copy {
  font-size: 11px;
  color: #fff;
}
#menu-overlay-bg,
#footer-bg {
  background: rgba(35, 35, 48, 0.96);
  position: fixed;
  top: 0px;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 90;
}
@media (max-width: 768px) {
  #menu-overlay-bg,
  #footer-bg {
    background: rgba(35, 35, 48, 0.99);
  }
}
#menu-overlay-bg:before,
#footer-bg:before {
  content: "";
  background: url("assets/images/pattern-dots-round.svg") repeat 0 0/550px;
  background-attachment: fixed;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
}
#menu-overlay .case-studies-carousel,
#footer .case-studies-carousel {
  display: flex;
  gap: 30px;
  max-width: 70vw;
  justify-self: flex-end;
}
@media (max-width: 768px) {
  #menu-overlay .case-studies-carousel,
  #footer .case-studies-carousel {
    flex-direction: column;
    padding: 0px;
    gap: 20px;
    width: 100%;
    max-width: 100vw;
  }
}
#menu-overlay .case-studies-carousel a.case-study-thumb,
#footer .case-studies-carousel a.case-study-thumb {
  display: block;
  width: 25vw;
  height: 35vw;
}
@media (max-width: 768px) {
  #menu-overlay .case-studies-carousel a.case-study-thumb,
  #footer .case-studies-carousel a.case-study-thumb {
    width: 100%;
    height: 11vh;
  }
  #menu-overlay .case-studies-carousel a.case-study-thumb .side-label,
  #footer .case-studies-carousel a.case-study-thumb .side-label {
    right: auto;
    left: 0;
    top: auto;
    bottom: 0;
    padding: 7px 10px;
    transform: rotate(0deg) translateY(0);
  }
}

#footer {
  padding: 60px;
  display: grid;
  grid-template-columns: auto max-content;
}
@media (max-width: 768px) {
  #footer {
    grid-template-columns: 1fr;
    padding: 0 30px;
  }
}
#footer .grid {
  display: grid;
  grid-template-columns: 16vw auto;
  column-gap: 50px;
  row-gap: 40px;
}
@media (max-width: 768px) {
  #footer .grid {
    grid-template-columns: 1fr;
  }
  #footer .grid .company {
    display: none;
  }
}
#footer .navigation {
  display: flex;
  gap: 70px;
}
@media (max-width: 768px) {
  #footer .navigation {
    flex-direction: column;
    gap: 20px;
  }
}
#footer .navigation ul {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  list-style-type: none;
}

@media (max-width: 768px) {
  .footer-end {
    margin-bottom: 50px;
  }
}
@media (min-width: 768px) {
  .footer-end {
    display: flex;
    grid-row: 2;
    grid-column: span 2;
  }
}
.footer-end ul {
  display: flex;
  list-style-type: none;
  margin: 0;
  padding: 0;
  gap: 40px;
  margin-right: 40px;
}
@media (max-width: 768px) {
  .footer-end ul {
    flex-wrap: wrap;
    gap: 20px;
    margin-bottom: 40px;
  }
}

.projects-ft {
  display: grid;
  grid-template-columns: repeat(4, minmax(100px, 1fr));
  gap: 15px;
}
@media (max-width: 768px) {
  .projects-ft {
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: 40px;
  }
}
.projects-ft a {
  display: block;
  max-width: 100px;
}
@media (max-width: 768px) {
  .projects-ft a {
    max-width: 100%;
  }
}
.projects-ft a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.projects-ft a span {
  width: 100%;
  padding-top: 70%;
  background: #F0F0F0;
  display: block;
}

section.hero_banner .hero-wrap {
  display: grid;
  height: 100vh;
  max-height: 1200px;
  align-items: center;
  grid-template-columns: repeat(2, 1fr);
  gap: 70px;
  position: relative;
}
@media (max-width: 768px) {
  section.hero_banner .hero-wrap {
    grid-template-columns: 1fr;
    grid-template-rows: max-content;
    gap: 0;
    min-height: 75vh;
    height: auto;
  }
}
section.hero_banner .hero-wrap:before {
  content: "";
  background: url("assets/images/pattern-dots-round.svg") repeat 0 0/275px;
  background-attachment: fixed;
  position: absolute;
  left: 0;
  bottom: -50px;
  width: calc(50% + 40px);
  height: 25%;
  opacity: 0.7;
}
section.hero_banner .layout-1 .img-wrap {
  width: 100%;
  height: calc(100% - 50px);
  align-self: flex-start;
}
@media (max-width: 768px) {
  section.hero_banner .layout-1 .img-wrap {
    min-height: 50vh;
  }
}
section.hero_banner .layout-1 h1 {
  position: relative;
  line-height: 1.1;
}
@media (min-width: 768px) {
  section.hero_banner .layout-1 h1 {
    margin-left: -100px;
  }
}
@media (max-width: 768px) {
  section.hero_banner .layout-1 h1 {
    margin-top: -15px;
  }
}
@media (min-width: 768px) {
  section.hero_banner .content {
    width: 35vw;
  }
}
@media (max-width: 768px) {
  section.hero_banner .content {
    padding: 0 30px;
  }
}
section.hero_banner .content .text-wrap {
  max-width: 600px;
  margin: 0 0 40px;
}
section.hero_banner .layout-2,
section.hero_banner .layout-3 {
  align-items: center;
  grid-template-columns: minmax(0, 0.6fr) minmax(0, 1.4fr);
  padding: 0 80px;
  gap: 30px;
}
@media (max-width: 768px) {
  section.hero_banner .layout-2,
  section.hero_banner .layout-3 {
    padding: 0;
    grid-template-columns: 1fr;
    gap: 0;
  }
}
section.hero_banner .layout-2:before,
section.hero_banner .layout-3:before {
  left: auto;
  right: 130px;
  bottom: -50px;
  width: 60%;
}
section.hero_banner .layout-2 .img-wrap,
section.hero_banner .layout-3 .img-wrap {
  grid-column: 2;
  grid-row: 1;
  height: auto;
  padding-top: calc(100% - 40px);
  width: calc(100% - 40px);
}
@media (max-width: 768px) {
  section.hero_banner .layout-2 .img-wrap,
  section.hero_banner .layout-3 .img-wrap {
    width: 100vw;
    grid-column: 1;
    grid-row: 1;
  }
}
section.hero_banner .layout-2 .content,
section.hero_banner .layout-3 .content {
  grid-column: 1;
  grid-row: 1;
}
@media (max-width: 768px) {
  section.hero_banner .layout-2 .content,
  section.hero_banner .layout-3 .content {
    grid-column: 1;
    grid-row: 2;
  }
}
@media (min-width: 768px) {
  section.hero_banner .layout-2 .content .text-wrap,
  section.hero_banner .layout-3 .content .text-wrap {
    max-width: 25vw;
  }
}
@media (min-width: 768px) {
  section.hero_banner .layout-3 {
    padding: 0 0 0 80px;
  }
}
@media (max-width: 768px) {
  section.hero_banner .layout-3 {
    padding: 80px 0 0;
  }
}
section.hero_banner .layout-3 .img-wrap {
  width: 100%;
  height: calc(100% - 110px);
  align-self: flex-end;
  padding: 0;
}
@media (max-width: 768px) {
  section.hero_banner .layout-3 .img-wrap {
    min-height: 35vh;
  }
}

section.case_studies .case-studies-wrap {
  display: grid;
  height: 100%;
  min-height: 70vh;
  align-items: center;
  grid-template-columns: max-content auto;
  gap: 0px;
}
@media (max-width: 768px) {
  section.case_studies .case-studies-wrap {
    grid-template-columns: 1fr;
    min-height: 50vh;
  }
}
section.case_studies .img-wrap {
  width: 100%;
  height: 100%;
}
section.case_studies .layout-1 h1 {
  position: relative;
  left: -100px;
}
section.case_studies .content {
  padding: 0 30px;
}
@media (min-width: 768px) {
  section.case_studies .content {
    width: 20vw;
    max-width: 600px;
    padding: 0 80px;
  }
}
section.case_studies .content .text-wrap {
  margin: 0 0 40px;
}
section.case_studies .case-studies-carousel {
  display: flex;
  gap: 30px;
}
@media (max-width: 768px) {
  section.case_studies .case-studies-carousel {
    flex-direction: column;
    padding: 20px 20px;
    gap: 20px;
  }
}
section.case_studies .case-studies-carousel a.case-study-thumb {
  display: block;
  width: 25vw;
  height: 35vw;
}
@media (max-width: 768px) {
  section.case_studies .case-studies-carousel a.case-study-thumb {
    width: 100%;
    height: calc(100vw - 100px);
  }
}

.case-study-thumb {
  display: block;
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
}
.case-study-thumb .img-inset {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
}
.case-study-thumb .side-label {
  position: absolute;
  top: 20px;
  right: 100%;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  transform: rotate(-90deg) translateY(calc(100% - 1px));
  transform-origin: 100% 100%;
  white-space: nowrap;
  z-index: 1;
  background: #232330;
  color: #fff;
  padding: 15px 20px;
  transition: all 0.5s ease;
  opacity: 1;
}
@media (max-width: 768px) {
  .case-study-thumb .side-label {
    top: 0px;
  }
}
.case-study-thumb.cs-to-move .side-label {
  opacity: 0;
}

section.clients .clients-wrap {
  display: grid;
  height: 100%;
  align-items: center;
  grid-template-columns: max-content auto;
  gap: 0px;
}
@media (max-width: 768px) {
  section.clients .clients-wrap {
    grid-template-columns: 1fr;
  }
}
section.clients .img-wrap {
  width: 100%;
  height: 100%;
}
section.clients .layout-1 h1 {
  position: relative;
  left: -100px;
}
section.clients .content {
  width: 20vw;
  max-width: 600px;
  padding: 0 80px;
}
@media (max-width: 768px) {
  section.clients .content {
    max-width: none;
    width: 100%;
    padding: 0 30px;
    box-sizing: border-box;
  }
}
section.clients .content .text-wrap {
  margin: 0 0 40px;
}
section.clients .client-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(10vw, 1fr);
  gap: 0px;
  padding-right: 150px;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  section.clients .client-group {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: minmax(30vw, 1fr);
    padding: 0px 10px;
  }
}
section.clients .client-group:not(.active) {
  display: none;
}
section.clients .client-group img {
  display: block;
  margin: 0 auto;
  object-fit: contain;
  object-position: center;
  width: 60%;
  max-height: 90px;
}
section.clients .client-group .img {
  position: relative;
  height: 100%;
  width: 100%;
  display: grid;
  align-items: center;
}
@media (max-width: 768px) {
  section.clients .client-group .img img {
    transform: scale(0.8);
  }
}
section.clients .client-group .img:before, section.clients .client-group .img:after {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  left: 0;
  height: calc(100% - 40px);
  width: 1px;
  background: rgba(255, 255, 255, 0.15);
}
section.clients .client-group .img:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 20px;
  height: 1px;
  width: calc(100% - 40px);
}
@media (min-width: 768px) {
  section.clients .client-group .img:first-child span, section.clients .client-group .img:first-child:before, section.clients .client-group .img:nth-child(4n) span, section.clients .client-group .img:nth-child(4n):before {
    display: none;
  }
  section.clients .client-group .img:nth-child(1):after,
  section.clients .client-group .img:nth-child(1) span, section.clients .client-group .img:nth-child(2):after,
  section.clients .client-group .img:nth-child(2) span, section.clients .client-group .img:nth-child(3):after,
  section.clients .client-group .img:nth-child(3) span {
    display: none;
  }
}
@media (max-width: 768px) {
  section.clients .client-group .img:first-child span, section.clients .client-group .img:first-child:before, section.clients .client-group .img:nth-child(odd) span, section.clients .client-group .img:nth-child(odd):before {
    display: none;
  }
  section.clients .client-group .img:first-child:after, section.clients .client-group .img:nth-child(2):after {
    display: none;
  }
  section.clients .client-group .img:nth-child(2) span {
    display: none;
  }
}
section.clients .client-group img {
  display: block;
  margin: 0 auto;
}
section.clients .client-group span {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
}
section.clients #client-nav {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (max-width: 768px) {
  section.clients #client-nav {
    flex-direction: row;
    margin-bottom: 2px;
  }
}
section.clients #client-nav a {
  display: inline-block;
  padding: 5px 0;
}
section.clients #client-nav .active {
  color: #E0DDA4;
  border-bottom: 1px solid #E0DDA4;
}

section.global_statistics {
  position: relative;
}
section.global_statistics:before {
  content: "";
  background: url("assets/images/pattern-tile-dash.svg") repeat 0 0/550px;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0.2;
}
section.global_statistics .global-stats-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  padding: 50px 130px 50px 50px;
  position: relative;
}
@media (max-width: 768px) {
  section.global_statistics .global-stats-wrap {
    grid-template-columns: 1fr;
    padding: 20px;
    gap: 20px;
  }
}
section.global_statistics .global-stats-wrap .stat {
  padding: 80px 50px;
  background: #232330;
}
@media (max-width: 768px) {
  section.global_statistics .global-stats-wrap .stat {
    padding: 30px;
  }
}
section.global_statistics .global-stats-wrap .stat .amount {
  display: flex;
}
section.global_statistics .global-stats-wrap .stat .amount .val:first-child,
section.global_statistics .global-stats-wrap .stat .amount .symbol:first-child,
section.global_statistics .global-stats-wrap .stat .amount .symbol:first-child + .val {
  font-family: museo, serif;
  font-weight: 500;
  font-style: normal;
  color: #fff;
  font-size: clamp(47px, 3.5vw, 100px);
}
section.global_statistics .global-stats-wrap .stat .val + .symbol {
  font-size: 15px;
  margin-left: 10px;
}
section.global_statistics .global-stats-wrap .stat h4 {
  color: #E0DDA4;
  margin: 0px 0 10px;
}

section.testimonials .testimonial-wrap {
  display: grid;
  min-height: 70vh;
  height: 100%;
  align-items: center;
  grid-template-columns: repeat(2, 1fr);
  gap: 70px;
}
@media (max-width: 768px) {
  section.testimonials .testimonial-wrap {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
@media (max-width: 768px) {
  section.testimonials .testimonial {
    padding: 20px;
    width: 100vw;
    box-sizing: border-box;
  }
}
section.testimonials .img-wrap,
section.testimonials .ft-images {
  width: 100%;
  height: 100%;
  position: relative;
}
@media (max-width: 768px) {
  section.testimonials .img-wrap,
  section.testimonials .ft-images {
    width: 100vw;
    height: 100vw;
  }
}
section.testimonials .layout-2 .split-images {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  width: 100%;
  height: 100%;
  max-height: 70vh;
}
section.testimonials .layout-2 .split-images .img-cell {
  max-width: 100%;
  overflow: hidden;
  min-height: 100%;
}
section.testimonials .layout-2 .split-images .img-cell img {
  max-height: 100%;
}
section.testimonials .layout-2 .split-images > div:nth-child(2) img {
  transform: translateX(calc(-30% - 10px));
}
section.testimonials .layout-2 .split-images > div:nth-child(3) img {
  transform: translateX(calc(-60% - 20px));
}
section.testimonials .layout-1 h1 {
  position: relative;
  margin-left: -100px;
}
section.testimonials .additional-images {
  display: flex;
  justify-content: flex-end;
  gap: 20px;
  padding-right: 150px;
}
@media (max-width: 768px) {
  section.testimonials .additional-images {
    padding-right: 0px;
  }
}
section.testimonials .additional-images img {
  max-height: 170px;
}
@media (max-width: 768px) {
  section.testimonials .additional-images img {
    max-height: 120px;
  }
}

.quote .author {
  margin-bottom: 60px;
  padding-left: 20px;
  border-left: 1px solid #E0DDA4;
}

.quote-wrap {
  width: 35vw;
  margin: 50px 0;
}
@media (max-width: 768px) {
  .quote-wrap {
    width: calc(100vw - 40px);
    box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
    margin: 20px 0;
  }
}
.quote-wrap p {
  font-size: 22px;
}
@media (max-width: 768px) {
  .quote-wrap p {
    font-size: 18px;
  }
}
.quote-wrap .text-wrap {
  max-width: 600px;
  margin: 0 0 40px;
}

section.call_to_action_banner {
  position: relative;
}
section.call_to_action_banner .img-wrap {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-size: cover;
  background-position: center;
}
@media (max-width: 768px) {
  section.call_to_action_banner .img-wrap {
    position: relative;
    height: 80vw;
  }
}
section.call_to_action_banner .layout-1 h1 {
  position: relative;
  margin-left: -100px;
}
section.call_to_action_banner .content {
  width: 35vw;
  position: relative;
  width: 50%;
  max-width: 680px;
  background: rgba(35, 35, 48, 0.85);
  box-sizing: border-box;
  padding: 50px 80px;
  min-height: 70vh;
  display: grid;
  align-items: center;
}
@media (max-width: 768px) {
  section.call_to_action_banner .content {
    max-width: none;
    width: 100%;
    padding: 30px;
    min-height: 0;
  }
}
section.call_to_action_banner .content .text-wrap {
  max-width: 600px;
  margin: 0 0 40px;
}

.projects_grid {
  padding-right: 130px;
}
@media (max-width: 768px) {
  .projects_grid {
    padding: 0px 20px;
  }
}
.projects_grid .grid-sizer {
  width: 100%;
}
.projects_grid .gutter-sizer {
  width: 3%;
}
.projects_grid .projects {
  width: 100%;
  padding-left: 30px;
}
@media (max-width: 768px) {
  .projects_grid .projects {
    padding: 0;
  }
}
.projects_grid .projects .project {
  position: relative;
  width: calc(33.33% - 30px);
  padding-bottom: 30px;
}
@media (max-width: 992px) {
  .projects_grid .projects .project {
    width: calc(50% - 30px);
  }
}
@media (max-width: 768px) {
  .projects_grid .projects .project {
    width: 100%;
  }
}
.projects_grid .projects .project img {
  width: 100%;
  height: auto;
  grid-row: 1;
  display: block;
}
.projects_grid .projects .project .image-wrap {
  overflow: hidden;
  padding-top: 100%;
  position: relative;
}
.projects_grid .projects .project .image-wrap img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}
.projects_grid .projects .project .overlay {
  width: 100%;
  height: 100%;
  padding: 30px;
  background: rgba(35, 35, 48, 0.95);
  opacity: 0;
  transition: all 0.25s ease;
  box-sizing: border-box;
  opacity: 1;
  position: relative;
  padding: 10px 0 0;
  margin-bottom: 40px;
  min-height: 270px;
}
@media (max-width: 768px) {
  .projects_grid .projects .project .overlay {
    min-height: 0;
  }
}
.projects_grid .projects .project .overlay svg {
  font-size: 34px;
  margin-bottom: 20px;
}
@media (max-width: 768px) {
  .projects_grid .projects .project .overlay svg {
    margin: -15px 0 20px;
  }
}
.projects_grid .projects .project .overlay h4 {
  color: #E0DDA4;
  margin: 10px 0;
}
.projects_grid .projects .project .overlay h3 {
  font-size: 31px;
  font-weight: 100;
  margin: 0;
}
@media (max-width: 768px) {
  .projects_grid .projects .project .overlay h3 {
    font-size: 25px;
  }
}
.projects_grid .projects .project .overlay .meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  max-width: 100%;
}
@media (max-width: 768px) {
  .projects_grid .projects .project .overlay .meta {
    display: flex;
    flex-wrap: wrap;
  }
}
.projects_grid .projects .project .overlay .meta > div {
  padding-left: 10px;
  border-left: 1px solid #e0dda4;
}
.projects_grid .projects .project .overlay .meta > div .label {
  color: #E0DDA4;
  font-size: 12px;
}
.projects_grid .projects .project:hover .overlay {
  opacity: 1;
}

.project-filter {
  padding: 0 130px 0 80px;
  max-width: 1500px;
  margin-bottom: 50px;
  width: 100%;
}
@media (max-width: 768px) {
  .project-filter {
    padding: 0;
  }
}
.project-filter .inner {
  align-items: baseline;
}
@media (min-width: 768px) {
  .project-filter .inner {
    display: grid;
    grid-template-columns: max-content max-content;
    gap: 50px;
  }
}
@media (max-width: 768px) {
  .project-filter .inner {
    grid-template-columns: 1fr;
    padding: 10px;
  }
}
.project-filter h3 {
  font-family: "Open Sans", sans-serif;
  font-size: 30px;
  margin: 0;
}
@media (max-width: 768px) {
  .project-filter h3 {
    margin-bottom: 20px;
  }
}
.project-filter .pre-title {
  color: #E0DDA4;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 20px;
  position: absolute;
  transform: translateY(-120%);
}
.project-filter .filters {
  display: flex;
  position: relative;
  gap: 3rem;
}
@media (max-width: 768px) {
  .project-filter .filters {
    flex-direction: column;
    gap: 10px;
  }
}
.project-filter .filters .top-level.open .drop {
  display: flex !important;
  row-gap: 0px;
  flex-direction: column;
  padding: 15px;
}
.project-filter .filters .top-level.open .drop .filt,
.project-filter .filters .top-level.open .drop .filt.active {
  border-bottom: none !important;
}
.project-filter .filters .top-level .drop {
  position: absolute;
  top: calc(100% - 1px);
  width: 100%;
  left: 0;
  display: none;
  z-index: 999;
  padding: 30px;
  border: 1px solid #E0DDA4 !important;
  border-width: 1px 0 !important;
  background: rgba(35, 35, 48, 0.99);
  grid-template-columns: repeat(3, 1fr);
  grid-gap: 40px;
  row-gap: 10px;
}
@media (max-width: 768px) {
  .project-filter .filters .top-level .drop {
    position: relative;
    width: calc(100% - 30px);
  }
}
.project-filter .filters .top-level .drop .filt {
  position: relative;
  z-index: 10;
  font-size: 16px;
}
.project-filter .filters .top-level .drop:before {
  content: "";
  background: url("assets/images/pattern-tile-stripes.svg") repeat 0 0/250px;
  background-attachment: fixed;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  opacity: 0.05;
}
.project-filter .filters .filt,
.project-filter .filters .top-level > a {
  cursor: pointer;
  transition: all 0.25s ease;
  font-size: 20px;
  display: flex;
  align-items: center;
  padding: 5px 0;
  border-bottom: 1px solid rgba(224, 221, 164, 0);
}
.project-filter .filters .filt svg,
.project-filter .filters .top-level > a svg {
  font-size: 23px;
  margin-right: 15px;
}
.project-filter .filters .filt.active, .project-filter .filters .filt:hover,
.project-filter .filters .top-level > a.active,
.project-filter .filters .top-level > a:hover {
  color: #E0DDA4;
}
@media (min-width: 768px) {
  .project-filter .filters .filt.active,
  .project-filter .filters .top-level > a.active {
    border-bottom: 1px solid #e0dda4;
  }
}
@media (min-width: 768px) {
  .project-filter .filters .top-level:hover > a {
    color: #E0DDA4;
  }
  .project-filter .filters .top-level:hover .drop {
    display: grid !important;
  }
  .project-filter .filters .top-level:hover .drop .filt,
  .project-filter .filters .top-level:hover .drop .filt.active {
    border-bottom: none !important;
  }
}

.text-area-wrap {
  padding: 0 130px 0 80px;
  max-width: 1500px;
}
@media (min-width: 768px) {
  .text-area-wrap {
    display: grid;
    grid-template-columns: 300px auto;
    gap: 50px;
  }
}
@media (max-width: 768px) {
  .text-area-wrap {
    grid-template-columns: 1fr;
    padding: 60px 30px 0;
  }
}
.text-area-wrap h3 {
  font-family: "Open Sans", sans-serif;
  font-size: 30px;
  margin: 0 0 10px;
}
.text-area-wrap .pre-title {
  color: #E0DDA4;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 20px;
  position: absolute;
  transform: translateY(-120%);
}
.text-area-wrap .text-wrap {
  column-count: 2;
  column-gap: 50px;
}
@media (max-width: 768px) {
  .text-area-wrap .text-wrap {
    column-count: 1;
  }
}
.text-area-wrap .text-wrap p {
  margin: 0 0 20px;
}
@media (min-width: 768px) {
  .text-area-wrap .testimonial {
    grid-column: 2;
    max-width: 55%;
  }
}
.text-area-wrap .testimonial .quote {
  margin-bottom: 40px;
}
.text-area-wrap .testimonial .quote p {
  font-size: 18px;
}
.text-area-wrap .testimonial .quote p:first-of-type:before {
  content: '" ';
}
.text-area-wrap .testimonial .quote p:last-of-type::after {
  content: ' "';
}
.text-area-wrap .testimonial .author {
  padding-left: 15px;
  border-left: 1px solid #E0DDA4;
}
.text-area-wrap .testimonial .author .name {
  margin-bottom: 5px;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 18px;
}

section.team .team-wrap {
  display: grid;
  height: 100%;
  min-height: 70vh;
  align-items: center;
  grid-template-columns: 35vw auto;
  gap: 0px;
}
@media (max-width: 768px) {
  section.team .team-wrap {
    grid-template-columns: 1fr;
    padding: 0 30px;
    max-width: 100vw;
    box-sizing: border-box;
  }
}
section.team .img-wrap {
  width: 100%;
  height: 100%;
}
section.team .layout-1 h1 {
  position: relative;
  left: -100px;
}
section.team .content {
  width: 20vw;
  max-width: 600px;
  padding: 0 80px;
}
@media (max-width: 768px) {
  section.team .content {
    width: 100vw;
    max-width: calc(100vw - 60px);
    padding: 0;
    box-sizing: border-box;
  }
}
section.team .content .text-wrap {
  margin: 0 0 40px;
}
section.team .members {
  display: flex;
  gap: 30px;
}
@media (max-width: 768px) {
  section.team .members {
    flex-direction: column;
  }
}
section.team .members .member {
  display: block;
  width: 33.33%;
}
@media (max-width: 768px) {
  section.team .members .member {
    width: 100%;
  }
}
section.team .members .member img {
  width: 100%;
  height: auto;
  margin-bottom: 20px;
  box-sizing: border-box;
}
section.team .members .member .author {
  padding-left: 15px;
  border-left: 1px solid #E0DDA4;
}
section.team .members .member .author .name {
  margin-bottom: 5px;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 18px;
}

.image-and-text-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 80px;
  align-items: center;
  padding-left: 80px;
}
@media (max-width: 768px) {
  .image-and-text-wrap {
    padding: 0 20px;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
.image-and-text-wrap .img-wrap {
  padding-top: 80%;
}
.image-and-text-wrap .content-inset {
  padding: 0;
}
.image-and-text-wrap.layout-1 {
  position: relative;
}
.image-and-text-wrap.layout-1 .content-inset {
  padding-right: 130px;
}
@media (max-width: 768px) {
  .image-and-text-wrap.layout-1 .content-inset {
    padding: 0;
  }
}
.image-and-text-wrap.layout-1:before {
  content: "";
  background: url("assets/images/pattern-tile-stripes.svg") repeat 0 0/275px;
  background-attachment: fixed;
  position: absolute;
  left: 0;
  bottom: -100px;
  width: 60vw;
  height: 40vh;
  opacity: 0.15;
}
@media (max-width: 768px) {
  .image-and-text-wrap.layout-1:before {
    width: 90vw;
    bottom: auto;
    top: 0px;
  }
}
.image-and-text-wrap.layout-2 {
  grid-template-columns: 0.9fr 1.1fr;
}
@media (max-width: 768px) {
  .image-and-text-wrap.layout-2 {
    grid-template-columns: 1fr;
  }
}
.image-and-text-wrap.layout-2 .img-wrap {
  grid-column: 2;
  grid-row: 1;
}

.services-wrap {
  padding: 0 130px 0 50px;
}
@media (max-width: 768px) {
  .services-wrap {
    padding: 0;
  }
}
.services-wrap .content {
  padding-left: 30px;
  display: grid;
  grid-template-columns: 0.3fr 0.7fr;
  max-width: 1000px;
  margin-bottom: 80px;
  gap: 50px;
  align-items: center;
}
@media (max-width: 768px) {
  .services-wrap .content {
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }
}
.services-wrap .content .title-wrap {
  padding-right: 25px;
  border-right: 1px solid #E0DDA4;
}
.services-wrap .content .title-wrap h2, .services-wrap .content .title-wrap h3 {
  font-family: "Open Sans", sans-serif;
  font-size: 30px;
  margin: 0;
}
.services-wrap .content .title-wrap .pre-title {
  color: #E0DDA4;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 20px;
  position: absolute;
  transform: translateY(-120%);
}
.services-wrap .content .text-wrap {
  column-count: 2;
  column-gap: 0px;
}
@media (max-width: 768px) {
  .services-wrap .content .text-wrap {
    column-count: 1;
  }
}
.services-wrap .content .text-wrap p {
  margin-top: 0;
}
.services-wrap .services {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(10vw, 1fr);
  gap: 0px;
  align-items: center;
  justify-content: center;
}
@media (max-width: 768px) {
  .services-wrap .services {
    grid-template-columns: 1fr;
  }
}
.services-wrap .services .service {
  position: relative;
  text-align: left;
}
.services-wrap .services .service .inner {
  padding: 40px;
}
@media (max-width: 768px) {
  .services-wrap .services .service .inner {
    padding: 20px 30px;
  }
}
.services-wrap .services .service span {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
}
.services-wrap .services .service:before, .services-wrap .services .service:after {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
  left: 0;
  height: calc(100% - 40px);
  width: 1px;
  background: rgba(255, 255, 255, 0.15);
}
.services-wrap .services .service:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 20px;
  height: 1px;
  width: calc(100% - 40px);
}
.services-wrap .services .service:first-child span, .services-wrap .services .service:first-child:before, .services-wrap .services .service:nth-child(4) span, .services-wrap .services .service:nth-child(4):before, .services-wrap .services .service:nth-child(7) span, .services-wrap .services .service:nth-child(7):before, .services-wrap .services .service:nth-child(10) span, .services-wrap .services .service:nth-child(10):before {
  display: none;
}
.services-wrap .services .service:nth-child(1):after,
.services-wrap .services .service:nth-child(1) span, .services-wrap .services .service:nth-child(2):after,
.services-wrap .services .service:nth-child(2) span, .services-wrap .services .service:nth-child(3):after,
.services-wrap .services .service:nth-child(3) span {
  display: none;
}

.wpforms-form input,
.wpforms-form textarea {
  background: none !important;
  background: linear-gradient(to right, rgba(35, 35, 48, 0.8), rgba(35, 35, 48, 0.8)), transparent url("assets/images/pattern-tile-stripes.svg") repeat 0 0/220px !important;
  border: 0 none !important;
  border-radius: 0 !important;
  border-bottom: 1px solid #FFF !important;
  color: #FFF !important;
}
.wpforms-form .wpforms-field {
  padding: 0 !important;
  margin: 20px 0 !important;
}

.hor-gallery-wrap {
  position: relative;
}
.hor-gallery-wrap:before {
  content: "";
  background: url("assets/images/pattern-dots-round.svg") repeat 0 0/275px;
  background-attachment: fixed;
  position: absolute;
  left: 0;
  bottom: -100px;
  width: 60vw;
  height: 40vh;
  opacity: 1;
}
.hor-gallery-wrap .content {
  padding: 0 130px 0 80px;
  display: grid;
  grid-template-columns: 0.3fr 0.7fr;
  max-width: 1000px;
  margin-bottom: 80px;
  gap: 50px;
  align-items: center;
}
@media (max-width: 768px) {
  .hor-gallery-wrap .content {
    grid-template-columns: 1fr;
    padding: 0 30px;
    gap: 20px;
    margin-bottom: 50px;
  }
}
.hor-gallery-wrap .content .title-wrap {
  padding-right: 25px;
  border-right: 1px solid #e0dda4;
}
@media (max-width: 768px) {
  .hor-gallery-wrap .content .title-wrap {
    border-right: 0 none;
    padding: 0 0 25px;
    border-bottom: 1px solid #e0dda4;
  }
}
.hor-gallery-wrap .content .title-wrap h2,
.hor-gallery-wrap .content .title-wrap h3 {
  font-family: "Open Sans", sans-serif;
  font-size: 30px;
  margin: 0 0 10px;
  margin-bottom: 0;
}
.hor-gallery-wrap .content .title-wrap .pre-title {
  color: #E0DDA4;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 20px;
  position: absolute;
  transform: translateY(-120%);
}
.hor-gallery-wrap .content .text-wrap {
  column-count: 2;
  column-gap: 0px;
}
@media (max-width: 768px) {
  .hor-gallery-wrap .content .text-wrap {
    column-count: 1;
  }
}
.hor-gallery-wrap .content .text-wrap p {
  margin-top: 0;
}
.hor-gallery-wrap .gallery {
  max-width: 100vw;
  overflow-x: auto;
}
.hor-gallery-wrap .gallery .gallery-slides {
  display: flex;
  gap: 30px;
}
.hor-gallery-wrap .gallery img {
  display: block;
  width: auto;
  height: 100%;
  max-height: 50vh;
}

.points-wrap {
  padding: 0 130px 0 50px;
}
@media (max-width: 768px) {
  .points-wrap {
    padding: 0 20px;
  }
}
.points-wrap .points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: minmax(10vw, 1fr);
  gap: 0px;
  align-items: center;
  justify-content: center;
  margin-bottom: 80px;
}
@media (max-width: 768px) {
  .points-wrap .points {
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }
}
.points-wrap .points .point {
  position: relative;
  text-align: left;
}
@media (max-width: 768px) {
  .points-wrap .points .point {
    border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  }
}
.points-wrap .points .point .pre-title {
  color: #E0DDA4;
  font-family: museo, serif;
  font-weight: 500;
  font-size: 20px;
  margin-bottom: 15px;
}
.points-wrap .points .point h4 {
  font-size: clamp(40px, 3.5vw, 50px);
  margin: 0;
  display: flex;
  gap: 15px;
  align-items: center;
}
.points-wrap .points .point h4 svg {
  font-size: 0.9em;
}
.points-wrap .points .point .inner {
  padding: 40px;
}
@media (max-width: 768px) {
  .points-wrap .points .point .inner {
    padding: 30px 10px;
  }
}
.points-wrap .points .point span.cross {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-50%, -50%);
}
@media (max-width: 768px) {
  .points-wrap .points .point span.cross {
    left: auto;
    right: 0px;
    top: calc(100% + 3px);
  }
}
@media (min-width: 768px) {
  .points-wrap .points .point:before, .points-wrap .points .point:after {
    content: "";
    display: block;
    position: absolute;
    top: 20px;
    left: 0;
    height: calc(100% - 40px);
    width: 1px;
    background: rgba(255, 255, 255, 0.15);
  }
  .points-wrap .points .point:after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 20px;
    height: 1px;
    width: calc(100% - 40px);
  }
  .points-wrap .points .point:first-child span.cross, .points-wrap .points .point:first-child:before, .points-wrap .points .point:nth-child(4) span.cross, .points-wrap .points .point:nth-child(4):before, .points-wrap .points .point:nth-child(7) span.cross, .points-wrap .points .point:nth-child(7):before, .points-wrap .points .point:nth-child(10) span.cross, .points-wrap .points .point:nth-child(10):before {
    display: none;
  }
  .points-wrap .points .point:nth-child(1):after,
  .points-wrap .points .point:nth-child(1) span.cross, .points-wrap .points .point:nth-child(2):after,
  .points-wrap .points .point:nth-child(2) span.cross, .points-wrap .points .point:nth-child(3):after,
  .points-wrap .points .point:nth-child(3) span.cross {
    display: none;
  }
}

.full_image {
  position: relative;
  min-height: 70vh;
}
@media (max-width: 768px) {
  .full_image {
    min-height: 100vw;
  }
}
.full_image .img-wrap:not(.full-img) {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-size: cover;
  background-position: center;
}
.full_image .full-img {
  min-height: none;
  max-height: none;
  display: flex;
  height: 100%;
}
.full_image .full-img .img-wrap {
  position: relative;
}
.full_image .full-img img {
  display: block;
  object-fit: contain;
  width: 100%;
  height: auto;
}

section.video {
  padding: 0 130px 80px 80px;
  position: relative;
}
@media (max-width: 768px) {
  section.video {
    padding: 0 20px 30px;
  }
}
section.video:before {
  content: "";
  background: url("assets/images/pattern-tile-dash.svg") repeat 0 0/clamp(440px, 40vw, 800px);
  background-attachment: fixed;
  position: absolute;
  left: 0;
  bottom: -50px;
  width: 100vw;
  height: calc(50% + 50px);
  opacity: 0.1;
}

.video-wrap {
  background: #232330;
  padding: 0 25px 30px;
  position: relative;
}
@media (max-width: 768px) {
  .video-wrap {
    padding: 0 15px 20px;
  }
}

.video-container {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
}
.video-container > iframe,
.video-container .video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

#body-classes.single-case_studies {
  padding-top: 200px;
  position: relative;
}
@media (max-width: 768px) {
  #body-classes.single-case_studies {
    padding-top: 120px;
  }
}
#body-classes.single-case_studies:before {
  content: "";
  background: url("assets/images/pattern-dots-round.svg") repeat 0 0/275px;
  background-attachment: fixed;
  position: absolute;
  right: 0;
  top: 100px;
  width: calc(100vw - 460px);
  height: 40vh;
  opacity: 1;
}
#body-classes.single-case_studies .case-study-thumb {
  width: calc(100vw - 140px);
  height: clamp(250px, 40vh, 450px);
}
@media (max-width: 768px) {
  #body-classes.single-case_studies .case-study-thumb {
    width: 100vw;
  }
}
#body-classes.single-case_studies .intro {
  padding: 0 80px;
  max-width: 50vw;
  margin: -30px 0 20vh;
  position: relative;
  z-index: 10;
}
@media (max-width: 768px) {
  #body-classes.single-case_studies .intro {
    max-width: 100vw;
    padding: 0 30px;
    margin: -15px 0 50px;
  }
}
#body-classes.single-case_studies .intro h1 {
  margin: 0 0 inherit;
}
#body-classes.single-case_studies .intro .content {
  column-count: 2;
  column-gap: 50px;
}
@media (max-width: 768px) {
  #body-classes.single-case_studies .intro .content {
    column-count: 1;
  }
}

.contact-image {
  padding: 200px 130px 0 80px;
}
@media (max-width: 768px) {
  .contact-image {
    padding: 120px 0px 0 0px;
  }
}
.contact-image .img-wrap {
  padding-top: 30%;
}
@media (max-width: 768px) {
  .contact-image .img-wrap {
    padding-top: 50%;
  }
}

.contact-intro {
  padding: 0 130px 0 80px;
}
@media (max-width: 768px) {
  .contact-intro {
    padding: 0 30px;
    box-sizing: border-box;
    width: 100%;
  }
}
.contact-intro .contact-intro-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  align-items: flex-end;
}
@media (max-width: 768px) {
  .contact-intro .contact-intro-wrap {
    grid-template-columns: 1fr;
  }
}
.contact-intro .contact-intro-wrap .content-wrap {
  max-width: 500px;
}
.contact-intro .contact-intro-wrap .address-wrap {
  justify-self: center;
  display: flex;
  margin-bottom: 1em;
}
@media (max-width: 768px) {
  .contact-intro .contact-intro-wrap .address-wrap {
    flex-direction: column;
  }
}
.contact-intro .contact-intro-wrap .address-wrap > div:first-of-type {
  max-width: 250px;
  font-size: 30px;
  padding-right: 25px;
  border-right: 1px solid #E0DDA4;
}
@media (max-width: 768px) {
  .contact-intro .contact-intro-wrap .address-wrap > div:first-of-type {
    max-width: 100%;
    margin-bottom: 20px;
  }
}
.contact-intro .contact-intro-wrap .address-wrap > div:last-of-type {
  padding-left: 30px;
}
@media (max-width: 768px) {
  .contact-intro .contact-intro-wrap .address-wrap > div:last-of-type {
    padding: 0;
  }
}

.contact-form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 120px;
  padding: 0 130px 0 80px;
}
@media (max-width: 768px) {
  .contact-form {
    grid-template-columns: 1fr;
    padding: 0 20px;
    gap: 40px;
  }
}

.page-template-contact #sections {
  gap: 80px;
}
@media (max-width: 768px) {
  .page-template-contact #sections {
    gap: 40px;
  }
}

/*# sourceMappingURL=style.css.map */
