/*
Theme Name: Astra Child
Theme URI: https://wpastra.com/
Template: astra
Author: Brainstorm Force
Author URI: https://wpastra.com/about/?utm_source=theme_preview&utm_medium=author_link&utm_campaign=astra_theme
Description: The Astra WordPress theme is lightning-fast and highly customizable. It has over 1 million downloads and the only theme in the world with 5,700+ five-star reviews! It’s ideal for professional web designers, solopreneurs, small businesses, eCommerce, membership sites and any type of website. It offers special features and templates so it works perfectly with all page builders like Spectra, Elementor, Beaver Builder, etc. Fast performance, clean code, mobile-first design and schema markup are all built-in, making the theme exceptionally SEO-friendly. It’s fully compatible with WooCommerce, SureCart and other eCommerce plugins and comes with lots of store-friendly features and templates. Astra also provides expert support for free users. A dedicated team of fully trained WordPress experts are on hand to help with every aspect of the theme. Try the live demo of Astra: https://zipwp.org/themes/astra/
Tags: custom-menu,custom-logo,entertainment,one-column,two-columns,left-sidebar,e-commerce,right-sidebar,custom-colors,editor-style,featured-images,full-width-template,microformats,post-formats,rtl-language-support,theme-options,threaded-comments,translation-ready,blog
Version: 4.11.12.1758593961
Updated: 2025-09-23 02:19:21

*/

/*** Global ***/
:root {
	--orange: #FFA31D;   
	--yellow: #FFC166;
	--gray: #878787;
	--light-gray: #b5b5b5;
	--arrow: url("data:image/svg+xml,%3Csvg%20width%3D%2243%22%20height%3D%2243%22%20viewBox%3D%220%200%2043%2043%22%20fill%3D%22none%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M0%2023.767L32.151%2023.767L17.363%2038.552L21.126%2042.252L42.252%2021.1259L21.126%20-4.57764e-05L17.363%203.69995L32.151%2018.4879L0%2018.4879L0%2023.767Z%22%20fill%3D%22%23FFA31D%22/%3E%3C/svg%3E");
  --chevron-circle:
url("data:image/svg+xml,%3Csvg width='30' height='30' viewBox='0 0 30 30' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M15.0002 9.7503L8.25018 16.5003L10.3872 18.6003L15.0002 13.9873L19.6132 18.6003L21.7502 16.5003L15.0002 9.7503ZM15.0002 0.000297546C17.0107 -0.0128632 19.0022 0.389225 20.8502 1.18133C22.6277 1.93661 24.2444 3.02481 25.6132 4.38732C26.9757 5.75611 28.0639 7.37281 28.8192 9.15032C29.6113 10.9983 30.0133 12.9898 30.0002 15.0003C30.0133 17.0108 29.6113 19.0023 28.8192 20.8503C28.0638 22.6274 26.9756 24.2438 25.6132 25.6123C24.2444 26.9748 22.6277 28.063 20.8502 28.8183C19.0023 29.6107 17.0107 30.0131 15.0002 30.0003C12.9897 30.0135 10.9981 29.6114 9.15018 28.8193C7.37265 28.064 5.75595 26.9758 4.38718 25.6133C3.02477 24.2448 1.93657 22.6285 1.18118 20.8513C0.388968 19.0031 -0.013092 17.0111 0.000177383 15.0003C-0.0129547 12.9898 0.389103 10.9983 1.18118 9.15032C1.93646 7.37281 3.02467 5.75611 4.38718 4.38732C5.75597 3.02481 7.37266 1.93661 9.15018 1.18133C10.9981 0.389225 12.9897 -0.0128632 15.0002 0.000297546ZM15.0002 3.0003C13.4184 2.96936 11.8471 3.26282 10.3832 3.86254C8.91919 4.46227 7.59361 5.35554 6.48818 6.4873C5.35611 7.59276 4.46257 8.91847 3.86267 10.3826C3.26276 11.8468 2.96923 13.4183 3.00018 15.0003C2.96931 16.5821 3.26288 18.1535 3.86278 19.6175C4.46268 21.0815 5.35619 22.407 6.48818 23.5123C7.59349 24.6443 8.91903 25.5378 10.383 26.1377C11.847 26.7376 13.4184 27.0312 15.0002 27.0003C16.5819 27.0313 18.1533 26.7379 19.6172 26.1382C21.0812 25.5384 22.4068 24.6451 23.5122 23.5133C24.6443 22.4079 25.5379 21.0822 26.1378 19.618C26.7377 18.1539 27.0312 16.5823 27.0002 15.0003C27.0312 13.4183 26.7377 11.8467 26.1378 10.3826C25.5379 8.9184 24.6443 7.59273 23.5122 6.4873C22.4067 5.35554 21.0812 4.46227 19.6172 3.86254C18.1532 3.26282 16.5819 2.96936 15.0002 3.0003Z' fill='%23FFA31D'/%3E%3C/svg%3E%0A");
}

