/*
Theme Name: Perlemedia
Theme URI: https://perlemedia.com   
Description: A block-based Kadence child theme built for clients of Perlemedia 
Author: Perlemedia
Author URI: https://perlemedia.com  
Template: kadence
Version: 1.0
Text Domain: perlemedia
*/
/* =============================================
 * Table of Contents
 * =============================================

# Initialise
# Global 
# Theme

================================================ */
/* Site Variables */
/* Mixins */
/* =============================================
 * Global
 * ============================================= */
/* Global Styles */
@media (max-width: 767px) {
  .center-mobile {
    text-align: center;
    margin: 0 auto;
  }
  .hide-mobile {
    display: none;
  }
  .sticky-mobile {
    position: sticky !important;
    -webkit-position: sticky;
  }
}
@media (max-width: 1023px) {
  .center-tablet {
    text-align: center;
    margin: 0 auto;
  }
  .hide-tablet {
    display: none;
  }
}
@media (min-width: 1339px) {
  .center-desktop {
    text-align: center;
    margin: 0 auto;
  }
  .hide-desktop {
    display: none;
  }
}
section {
  position: relative;
}
section .site-container {
  margin: 0 auto !important;
  z-index: 1;
  width: 100%;
}
@media (max-width: 1023px) {
  section .site-container {
    max-width: 100%;
  }
}
@media (max-width: 767px) {
  section .site-container.is-layout-flex {
    flex-wrap: wrap;
  }
  section .site-container.is-layout-flex > * {
    flex-basis: 100%;
  }
}
section .site-container.container-left {
  max-width: calc(var(--global-content-width) * 0.5);
  margin-left: auto;
  margin-right: 0;
}
section .site-container.container-right {
  max-width: calc(var(--global-content-width) * 0.5);
  margin-left: 0;
  margin-right: auto;
}
section .site-container .extend-right {
  margin-right: calc((var(--global-content-width) - 100vw) / 2 - var(--global-content-edge-padding));
}
@media (min-width: 1339px) {
  section .site-container .extend-right {
    width: calc(100% - ((var(--global-content-width) - 100vw) / 2 - var(--global-content-edge-padding))) !important;
    max-width: none !important;
  }
}
@media (max-width: 1023px) {
  section .site-container .extend-right {
    margin-right: calc(var(--global-content-edge-padding) * -1);
  }
}
section .site-container .extend-right .carousel-slider__container {
  width: 100%;
}
section .site-container .extend-right img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  border-top-right-radius: 0;
  border-top-left-radius: 0;
}
section .site-container .extend-right.flat-edge img {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}
section .site-container .extend-left {
  margin-left: calc((var(--global-content-width) - 100vw) / 2 - var(--global-content-edge-padding));
}
@media (max-width: 1023px) {
  section .site-container .extend-left {
    margin-left: calc(var(--global-content-edge-padding) * -1);
  }
}
section .site-container .extend-left img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
section .site-container .extend-left.flat-edge img {
  border-top-left-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
}

section.wp-block-group.has-background {
  padding: 0;
}

.wp-block-group__inner-container {
  height: 100%;
}

.gap-large {
  gap: calc(var(--global-content-edge-padding) * 2);
}

.gap-standard {
  gap: var(--global-content-edge-padding);
}

.gap-0 {
  gap: 0;
}

@media (max-width: 767px) {
  .is-position-sticky {
    position: relative;
  }
}

.pin-spacer .is-position-sticky {
  flex-basis: 100% !important;
}

.eyebrow {
  margin: 0;
}

figure.wp-block-image {
  margin: 0;
}

.glass {
  background-color: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(10px);
}

.wp-block-separator {
  width: 100%;
  border-top: 1px solid;
}

.zindex-1 {
  z-index: 1 !important;
}

.zindex-10 {
  z-index: 10 !important;
}

.block-editor-page.post-content-style-boxed .editor-styles-wrapper:before,
.admin-color-pcs-boxed.editor-styles-wrapper:before {
  background: transparent;
}

.editor-styles-wrapper .wp-block-separator {
  width: 100%;
  border-top: 1px solid;
}

.editor-styles-wrapper .site-container,
.block-editor-iframe__html .site-container {
  padding: 0 var(--global-content-edge-padding) !important;
}

.editor-styles-wrapper h1,
.editor-styles-wrapper h2,
.editor-styles-wrapper h3,
.editor-styles-wrapper h4,
.editor-styles-wrapper h5,
.editor-styles-wrapper h6 {
  margin: 0;
}

.block-editor-iframe__html section.wrapper-overlap-container {
  width: 75% !important;
  margin: 20px auto !important;
}