/*** Global Styles ***/

body {
	font-weight: 300 !important;
	text-wrap: balance;
	
	h1, h2, h3, h4, h5, h6, .entry-content :where(h1,h2,h3,h4,h5,h6) {
		text-wrap: balance;
		margin-bottom: 1em;
		letter-spacing: 0.02em !important;
	}
	
	h6 {
		font-weight: 500 !important;
	}
	
}

@supports (-webkit-touch-callout: none) {
  [style*="background-attachment:fixed"],
  .gradient-overlay {
    background-attachment: scroll !important;
    background-position: center center !important;
    background-size: cover !important;
    transform: translateZ(0);
    will-change: transform;
  }
}

#content .wpb_text_column :last-child:is(h1,h2,h3,h4,h5,h6),
.wpb_text_column :last-child:is(h1,h2,h3,h4,h5,h6) {
	margin-bottom: 1em;
}

.wpb-content-wrapper > .wpb_row {
    padding-top: 8rem;
    padding-bottom: 8rem;
}

hr {
    background-color: #000;
    border: 0;
    height: 1px;
    margin-bottom: 2rem;
}

.max-width--900 {
	margin-inline: auto !important;
	max-width: 980px;
	padding-inline: 1rem;
}

.fixed-bg {
	background-attachment: fixed;
	background-size: cover;
}

.hero {
	* { margin: 0 !important; }
	
	.vc_column-inner > .wpb_wrapper {
		display: flex;
		flex-direction: column;
		gap: 60px;
		max-width: 1080px;
	}
}

.wpb-content-wrapper > .wpb_row > .wpb_column > .vc_column-inner {
    padding-inline: 1.5rem;
}

.vc_row.vc_row-no-padding > .wpb_column > .vc_column-inner {
    padding-left: 0;
    padding-right: 0;
}

a.vc_single_image-wrapper:hover {
	translate: 0 .5rem;
	opacity: .8;
}

.ast-container, .ast-container-fluid {
    padding: 0;
}

figcaption.vc_figure-caption {
    margin-top: 1.25em !important;
    line-height: 1.5;
    font-size: .75em !important;
}

.gradient-overlay {
	position: relative;
	background-color: #000;
	isolation: isolate;
	background-attachment: fixed;

	> * {
		position: relative;
		z-index: 2;
	}
	
	&::before {
		content: "";
		position: absolute;
		inset: 0;
		background: rgba(0, 0, 0, 0.6);
		pointer-events: none;
		z-index: 0;
		display: block !important;
		visibility: visible !important;
        width: 100% !important;
        height: 100% !important;
	}

	&::after {
		content: "";
		position: absolute;
		inset: 0;
		background: linear-gradient(
			180deg,
			#000000 0%,
			rgba(0, 0, 0, 0) 25%,
			rgba(0, 0, 0, 0) 75%,
			#000000 100%
		);
		pointer-events: none;
		z-index: 1;
		display: block !important;
		visibility: visible !important;
        width: 100% !important;
        height: 100% !important;
	}
	
	&.rotated::after {
		background: linear-gradient(
			90deg,
			#000000 0%,
			rgba(0, 0, 0, 0) 25%,
			rgba(0, 0, 0, 0) 75%,
			#000000 100%
		);
	}
}

/*** Paralax Marquee ***/

.ldw-parallax-marquee {
	* { white-space: nowrap; }
	
	h2 {
		font-size: 7.5rem;
		line-height: 1;
		color: rgba(217, 217, 217, 0.3) !important;
		margin-bottom: 0 !important;
		white-space: nowrap;
	}

} 


/*** Liberty Button ***/
.ldw-btn {
	display: flex;
    width: fit-content;
  align-items: center;
  justify-content: center;
  height: 50px;
  padding: 0 36px;
  border: 1px solid var(--orange);
  border-radius: 0;
  box-sizing: border-box;
  text-decoration: none !important;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color .2s ease, border-color .2s ease, color .2s ease, transform .08s ease;
  font-style: normal;
  font-weight: 500;
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.05em;
  color: #000000;
  position: relative;  
  overflow: hidden;
	
	&.center {
		margin-inline: auto;
	}

  span,  
  & > * {
    position: relative;
    z-index: 1; 
  }

  &:active { transform: translateY(1px); }

  &:focus-visible {
    outline: 2px solid var(--yellow);
    outline-offset: 2px;
  }

  &.ldw-btn--primary {
    background: var(--orange);

    &:hover {
      background: var(--yellow);
      border-color: var(--yellow);
      color: #000000;
    }
  }

  &.ldw-btn--secondary {
    background: #ffffff;

    &:hover {
      background: var(--yellow);
      border-color: var(--yellow);
      color: #000000;
    }
  }

  + .ldw-btn {
    margin-left: 20px;
  }

  /* Subtle shine sweep */
  &::before, .ast-custom-button::before {
    content: "";
    position: absolute;
    top: -25%;
    left: -60%;
    width: 50%;
    height: 150%;
    pointer-events: none;
    background: linear-gradient(
      60deg,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.2) 50%,
      rgba(255, 255, 255, 0) 100%
    );
    transform: translateX(-120%) skewX(-20deg);
    transition: transform 300ms ease;
    mix-blend-mode: screen;
    z-index: 0; 
  }

  &:hover::before, .ast-custom-button:hover::before {
    transform: translateX(350%) skewX(-20deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ldw-btn::before {
    transition: none;
    transform: none;
    opacity: 0;
  }
}

.wpb_content_element + .ldw-btn {
    margin-top: 6em;
}


.ldw-btn--cta {
    display: inline-flex;
    align-items: center;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.05em;
    text-transform: uppercase;
	line-height: 1;
    color: #fff;
    text-decoration: none;
    gap: 0.5rem;
    transition: all 0.2s ease;
	
	&:hover {
		color: var(--yellow);
		gap: .75rem;
    }
	
	&::after {
      content: "";
      width: 1rem;
      height: 1rem;
      background: var(--arrow) no-repeat center / contain;
    }
}



/*** Capabilities Menu ***/

.menu-capabilities-container {

  .menu {
    list-style: none;
    padding: 0;
    margin: 0;

    .menu-item {
      .menu-link {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 1rem 0;
		font-family: 'Merriweather';
		font-style: normal;
		font-weight: 600;
		font-size: 30px;
		line-height: 38px;
		letter-spacing: 0.02em;
		color: #000000;
        text-decoration: none;
        border-bottom: 2px solid #acacac;
        position: relative;
        transition: color 0.2s ease;
		  
		  &:hover {
			  color: var(--orange) !important;
		  }

        &::after {
			@media (max-width: 768px) { scale: .9; }

          content: "";
          background-image: var(--arrow);
          background-size: contain;
          background-repeat: no-repeat;
          width: 2rem;
          height: 2rem;
          transform: rotate(-45deg);
          transition: all 0.25s ease;
        }

        &:hover::after {
          translate: 4px -4px;
			opacity: 0.8;
        }
      }
    }
  }
}



/*** Header ***/

a.menu-link {
    letter-spacing: .05em;
}

.sub-menu { 
	padding: 1rem 0;
	
	a.menu-link {
		padding-top: 0 !important;
		padding-bottom: 0 !important;
		text-transform: none;
		line-height: 2 !important;
	}
}

#masthead > #ast-desktop-header > .ast-below-header-wrap, #ast-fixed-header #ast-desktop-header .ast-main-header-wrap  {
    display: none;
}

.site-header-primary-section-right {
    position: relative;
	
	.ast-header-account {
		position: absolute;
		top: 0;
		right: 0;
	}
}

.ast-mobile-popup-drawer.active .ast-mobile-popup-inner {
    background-color: rgb(0 0 0 / 80%);
    backdrop-filter: blur(10px);
}