.block-editor-iframe__html section.wrapper-overlap-container::before {
  content: "";
  width: 150%;
  position: absolute;
  top: 50%;
  border-top: 1px solid black;
  left: -25%;
  z-index: -1;
}

/* Animations */
.gsap-swipe-in-left {
  --clip: 100%;
  clip-path: inset(0 0 0 var(--clip));
  opacity: 0;
  will-change: clip-path, transform, opacity;
}

.gsap-parallax-scope,
.clusterGreat {
  position: relative;
  overflow: hidden;
}

.pillar-stage {
  position: relative;
  height: 100vh;
  overflow: clip;
}
.pillar-stage .pillar-pin {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: scale(0.98);
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  will-change: opacity, transform;
  box-sizing: border-box;
}
@media (max-width: 1023px) {
  .pillar-stage .pillar-pin img {
    aspect-ratio: 5/2;
    object-fit: cover;
    object-position: 0 60%;
  }
}
.pillar-stage .pillar-pin.is-initial {
  opacity: 1;
  transform: none;
}

@supports (height: 100svh) {
  .pillar-stage {
    height: 100svh;
  }
}
@supports (-webkit-touch-callout: none) {
  .pillar-stage {
    overflow: hidden;
  }
}
@supports (-webkit-touch-callout: none) {
  @media (hover: none) and (pointer: coarse) {
    .pillar-stage .pillar-pin {
      -webkit-backface-visibility: hidden;
      backface-visibility: hidden;
      will-change: opacity, transform;
    }
  }
}
.marquee-text {
  overflow: hidden;
  width: 100%;
}
.marquee-text .marquee-track {
  display: flex;
  width: max-content;
  align-items: center;
  will-change: transform;
  gap: calc(var(--global-content-edge-padding) * 2);
}
.marquee-text .marquee-track > span {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  width: max-content;
  gap: calc(var(--global-content-edge-padding) * 2);
}
.marquee-text .marquee-track > span figure,
.marquee-text .marquee-track > span .wp-block-image {
  margin: 0;
  flex-shrink: 0;
  line-height: 0;
  width: auto !important;
  height: auto !important;
  max-width: none !important;
}
.marquee-text .marquee-track > span img {
  display: block;
  flex-shrink: 0;
  max-width: none !important;
  width: auto !important;
  height: 50px !important;
}
.marquee-text.is-layout-flex .marquee-track {
  flex: none;
  width: max-content;
}

.parallax-frame {
  position: relative;
  overflow: hidden;
  aspect-ratio: 5/3.5;
}
.parallax-frame.square {
  aspect-ratio: 1.25;
}

.parallax-frame img {
  width: 100%;
  height: 140% !important;
  object-fit: cover;
  will-change: transform;
}

.gsap-swipe-in-left {
  --clip: 100%;
  -webkit-clip-path: inset(0 var(--clip) 0 0);
  clip-path: inset(0 var(--clip) 0 0);
  will-change: clip-path, opacity;
}

.gsap-swipe-in-left img {
  display: block;
  width: 100%;
  height: auto;
}

.gsap-fade-in {
  opacity: 0;
}

.split-word {
  overflow: hidden;
}

.el-is-editing .pillar-stage {
  height: auto;
  overflow: visible;
}

.el-is-editing .pillar-stage .pillar-pin {
  position: static !important;
  inset: auto !important;
  opacity: 1 !important;
  transform: none !important;
  z-index: auto !important;
}

.el-is-editing .gsap-swipe-in-left {
  --clip: 0%;
  opacity: 1 !important;
  visibility: visible !important;
}

.el-is-editing .gsap-fade-in {
  opacity: 1 !important;
}

/* =============================================
 * Theme
 * ============================================= */
/* Site Theme Custom Styles */
#quote-request .gform_wrapper {
  width: 100%;
}
#quote-request .gform_wrapper .gform_required_legend {
  display: none;
}
#quote-request .gform_wrapper .gfield_required_asterisk {
  color: var(--global-palette2);
}
#quote-request .gform_wrapper .gform_fields {
  row-gap: 1rem;
}
#quote-request .gform_wrapper input[type=submit] {
  border-radius: 0 0.75rem;
  font-family: var(--global-body-font-family);
  font-weight: 300;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.15em;
  padding: 0.75rem 2rem 0.75rem 2rem;
  box-shadow: 0px 0px 0px -7px rgba(0, 0, 0, 0);
  transition: 0.4s all ease-out;
}
#quote-request .gform_wrapper input[type=submit]:hover {
  box-shadow: 0px 15px 25px -7px rgba(0, 0, 0, 0.1);
  background: var(--global-palette2);
}
#quote-request h2,
#quote-request .eyebrow {
  margin: 0 !important;
}
@media (max-width: 767px) {
  #quote-request {
    padding: 0 !important;
  }
  #quote-request .site-container {
    padding: 1rem !important;
  }
  #quote-request .site-container .content-wrapper {
    padding: 3rem 2rem !important;
  }
}

.logo-block-marquee {
  filter: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg"><filter id="o"><feFlood flood-color="%2398A3A3" result="c"/><feComposite in="c" in2="SourceGraphic" operator="in"/></filter></svg>#o');
  opacity: 0.3;
}

.wp-block-accordion {
  width: 100%;
}
.wp-block-accordion .wp-block-accordion-item .wp-block-accordion-panel {
  display: block !important;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  padding: 0 !important;
  transition: max-height 0.6s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.6s ease-out, padding 0.6s ease-out, background 0.6s ease-out;
}
.wp-block-accordion button {
  background: transparent !important;
  box-shadow: none !important;
  color: inherit !important;
  align-items: flex-start;
}

.testimonial-slider .wp-block-perlemedia-icon-box .content-container {
  display: flex;
  flex-direction: column;
}
.testimonial-slider .wp-block-perlemedia-icon-box .content-container .icon-box__eyebrow {
  order: 3;
  justify-content: flex-end;
  margin-top: var(--global-content-edge-padding);
}
.testimonial-slider .testimonial-meta {
  display: none;
}

.wp-block-post-template {
  margin-left: 0;
}

@media (max-width: 767px) {
  #site-content h1,
  #site-content h2 {
    font-size: 2.5rem;
  }
  #site-content h3,
  #site-content h4 {
    font-size: 1.5rem;
  }
}

main a {
  text-underline-offset: 0.4em;
}

.highlight-paragraph {
  font-size: 1.25em;
}

.accent-text-color {
  color: var(--global-palette2);
}

.eyebrow {
  font-family: var(--global-body-font-family);
  font-weight: 300;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  position: relative;
}
.eyebrow::before {
  content: "";
  width: 2rem;
  position: relative;
  left: 0;
  height: 1px;
  display: inline-block;
  border-top: 0.5px solid currentColor;
  margin-right: 0.5rem;
}

.wp-element-button.wp-block-button__link a,
a.wp-element-button.wp-block-button__link {
  border-radius: 0 0.75rem;
}

:root :where(.wp-element-button, .wp-block-button__link) {
  font-style: normal !important;
  font-weight: 600 !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}

.pm-button-simple a,
a.pm-button-simple {
  font-family: var(--global-body-font-family);
  font-weight: 300;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  --width:24px;
  position: relative;
  padding: 0.25rem calc(var(--width) + 0.25rem) 0.25rem 0;
  display: flex;
  align-items: center;
  box-shadow: none !important;
}
.pm-button-simple a::before,
a.pm-button-simple::before {
  content: "";
  position: absolute;
  width: 0;
  height: 1px;
  background-color: currentColor;
  left: 0;
  bottom: 0;
  transition: 0.4s width ease-out;
}
.pm-button-simple a::after,
a.pm-button-simple::after {
  content: "";
  background-color: currentColor;
  mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTE4IDhMMjIgMTJMMTggMTYiLz48cGF0aCBkPSJNMiAxMkgyMiIvPjwvc3ZnPg==");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTE4IDhMMjIgMTJMMTggMTYiLz48cGF0aCBkPSJNMiAxMkgyMiIvPjwvc3ZnPg==");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  width: var(--width);
  height: var(--width);
  position: absolute;
  right: 0;
  top: 0;
  display: inline-block;
  transition: 0.4s width ease-out;
}
.pm-button-simple a:hover::before,
a.pm-button-simple:hover::before {
  width: calc(100% - (var(--width) + 0.25rem));
  background-color: var(--global-palette2);
}
.pm-button-simple a:hover::after,
a.pm-button-simple:hover::after {
  background-color: var(--global-palette2);
}
.pm-button-simple a,
a.pm-button-simple {
  font-weight: 100 !important;
}

.pm-button-simple.white a:hover::before,
a.pm-button-simple.white:hover::before {
  background-color: #fff;
}
.pm-button-simple.white a:hover::after,
a.pm-button-simple.white:hover::after {
  background-color: #fff;
}

blockquote a.pm-button-simple {
  display: table;
  text-decoration: none;
  font-weight: 600;
}

.has-text-align-left {
  text-align: left !important;
}

.has-text-align-center {
  text-align: center !important;
}

.has-text-align-right {
  text-align: right !important;
}