.ast-mobile-popup-header {
    min-height: 128px !important;
	
	#menu-toggle-close {
		width: 32px;
		height: 32px;
		background: var(--ast-global-color-0);
		display: flex;
		align-content: center;
		justify-content: center;
		flex-wrap: wrap;
		position: absolute;
		top: 32px;
		right: 32px;

		 &:hover {
			 background: var(--ast-global-color-1);
		 }
		
		&:focus {
			border: 0;
		}

		.ast-svg-iconset {
			font-size: 32px;
		}

		 svg {
			 width: 24px;
			 height: 24px;
		 }
	}
}

button.ast-menu-toggle {
    padding: 0 1.5em !important;
    line-height: 2 !important;
}

@media (max-width: 921px) {
	.ast-header-break-point #ast-fixed-header .site-logo-img .custom-logo-link img {
        width: 122px;
        height: 55px;
    }
}

#ast-desktop-toggle-menu, #ast-mobile-popup {
	.sub-menu {
    font-size: .6em;
	
		span.ast-icon.icon-arrow {
			display: none;
		}
	}
}

/*** Footer ***/
footer {
	.widget ul, .widget p {
		line-height: 2;
	}
	
	h3.wp-block-heading {
		margin-bottom: 0 !important;
	}

	#wpforms-186 {
		
		width: 336px;
		@media (min-width: 922px) { margin-inline: 0 !important; }
		
	  form#wpforms-form-186,
	  .wpforms-field-container,
	  .wpforms-submit-container {
		display: flex;
		flex-wrap: nowrap;
		align-items: stretch;
		margin: 0;
	  }
		
		.wpforms-field-container {
			width: 250px;
		}

	  .wpforms-field-email {
		flex: 1;
		margin: 0;
		padding: 0;

		input {
		  max-width: 100%;
		  border-right: none;
		  padding: 12px 16px;
		  font-size: 14px;
		  height: 48px;
		  line-height: 48px;
		}
	  }

	  .wpforms-submit-container {
		margin: 0;
		  width: 87px;

		.wpforms-submit {
		  color: #000;
		  font-weight: 500;
		  font-size: 14px;
		  text-transform: uppercase;
		  padding: 0 24px;
		  cursor: pointer;
		  border-radius: 0;
		  display: flex;
		  align-items: center;
		  height: 48px;
		  line-height: 48px;
		}
	  }
	}


	.site-footer-above-section-2 {
		
		h3 {
			text-transform: uppercase;
			font-family: 'Roboto Flex';
				margin: 0 !important;
		}
		
		.widget_block {
			margin-bottom: .75em;
		}

		.widget_text {
			margin-bottom: 1.25em;
		}
		
	}
	
}

#ast-scroll-top {
  .ast-icon.icon-arrow {
    position: relative;
    width: 32px;
    height: 32px;
    display: inline-block;
    background-image: var(--chevron-circle);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
	transition: all 0.25s ease;

		&:hover {
			transform: translate(0, -4px);
			opacity: 0.8;
		}
	}

  .ast-icon.icon-arrow svg {
    display: none;
  }
}

/*** Home Page ***/
.home.hero {
	width: 100vw !important;
	height: 100vh !important;   
	
	.vc_column-inner > .wpb_wrapper {
		max-width: 1240px;
		margin-inline: auto !important;
		padding-inline: 1rem;
	}

}

.hero-video_wrapper {
	position: absolute !important;
	top: 0;
	left: 0;
	width: 100vw !important;
	height: 100vh !important;
	object-fit: cover;
	object-position: center;
	z-index: -1;
	pointer-events: none;
}

.hero-video_wrapper::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.3);
	pointer-events: none;
	z-index: 1;
	display: block !important;
	visibility: visible !important;
	width: 100vw !important;
	height: 100vh !important;
}
.hero-video_wrapper:after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		180deg,
		#000000 0%,
		rgba(0, 0, 0, 0) 25%,
		rgba(0, 0, 0, 0) 75%,
		#000000 100%
	);
	pointer-events: none;
	z-index: 1;
	display: block !important;
	visibility: visible !important;
	width: 100vw !important;
	height: 100vh !important;
}

.hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transform: translate(-50%, -50%);
  z-index: 0;
  min-width: 100%;
  min-height: 100%;
}