#site-content [id^=gform_wrapper_] {
  width: 100%;
}
#site-content [id^=gform_wrapper_] .gform_heading {
  display: none;
}
#site-content [id^=gform_wrapper_] .gform-body .gform_fields {
  row-gap: 1rem;
}
#site-content [id^=gform_wrapper_] .gform-body .gform_fields .gfield .gfield_label {
  margin-bottom: 0.15em;
}
#site-content [id^=gform_wrapper_] .gform-body .gform_fields .gfield .gfield_label .gfield_required_asterisk {
  color: var(--global-palette2);
}
#site-content [id^=gform_wrapper_] .gform-body .gform_fields .gfield .ginput_container input,
#site-content [id^=gform_wrapper_] .gform-body .gform_fields .gfield .ginput_container textarea {
  box-shadow: none;
}
#site-content [id^=gform_wrapper_] .gform-footer input[type=submit] {
  border-radius: 0 0.75rem;
  font-family: var(--global-body-font-family);
  font-weight: 300;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 0.85rem;
  letter-spacing: 0.15em;
  padding: 0.75rem 2rem 0.75rem 2rem;
  box-shadow: 0px 0px 0px -7px rgba(0, 0, 0, 0);
  transition: 0.4s all ease-out;
}
#site-content [id^=gform_wrapper_] .gform-footer input[type=submit]:hover {
  box-shadow: 0px 15px 25px -7px rgba(0, 0, 0, 0.1);
  background: var(--global-palette2);
}

#main-header {
  padding: calc(var(--global-content-edge-padding) / 2) 0;
  position: relative;
}
#main-header::after {
  content: "";
  width: 40%;
  position: absolute;
  bottom: -1rem;
  left: 0;
  display: block;
  height: 1px;
  background: linear-gradient(90deg, white, transparent);
}
#main-header .header-navigation[class*=header-navigation-style-underline] .header-menu-container > ul > li > a:after {
  height: 1px;
}
#main-header ul#primary-menu ul.sub-menu {
  background: rgba(255, 255, 255, 0.7);
  background: linear-gradient(0deg, rgba(52, 64, 85, 0.8), rgba(152, 163, 163, 0.3));
  backdrop-filter: blur(8px);
  border-radius: 0.5rem;
  overflow: hidden;
}
#main-header ul#primary-menu ul.sub-menu a {
  letter-spacing: unset;
  text-transform: unset;
  font-weight: 400px;
}

body.home #main-header ul#primary-menu ul.sub-menu {
  background: linear-gradient(0deg, rgba(52, 64, 85, 0.8), rgba(200, 166, 157, 0.7));
}

@media (max-width: 1023px) and (min-width: 767px) {
  #mobile-header .site-header-row-container-inner {
    background-color: transparent !important;
  }
}
@media (max-width: 767px) {
  #mobile-header a.has-logo-image img {
    width: 80%;
  }
}
#mobile-header .site-header-main-section-right .site-header-item .mobile-header-button-wrap a.mobile-header-button {
  font-size: 0;
  display: block;
}
#mobile-header .site-header-main-section-right .site-header-item .mobile-header-button-wrap a.mobile-header-button::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  background-image: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="1" stroke-linecap="round" stroke-linejoin="round"%3E%3Cpath d="M13.832 16.568a1 1 0 0 0 1.213-.303l.355-.465A2 2 0 0 1 17 15h3a2 2 0 0 1 2 2v3a2 2 0 0 1-2 2A18 18 0 0 1 2 4a2 2 0 0 1 2-2h3a2 2 0 0 1 2 2v3a2 2 0 0 1-.8 1.6l-.468.351a1 1 0 0 0-.292 1.233 14 14 0 0 0 6.392 6.384"/%3E%3C/svg%3E');
  background-size: contain;
  background-repeat: no-repeat;
  vertical-align: middle;
}

@media (max-width: 1023px) and (min-width: 767px) {
  #mobile-drawer .drawer-inner .drawer-content {
    min-height: unset;
    height: 100vh;
  }
  #mobile-drawer .drawer-inner .drawer-content .pm-button-simple {
    background: transparent;
    display: table;
    margin-left: 1rem;
  }
}
@media (max-width: 767px) {
  #mobile-drawer {
    backdrop-filter: blur(5px);
  }
  #mobile-drawer ul#mobile-menu li.menu-item-has-children .drawer-nav-drop-wrap > a {
    display: table !important;
    width: auto !important;
    padding-right: 0 !important;
  }
  #mobile-drawer ul#mobile-menu li.menu-item-has-children ul.sub-menu li a {
    font-size: 1.25rem;
    padding: 0.5rem;
    color: var(--global-palette1) !important;
  }
  #mobile-drawer .button.pm-button-simple {
    background: transparent;
    display: table;
    margin-left: 1rem;
    margin-top: 3rem;
  }
}