.process {
	.scrolling-process {
		z-index: 0;
	}
	
	.vc_inner {
		z-index: 3;
	}
	&::after {
		z-index: 2;
	}
}
.scrolling-process {
	position: absolute;
	top: -6rem;
	
	ul {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 2em;
    padding: 0;
    margin: 0;
    list-style: none;

    li {
      display: flex;
      align-items: center;

      h3 {
			margin: 0 !important;
			position: relative;
			padding-right: 2em;
			width: max-content;

        &::after {
          content: "";
          position: absolute;
          right: 0;
          top: 0.08em;
          background-image: var(--arrow);
          background-repeat: no-repeat;
          background-size: contain;
          width: 1em;
          height: 1em;
        }
      }
    }
  }
}

@media (min-width: 922px) {
  .why-ldw {
    display: flex;
    align-items: stretch;
    overflow: hidden;
  }

  /* Left column (background image) */
  .why-ldw > .vc_column_container:first-child {
    position: sticky;
    top: 0;
    flex: 0 0 50%;
    height: 100vh;
    background-attachment: fixed !important; /* simulate "pinned" look */
    background-position: center center !important;
    background-size: cover !important;
    z-index: 0;
  }

  /* Right column (text scrolls) */
  .why-ldw > .vc_column_container:last-child {
    flex: 0 0 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 2rem 5vw;
    position: relative;
    z-index: 1;
  }

  /* Text reveal animation */
  .why-ldw .wpb_wrapper > * {
    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s ease-out;
  }

  .why-ldw .wpb_wrapper > *.visible {
    opacity: 1;
    transform: translateY(0);
  }
}

.why-ldw > .vc_column_container:last-child {
	padding: 4rem 1.5rem;
}
 

/*** Testimonial Slider ***/
.ldw-testimonials {
  position: relative;
  --slider-gutter: 3rem;

  .ldw-testimonials__slider {
    position: relative;
    overflow: hidden;
    margin-inline: var(--slider-gutter);
  }

  .swiper-wrapper {
    display: flex;
    align-items: center;
  }

  .swiper-slide {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    transition: min-height 0.3s ease;
  }

  .ldw-testimonial-card {
    max-width: 800px;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2rem;

    .ldw-testimonial-card__quote svg {
      display: block;
      margin: 0 auto;
      fill: var(--orange);
    }

    .ldw-testimonial-card__author {
      font-size: 1.25rem;
      line-height: 1.25;
    }
  }
	.ldw-testimonial-card__quote {
		svg {
	  @media (max-width: 768px) { width: 50px; height: 37px; }
		}
	}


  .ldw-testimonials__nav {
	  	  
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    pointer-events: none;
    transform: translateY(-50%);
    z-index: 2;

    .ldw-testimonials__prev,
    .ldw-testimonials__next {
      width: 46px;
      height: 46px;
      display: flex;
      align-items: center;
      justify-content: center;
      pointer-events: all;
      cursor: pointer;
      background: transparent;
      transition: all 0.25s ease;

      &::before {
		@media (max-width: 768px) { scale: .9; }

        content: "";
        width: 38px;
        height: 38px;
        background-image: var(--chevron-circle);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        transition: all 0.25s ease;
      }

      &.ldw-testimonials__prev::before { transform: rotate(-90deg); }
      &.ldw-testimonials__next::before { transform: rotate(90deg); }

      &:hover::before { opacity: 0.8; }
      &.ldw-testimonials__prev:hover::before { translate: -4px 0; }
      &.ldw-testimonials__next:hover::before { translate: 4px 0; }
    }
  }
}


/*** Project Single ***/

.single-project #content {
	padding: 0 1rem;
}

.project-hero {
  position: relative;
  display: flex;
  align-items: flex-end;   /* pushes content to bottom */
  justify-content: center; /* centers horizontally */
  min-height: 100vh;
	width: 100vw;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  min-height: 100svh; /* better on mobile than 100vh */
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
	overflow: hidden;

  .project-hero__content {
    width: 100%;
    max-width: 1240px;   /* site grid */
    margin: 0 auto;      /* center inside */
    padding: 4rem 1rem;
    text-align: left;

    .project-title {
      margin: 0 !important;
      color: #fff;
      max-width: 800px;

      span {
        font-size: 1.42em;
      }
    }
  }
}


.project-details {
  display: grid;
  grid-template-columns: minmax(260px, 420px) 1fr;
  column-gap: clamp(24px, 6vw, 80px);
  align-items: start;
	padding-top: 10rem;
	padding-bottom: 10rem;

  .project-meta {
    p {
      display: grid;
      grid-template-columns: 140px 1fr;
      align-items: center;
      margin: 0 0 10px;
      line-height: 25px;
      font-family: 'Roboto Flex', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      font-weight: 300;
      font-size: 14px;
      letter-spacing: 0.05em;
      color: #000;

      strong {
        font-weight: 700;
        color: #ACACAC;
        text-transform: uppercase;
      }
    }
  }

  .project-description {
  }
}

@media (max-width: 900px) {
  .project-details {
    grid-template-columns: 1fr;
    row-gap: 32px;

    .project-meta p {
      grid-template-columns: 120px 1fr;
    }
  }
}

@media (max-width: 540px) {
  .project-details .project-meta p {
    grid-template-columns: 1fr;
    row-gap: 2px;

    strong { margin-bottom: 2px; }
  }
}

.project-gallery {
	margin-bottom: 1rem;
	
  .project-gallery__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: repeat(6, 1fr);
    gap: 1.25rem;

    .project-gallery__item {
      overflow: hidden;

      img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        display: block;
      }
    }

    /* Item 1 */
    .project-gallery__item:nth-child(1) {
      grid-column: span 2 / span 2;
      grid-row: span 3 / span 3;
    }

    /* Item 2 */
    .project-gallery__item:nth-child(2) {
      grid-column: span 3 / span 3;
      grid-row: span 3 / span 3;
      grid-column-start: 3;
    }

    /* Item 3 */
    .project-gallery__item:nth-child(3) {
      grid-column: span 3 / span 3;
      grid-row: span 3 / span 3;
      grid-row-start: 4;
    }

    /* Item 4 */
    .project-gallery__item:nth-child(4) {
      grid-column: span 2 / span 2;
      grid-row: span 3 / span 3;
      grid-column-start: 4;
      grid-row-start: 4;
    }
  }

  @media (max-width: 768px) {
    .project-gallery__grid {
      grid-template-columns: 1fr;
      grid-template-rows: none;

      .project-gallery__item {
        aspect-ratio: 4 / 3; /* keep rectangle-ish ratio */
      }

      .project-gallery__item:nth-child(n) {
        grid-column: auto;
        grid-row: auto;
        grid-column-start: auto;
        grid-row-start: auto;
      }
    }
  }
}

.project-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10rem;

  a {
    display: inline-flex;
    align-items: center;
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--orange);
    text-decoration: none;
    gap: 0.5rem;
    transition: color 0.2s ease;

    &:hover {
      color: var(--light-yellow);
    }
  }

  .prev a {
    padding-left: 1.5rem;
    position: relative;

    &::before {
      content: "";
      position: absolute;
      left: 0;
      top: 50%;
      transform: translateY(-50%) rotate(180deg);
      width: 1rem;
      height: 1rem;
      background: var(--arrow) no-repeat center / contain;
    }
  }

  .next a {
    padding-right: 1.5rem;
    position: relative;

    &::after {
      content: "";
      position: absolute;
      right: 0;
      top: 50%;
      transform: translateY(-50%);
      width: 1rem;
      height: 1rem;
      background: var(--arrow) no-repeat center / contain;
    }
  }
}


/*** Project Card ***/
.ldw-project-card {
	  display: flex;
	  flex-direction: column;
	  height: 100%;
	  text-decoration: none;
	  transition: transform 0.3s ease;
	  position: relative;
	color: inherit !important;

	  .ldw-project-card__img {
		margin-bottom: 1rem;
		aspect-ratio: 1;
		overflow: hidden;
		display: flex;
		align-items: center;
		justify-content: center;

		img {
		  width: 100%;
		  height: 100%;
		  object-fit: cover;
		  object-position: center;
		  display: block;
		  transition: transform 0.35s ease;
		}
	  }

	  h5 {
		margin: 0 !important;
		display: flex;
		justify-content: space-between;

		&::after {
		  content: "";
		  background-image: var(--arrow);
		  background-size: contain;
		  background-repeat: no-repeat;
			flex-shrink: 0; 
		  width: 1.5rem;
		  height: 1.5rem;
		  transform: rotate(-45deg);
		  margin-left: 0.5rem;
		  transition: all 0.25s ease;
			
			@media (max-width: 768px) { width: 1.2em; height: 1.2em; }
		}
	  }

	  p {
		margin: 0;
	  }

	  &:hover {
		h5 {
		  color: var(--orange);

		  &::after {
			translate: 4px -4px;
		  }
		}

	  }
}