@media (max-width: 1023px) and (min-width: 767px) {
  footer.site-footer .site-footer-middle-section-1 figure.wp-block-image {
    max-width: 60%;
  }
}

body.wp-singular.single main#inner-wrap #primary {
  margin: 0;
}
body.wp-singular.single main#inner-wrap #primary section {
  margin-bottom: 0;
}

@media (max-width: 767px) {
  #package-hero {
    padding: 1rem !important;
  }
  #package-hero h1 {
    font-size: 2.5rem;
  }
}

#package-content .price-box {
  border: 1px solid var(--global-palette2);
  outline: 1px solid var(--global-palette2);
  outline-offset: 0.5rem;
}
#package-content .price-box p {
  margin-bottom: 0;
}
#package-content .price-box h2 {
  margin-top: 0;
}
#package-content .site-container.container-right {
  max-width: 100%;
}
@media (max-width: 767px) {
  #package-content {
    padding: 0 !important;
  }
  #package-content .site-container {
    padding: 1rem !important;
  }
  #package-content .site-container .wp-block-columns > .wp-block-column > .content-wrapper {
    padding: 4rem 0 2rem !important;
  }
}

#package-related .is-layout-flex .is-nowrap > .wp-block-perlemedia-image-card {
  flex: 1 1 0;
  min-width: 0;
}
#package-related .is-layout-flex .is-nowrap > .wp-block-group {
  flex: 2 1 0;
  min-width: 0;
}
#package-related .is-layout-flex .is-nowrap > .wp-block-group .wp-block-post-template {
  grid-template-columns: repeat(2, 1fr) !important;
}
#package-related .is-layout-flex .is-nowrap > .wp-block-group .image-card {
  width: 100%;
}
#package-related .is-layout-flex .image-card .image-card__title {
  margin-top: 1rem;
}
#package-related .is-layout-flex .image-card .image-card__title:hover {
  color: var(--global-palette2);
}
#package-related .is-layout-flex .image-card img {
  border-top-left-radius: 3rem !important;
  border-bottom-right-radius: 3rem !important;
}
@media (max-width: 767px) {
  #package-related {
    padding: 0 !important;
  }
  #package-related .site-container {
    padding: 0 1rem 4rem !important;
  }
  #package-related .site-container .is-layout-flex {
    flex-wrap: wrap;
  }
  #package-related .site-container .is-layout-flex .is-nowrap > .wp-block-perlemedia-image-card, #package-related .site-container .is-layout-flex .is-nowrap > .wp-block-group {
    flex-basis: 100%;
  }
  #package-related .site-container .is-layout-flex .is-nowrap .wp-block-post-template {
    grid-template-columns: 1fr !important;
  }
}

body.home #site-navigation #primary-menu > li > a {
  color: var(--global-palette10);
}

#home-hero {
  align-items: stretch;
  min-height: 100svh !important;
  contain: layout;
}
#home-hero.hero-split-modern .right-content .container-right .primary-content {
  --offset: 25%;
  width: calc(100% + var(--offset));
  margin: var(--global-content-edge-padding) 1.5rem;
  margin-left: calc(var(--offset) * -1 - var(--global-content-edge-padding));
  gap: var(--global-content-edge-padding);
  z-index: 1;
  contain: layout;
}
#home-hero .carousel-slider__slides {
  border-radius: 3rem 0 3rem 0;
}
#home-hero .primary-image {
  contain: layout;
}
@media (min-width: 1339px) {
  #home-hero .primary-image {
    max-width: 40vw !important;
  }
}
#home-hero .primary-image figure {
  height: 100%;
  background: var(--global-palette10);
  background: linear-gradient(117deg, rgb(200, 166, 157) 12%, rgb(133, 120, 124) 37%, rgb(52, 64, 85) 100%);
}
#home-hero .primary-image figure img {
  opacity: 0.2;
  height: 100%;
}
@media (min-width: 1339px) {
  #home-hero {
    height: 100svh !important;
  }
  #home-hero .primary-image,
  #home-hero .right-content {
    flex-shrink: 0;
    min-height: 100vh;
    contain: layout;
  }
  #home-hero .wp-block-perlemedia-carousel-slider {
    max-height: 300px !important;
    overflow: hidden !important;
  }
}
#home-hero .right-content {
  flex-shrink: 0;
  min-height: 100vh;
}
@media (max-width: 1023px) {
  #home-hero {
    flex-wrap: wrap;
  }
  #home-hero .primary-image {
    flex-basis: 100%;
  }
  #home-hero .primary-image img {
    aspect-ratio: 1.5/1;
  }
  #home-hero .right-content {
    flex-basis: 100%;
    position: relative;
  }
  #home-hero .right-content .container-right .primary-content {
    width: 100%;
    margin: 0;
    transform: none !important;
    max-width: 100%;
    display: block;
    position: relative;
    left: 0px;
    --offset: 0!important;
  }
  #home-hero .right-content .container-right .primary-content figure {
    position: absolute;
    top: 0;
    margin-left: 50%;
    margin-right: 1rem;
    margin-top: -20%;
    border-bottom-right-radius: 3rem;
    overflow: hidden;
  }
  #home-hero .right-content .container-right .primary-content .carousel-slider {
    max-width: 80% !important;
    width: 166px !important;
    height: 132px !important;
    overflow: hidden;
  }
  #home-hero .right-content .container-right .primary-content .carousel-slider .carousel-slider__container {
    height: 100%;
  }
  #home-hero .right-content .container-right .primary-content .carousel-slider .carousel-slider__container .carousel-slider__slides {
    height: 100%;
  }
  #home-hero .right-content .container-right .primary-content .carousel-slider .carousel-slider__container .carousel-slider__slides figure {
    margin-left: 0;
    margin-right: 0;
    margin-top: 0;
  }
  #home-hero .right-content .container-right .primary-content p {
    flex-basis: 100%;
  }
}
@media (max-width: 767px) {
  #home-hero .right-content {
    padding: 4rem 1rem !important;
  }
}