/*** Related Projects on Single Project post ***/
.single-project-grid {
  padding: 6rem 0;
  color: #fff;
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);

  .single-project-grid__title {
    text-align: center;
    font-family: 'Merriweather', serif;
    font-weight: 300;
    font-size: 2.5rem;
    color: #fff;
    margin-bottom: 3rem;

    .dropdown {
      display: inline-block;
      position: relative;
      cursor: pointer;
      padding-bottom: 1rem;
      margin-right: .25rem;

      .dropdown__current {
        color: var(--orange);
        border-bottom: 2px solid var(--orange);
        padding: 0 0 0 .25em;
        text-transform: lowercase;
        transition: opacity 0.3s ease, transform 0.3s ease;

        &::after {
          content: "";
          display: inline-block;
          background-image: var(--chevron-circle); 
          background-size: contain;
          background-repeat: no-repeat;
          width: 1.25rem;
          height: 1.25rem;
          margin-left: 0.5rem;
          transform: rotate(180deg);
          transition: transform 0.25s ease;
        }

        &:hover::after {
          transform: rotate(0deg);
        }

        &.is-updating {
          opacity: 0;
          transform: translateY(-5px);
        }
      }

      .dropdown__menu {
        display: none;
        position: absolute;
        top: 100%;
        right: 0;
        background: rgb(0 0 0 / 80%);
        border: 2px solid var(--orange);
        padding: 0;
        min-width: 200px;
        z-index: 1000;
        text-align: center;

        li {
          list-style: none;

          a {
            display: block;
            font-size: 1.25rem;
            color: #fff;
            line-height: 2;
            text-decoration: none;
            transition: color 0.2s ease;

            &:hover {
              color: var(--orange);
              background: rgba(255, 255, 255, 0.05);
            }
          }
        }
      }

      &:hover .dropdown__menu {
        display: block;
      }
    }
  }

  .grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 2rem;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 1rem;
    position: relative;
    transition: opacity 0.4s ease;

    &.is-updating {
      opacity: 0;
    }

  }
}

/*** Recent Projects Slider ***/

.ldw-recent-projects {
  --slider-gutter: 3rem;
  position: relative;

  .ldw-recent-projects__slider {
    position: relative;
    margin-inline: var(--slider-gutter);
    overflow: hidden;
    clip-path: inset(0 round 0);
  }

  .swiper-wrapper {
    overflow: visible;
  }

  .ldw-recent-projects__nav {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    pointer-events: none;
    transform: translateY(-50%);
    z-index: 10;

    .ldw-recent-projects__prev,
    .ldw-recent-projects__next {
      width: 46px;
      height: 46px;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      pointer-events: all;
      background: transparent;
      transition: all 0.25s ease;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);

      &::before {
		@media (max-width: 768px) { scale: .9; }

		display: block;
        content: "";
        width: 38px;
        height: 38px;
        background-image: var(--chevron-circle);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        transition: all 0.25s ease;
      }

      &.ldw-recent-projects__prev::before { transform: rotate(-90deg); }
      &.ldw-recent-projects__next::before { transform: rotate(90deg); }

      &:hover::before { opacity: 0.8; }
      &.ldw-recent-projects__prev:hover::before { translate: -4px 0; }
      &.ldw-recent-projects__next:hover::before { translate: 4px 0; }

      @media (max-width: 768px) {
        width: 40px;
        height: 40px;
        &::before { width: 32px; height: 32px; }
      }
    }

    .ldw-recent-projects__prev { left: 0; }
    .ldw-recent-projects__next { right: 0; }
  }
}


/*** About Us ***/

.our-leaders > .wpb_column > .vc_column-inner > .wpb_wrapper {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(375px, 1fr));
  gap: 8rem 2rem; 
  text-align: center;

  h4 {
    margin: 0 !important;
  }

}


/*** Capabilities ***/
.capabilities-row {
  position: relative;
  overflow: hidden; 
}