@media (max-width: 1023px) {
  #home-intro .site-container {
    flex-wrap: wrap;
  }
  #home-intro .site-container > * {
    flex-basis: 100%;
  }
}
@media (max-width: 767px) {
  #home-intro .heading-wrapper {
    padding-top: 0 !important;
  }
}

#home-logos .marquee-text .marquee-track > span img {
  height: 100px !important;
}

#home-portfolio .wp-block-perlemedia-carousel-slider {
  border-top-right-radius: 6rem !important;
  overflow: hidden;
}
#home-portfolio .wp-block-perlemedia-carousel-slider .carousel-slider__container {
  padding-bottom: 40px;
}
#home-portfolio .wp-block-perlemedia-carousel-slider .carousel-slider__container .wp-block-perlemedia-image-card .image-card-wrapper {
  background: linear-gradient(90deg, rgb(224, 223, 222) 0%, rgb(221, 220, 219) 53%, rgb(217, 215, 214) 90%, rgb(209, 208, 207) 100%);
}
#home-portfolio .wp-block-perlemedia-carousel-slider .carousel-slider__container .wp-block-perlemedia-image-card .image-card-wrapper .image-card__image-wrapper img {
  margin-top: -3rem;
}
#home-portfolio p.intro-content {
  padding: 2rem 0;
}
@media (max-width: 767px) {
  #home-portfolio .primary-content {
    padding: 4rem 0 0 0 !important;
  }
}

#home-services > .wp-block-group.content-wrapper {
  position: relative;
}
#home-services > .wp-block-group.content-wrapper::after {
  content: "";
  position: absolute;
  width: 6rem;
  height: calc(100% - 5rem);
  background: var(--global-palette10);
  bottom: 0;
  right: -6rem;
}
#home-services .pin-spacer > .content-wrapper {
  position: relative;
}
#home-services .pin-spacer > .content-wrapper::after {
  content: "";
  position: absolute;
  width: 6rem;
  height: 3rem;
  background: var(--global-palette2);
  top: -3rem;
  left: 0;
}
@media (max-width: 1023px) {
  #home-services {
    flex-wrap: wrap;
  }
  #home-services .content-wrapper {
    flex-basis: 100%;
  }
  #home-services .content-wrapper:nth-child(1) {
    margin: 0 auto -5rem !important;
    padding: 2rem 1rem 6rem !important;
  }
  #home-services .content-wrapper:nth-child(2) {
    min-height: 50vh !important;
  }
}

@media (max-width: 767px) {
  #about-hero .top-section {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    min-height: unset !important;
    align-items: flex-start;
  }
  #about-hero .top-section .site-container > .wp-block-group {
    margin-bottom: -9rem !important;
  }
  #about-hero .top-section .site-container > .wp-block-group figure img {
    max-width: 50%;
    margin: 0 auto;
  }
}

#about-intro .wp-block-perlemedia-icon-box.icon-box {
  border-left: 1px solid var(--global-palette2);
}

@media (max-width: 767px) {
  #about-testimonials .testimonial-slider {
    max-width: 100% !important;
  }
}
#about-testimonials .testimonial-slider .wp-block-perlemedia-icon-box .content-container .icon-box__eyebrow {
  order: 3;
  justify-content: center;
  margin-top: var(--global-content-edge-padding);
  margin-bottom: 2rem;
}

@media (max-width: 1023px) {
  #about-expertise .stat-container {
    flex-wrap: wrap;
    display: flex;
    padding: 1rem;
  }
}

@media (max-width: 1023px) and (min-width: 767px) {
  #about-approach {
    flex-wrap: wrap;
  }
  #about-approach .secondary-content {
    display: none;
  }
}
#about-approach .wp-block-perlemedia-double-image-modern figure.background-element {
  display: none;
}
@media (max-width: 767px) {
  #about-approach .site-container {
    padding: 0 !important;
  }
}

#services-page-services .service-header img {
  aspect-ratio: 16/4.5 !important;
}
@media (max-width: 767px) {
  #services-page-services .wp-block-column:nth-child(2) {
    display: flex;
    flex-direction: column;
  }
  #services-page-services .wp-block-column:nth-child(2) > figure {
    order: 2;
  }
  #services-page-services .wp-block-column:nth-child(2) > p {
    order: 1;
    margin-top: 0 !important;
  }
  #services-page-services .wp-block-column:nth-child(2) > .wp-block-buttons {
    order: 3;
  }
}

@media (max-width: 1023px) and (min-width: 767px) {
  #service-hero .primary-content {
    flex-basis: 90%;
  }
}
@media (max-width: 767px) {
  #service-hero {
    min-height: 90vh !important;
  }
}

@media (max-width: 1023px) {
  #service-benefits .site-container {
    flex-wrap: wrap;
  }
  #service-benefits .site-container .wp-block-perlemedia-icon-box {
    min-width: unset;
    width: calc(50% - 1rem);
  }
}
@media (max-width: 767px) {
  #service-benefits {
    position: relative;
  }
  #service-benefits .site-container .wp-block-perlemedia-icon-box {
    padding: 1rem 0 !important;
  }
}

@media (max-width: 1023px) {
  #service-options {
    position: relative;
  }
  #service-options .site-container {
    flex-wrap: wrap;
  }
  #service-options .site-container > .wp-block-group {
    flex-basis: 100%;
  }
  #service-options .site-container > .wp-block-group.primary-content {
    padding-top: calc(var(--global-content-edge-padding) * 2) !important;
  }
  #service-options .site-container > .wp-block-group.primary-content h2 {
    width: 70%;
    padding-bottom: 2rem;
  }
}
@media (max-width: 1023px) and (max-width: 767px) {
  #service-options .site-container > .wp-block-group.primary-content h2 {
    width: 100%;
  }
}
@media (max-width: 767px) {
  #service-options .site-container .primary-content {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

@media (max-width: 1023px) {
  #service-testimonials .wp-block-perlemedia-carousel-slider {
    max-width: 100% !important;
    padding: 0 5% !important;
  }
  #service-testimonials .wp-block-perlemedia-carousel-slider .swiper-button-prev {
    margin-left: -5%;
  }
  #service-testimonials .wp-block-perlemedia-carousel-slider .swiper-button-next {
    margin-right: -5%;
  }
}
@media (max-width: 767px) {
  #service-testimonials .site-container {
    padding: 4rem 0 !important;
  }
  #service-testimonials .site-container .wp-block-perlemedia-icon-box {
    max-width: unset !important;
    min-width: unset !important;
  }
  #service-testimonials .site-container .wp-block-perlemedia-icon-box .content-container .icon-box__eyebrow {
    justify-content: center;
    padding-bottom: 2rem;
  }
}

#service-cta .site-container .row {
  padding-left: 0;
  margin: -30vh auto 0;
}
#service-cta .site-container .row .wp-element-button {
  margin: 0 auto;
  display: table;
}
@media (max-width: 1023px) {
  #service-cta .site-container .row {
    width: 75%;
  }
}
@media (max-width: 767px) {
  #service-cta .site-container {
    padding: 0 !important;
  }
}