.capabilities-row::before {
    content: "";
    display: block !important;
    position: absolute;
    inset: 0;
    background: #000;
    opacity: 0.45;
    z-index: 0;
    visibility: visible !important;
}

.capabilities-row > * {
  position: relative;
  z-index: 1;
}

.parent-pageid-97 {
	.wpb_text_column ul {
	  list-style: none;
	  padding: 0;
	  margin: 0;

		 li {

		  position: relative;
		  padding-left: 2.5rem;
			margin-bottom: .5rem;

			&::before {
			  content: "";
			  position: absolute;
			  left: 0;
			  top: 50%;
			  transform: translateY(-50%);
			  width: 2rem;
			  height: 2px;
			  background-color: var(--orange);
			}

			 h6 {
				 margin-bottom: 0 !important;
			 }
		}
	}
}

/*** Contact Us ***/
.contact-us .contact-info {
	p { 
		font-weight: 500;
		margin-bottom: 0;
		
		a {
			font-size: 25px;
			color: #fff;
			
			&:hover {
				color: var(--orange);
			}
		}
		
	}
	
}

.locations {
	
	h6 {
		color: var(--orange);
	}
	
	p {
		font-weight: 500;
		font-size: 14px;
		letter-spacing: .05em;
		line-height: 25px;
	}
}

/* General WPForms Styling */
.site-content {
	.wpforms-container {
	  max-width: 800px;
	  margin: 0 auto;
	}

	.wpforms-container .wpforms-field-container {
	  display: flex;
	  flex-direction: column;
	  gap: 1rem;
	}

	.wpforms-container input[type="text"],
	.wpforms-container input[type="email"],
	.wpforms-container input[type="url"],
	.wpforms-container input[type="tel"],
	.wpforms-container input[type="number"],
	.wpforms-container input[type="password"] {

	  border: none !important;
	  border-bottom: 1px solid #fff !important;
	  color: #fff;
	  padding: 10px 0 !important;
	  font-size: 14px !important;
	  font-weight: 500 !important;
	  outline: none;
	  box-shadow: none;
	}

	.wpforms-container ::placeholder, .wpforms-field-label {
	  color: #fff !important;
	  opacity: 1 !important;
		font-size: 14px !important;
	  font-weight: 500 !important;
		letter-spacing: .05em;
	}

	.wpforms-container .wpforms-submit-container {
	  text-align: center;
	  margin-top: 2rem !important;
	}

	.wpforms-container button.wpforms-submit {
	  border: none !important;
	  padding: 0 3rem !important;
		letter-spacing: .05em !important;
	  font-size: 14px !important;
	  font-weight: 500 !important;
	  text-transform: uppercase !important;
	  cursor: pointer;
	  transition: background 0.3s ease !important;
	}

	.wpforms-container button.wpforms-submit:hover {
	  background: var(--yellow) !important;
	}
}

.grecaptcha-badge { 
	visibility: hidden; 
}

/*** Process Page ***/

.process-page__three-columns .vc_inner .vc_column_container {
    border-left: 2px solid #d9d9d9;
    padding: 1rem;
	margin: 1rem 0;
}

/*** FAQ ***/

.vc_tta-container {
	.vc_tta-panels {
		border-top: 2px solid #7F7F7F;
	}

	.vc_tta.vc_general .vc_tta-panel {
		border-bottom: 2px solid #7F7F7F;
		padding: 1rem 0;
	}

	.vc_tta-color-black.vc_tta-style-flat .vc_tta-panel .vc_tta-panel-heading {
		background-color: #000 !important;
	}

	.vc_tta-color-black.vc_tta-style-flat .vc_active .vc_tta-panel-heading .vc_tta-controls-icon:after, .vc_tta-color-black.vc_tta-style-flat .vc_active .vc_tta-panel-heading .vc_tta-controls-icon:before, .vc_tta-color-black.vc_tta-style-flat .vc_tta-controls-icon:after, .vc_tta-color-black.vc_tta-style-flat .vc_tta-controls-icon:before {
		border-color: var(--orange) !important;
	}

	.vc_tta.vc_general .vc_tta-panel-title {
		line-height: 1.5 !important;
	}

	.vc_tta.vc_tta-accordion .vc_tta-controls-icon-position-right .vc_tta-controls-icon {
		transform: translateY(-50%) scale(2);
	}
}