#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__image-wrapper {
  transition: 0.7s all ease-out;
  opacity: 0.2;
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper {
  background: linear-gradient(0deg, white 15%, transparent);
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button {
  font-family: var(--global-body-font-family);
  font-weight: 300;
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  --width:24px;
  position: relative;
  padding: 0.25rem calc(var(--width) + 0.25rem) 0.25rem 0;
  display: flex;
  align-items: center;
  box-shadow: none !important;
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button::before {
  content: "";
  position: absolute;
  width: 0;
  height: 1px;
  background-color: currentColor;
  left: 0;
  bottom: 0;
  transition: 0.4s width ease-out;
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button::after {
  content: "";
  background-color: currentColor;
  mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTE4IDhMMjIgMTJMMTggMTYiLz48cGF0aCBkPSJNMiAxMkgyMiIvPjwvc3ZnPg==");
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-image: url("data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgdmlld0JveD0iMCAwIDI0IDI0IiBmaWxsPSJub25lIiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjEiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PHBhdGggZD0iTTE4IDhMMjIgMTJMMTggMTYiLz48cGF0aCBkPSJNMiAxMkgyMiIvPjwvc3ZnPg==");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  width: var(--width);
  height: var(--width);
  position: absolute;
  right: 0;
  top: 0;
  display: inline-block;
  transition: 0.4s width ease-out;
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button:hover::before {
  width: calc(100% - (var(--width) + 0.25rem));
  background-color: var(--global-palette2);
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button:hover::after {
  background-color: var(--global-palette2);
}
#service-packages .wp-block-perlemedia-image-card .image-card-wrapper .image-card__content-wrapper .image-card__button {
  background: transparent !important;
  color: currentColor;
  box-shadow: none !important;
  align-self: flex-start;
  margin-top: 1rem;
}
#service-packages .wp-block-perlemedia-image-card:hover .image-card-wrapper .image-card__image-wrapper {
  filter: blur(5px);
  opacity: 0.6;
}
@media (max-width: 1023px) {
  #service-packages .wp-block-columns {
    flex-wrap: wrap !important;
  }
  #service-packages .wp-block-columns > .wp-block-column {
    flex-basis: 100% !important;
  }
  #service-packages .wp-block-columns > .wp-block-column h2 {
    width: 70%;
  }
}
@media (max-width: 1023px) and (max-width: 767px) {
  #service-packages .wp-block-columns > .wp-block-column h2 {
    width: 100%;
  }
}
@media (max-width: 1023px) {
  #service-packages .wp-block-columns > .wp-block-column .wp-element-button {
    width: auto;
  }
  #service-packages .wp-block-columns > .wp-block-column .wp-block-group.is-layout-flex {
    flex-wrap: wrap;
  }
}
@media (max-width: 767px) {
  #service-packages {
    padding-bottom: 0 !important;
  }
  #service-packages .site-container {
    padding-left: 2rem !important;
    padding-right: 2rem !important;
  }
}

@media (max-width: 767px) {
  #service-faq {
    padding-bottom: 0 !important;
  }
  #service-faq .site-container {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}

body.packages-template-default.single-packages .entry-content-wrap {
  padding: 0 !important;
}

#package-hero .eyebrow {
  margin-bottom: 0;
}
#package-hero h1 {
  margin-top: 0;
}
#package-hero p.intro-content {
  width: 80%;
}

#package-content .eyebrow {
  margin-bottom: 0;
}
#package-content h2,
#package-content h3 {
  margin-top: 0;
}
#package-content p.intro-content {
  padding: 0 !important;
}
#package-content .wp-block-perlemedia-icon-box {
  margin: 0 !important;
}
#package-content .wp-block-perlemedia-icon-box h4.icon-box__title {
  font-size: 1.5em !important;
}

@media (max-width: 767px) {
  #pricing-package-intro .is-content-justification-center > .wp-block-group {
    min-width: 100% !important;
  }
}

#pricing-packages .package-filter {
  margin-bottom: 2rem;
}
#pricing-packages .package-filter .package-filter__buttons {
  display: flex;
  justify-content: center;
  gap: var(--global-content-edge-padding);
}
#pricing-packages .package-filter .package-filter__buttons button {
  background: transparent;
  padding: 0;
  position: relative;
  font-weight: 100 !important;
}
#pricing-packages .package-filter .package-filter__buttons button::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: currentColor;
  opacity: 0;
  transition: 0.4s opacity ease-out;
}
#pricing-packages .package-filter .package-filter__buttons button.is-active {
  color: var(--global-palette2);
}
#pricing-packages .package-filter .package-filter__buttons button.is-active::after {
  opacity: 1;
}
#pricing-packages .package-filter .package-filter__buttons button:hover {
  color: var(--global-palette1);
}
#pricing-packages ul.is-layout-grid li.wp-block-post {
  background: white;
  overflow: hidden;
  border-top-left-radius: 3rem;
  border-bottom-right-radius: 3rem;
}
#pricing-packages ul.is-layout-grid li.wp-block-post .image-card__description {
  margin-top: 1rem !important;
}
#pricing-packages .package-filter__load-more-wrapper {
  text-align: center;
  margin-top: 2rem;
}
@media (max-width: 1023px) and (min-width: 767px) {
  #pricing-packages ul.is-layout-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 767px) {
  #pricing-packages .package-filter__buttons {
    flex-wrap: wrap !important;
  }
}