/*
Theme Name: Twenty Twenty-Four - Child Theme
Theme URI: https://wordpress.org/themes/twentytwentyfour/
Author: the WordPress team
Author URI: https://wordpress.org
Description: Twenty Twenty-Four is designed to be flexible, versatile and applicable to any website. Its collection of templates and patterns tailor to different needs, such as presenting a business, blogging and writing or showcasing work. A multitude of possibilities open up with just a few adjustments to color and typography. Twenty Twenty-Four comes with style variations and full page designs to help speed up the site building process, is fully compatible with the site editor, and takes advantage of new design tools introduced in WordPress 6.4.
Requires at least: 6.4
Tested up to: 6.4
Requires PHP: 7.0
Version: 1.0.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: twentytwentyfour-childtheme
Tags: one-column, custom-colors, custom-menu, custom-logo, editor-style, featured-images, full-site-editing, block-patterns, rtl-language-support, sticky-post, threaded-comments, translation-ready, wide-blocks, block-styles, style-variations, accessibility-ready, blog, portfolio, news
*/

* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
#wpadminbar {
  background:#1d2327 !important;
}

/* Sticky Header Nav Scroll-To Padding */
html {
  scroll-padding-top: clamp(80px, -3.55vw + 127.215px, 100px);
}

/*---------------------------------------*/
/*---------- Global Max Widths ----------*/
/*Pixel Base */
.max-width-1400 {
  max-width: 1400px;
}
.max-width-1350 {
  max-width: 1350px;
}
.max-width-1300 {
  max-width: 1300px;
}
.max-width-1250 {
  max-width: 1250px;
}
.max-width-1200 {
  max-width: 1200px;
}
.max-width-1150 {
  max-width: 1150px;
}
.max-width-1100 {
  max-width: 1100px;
}
.max-width-1050 {
  max-width: 1050px;
}
.max-width-1000 {
  max-width: 1000px;
}
.max-width-950 {
  max-width: 950px;
}
.max-width-900 {
  max-width: 900px;
}
.max-width-850 {
  max-width: 850px;
}
.max-width-800 {
  max-width: 800px;
}
.max-width-765 {
  max-width: 765px;
}
.max-width-750 {
  max-width: 750px;
}
.max-width-700 {
  max-width: 700px;
}
.max-width-650 {
  max-width: 650px;
}
.max-width-600 {
  max-width: 600px;
}
.max-width-550 {
  max-width: 550px;
}
.max-width-500 {
  max-width: 500px;
}
.max-width-450 {
  max-width: 450px;
}
.max-width-400 {
  max-width: 400px;
}
.max-width-150 {
  max-width: 150px;
}
/* Percentage Base */
.max-width-95-percent {
  width: 95%;
}
.max-width-90-percent {
  width: 90%;
}
.max-width-85-percent {
  width: 85%;
}
.max-width-80-percent {
  width: 80%;
}
.max-width-75-percent {
  width: 75%;
}
.max-width-70-percent {
  width: 70%;
}
.max-width-65-percent {
  width: 65%;
}
.max-width-60-percent {
  width: 60%;
}
.max-width-55-percent {
  width: 55%;
}
.max-width-50-percent {
  width: 50%;
}
/* Fit Content */
.fit-content {
  width: fit-content;
}
/* 100% Width */
.width-100 {
  width: 100%;
}


/*---------------------------------------*/
/*---------- Global Max Height ----------*/
.height-100-percent {
  height: 100%;
}
.height-fit-content {
  height: fit-content;
}


/*---------------------------------------*/
/*---------- Global GAP Styles ----------*/
@media (min-width: 768px) and (max-width: 1024px) {
  .tablet-gap-80 {
    gap: 80px;
  }
  .tablet-gap-70 {
    gap: 70px;
  }
  .tablet-gap-60 {
    gap: 60px;
  }
  .tablet-gap-50 {
    gap: 50px;
  }
  .tablet-gap-40 {
    gap: 40px;
  }
  .tablet-gap-30 {
    gap: 30px;
  }
  .tablet-gap-20 {
    gap: 20px;
  }
  .tablet-gap-10 {
    gap: 10px;
  }
  .tablet-gap-5 {
    gap: 5px;
  }
}
@media (max-width: 767px) {
  .mobile-gap-80 {
    gap: 80px;
  }
  .mobile-gap-70 {
    gap: 70px;
  }
  .mobile-gap-60 {
    gap: 60px;
  }
  .mobile-gap-50 {
    gap: 50px;
  }
  .mobile-gap-40 {
    gap: 40px;
  }
  .mobile-gap-30 {
    gap: 30px;
  }
  .mobile-gap-20 {
    gap: 20px;
  }
  .mobile-gap-10 {
    gap: 10px;
  }
  .mobile-gap-5 {
    gap: 5px;
  }
}


/*------------------------------------------*/
/*---------- Global Border Radius ----------*/
.border-radius-8 {
  border-radius: 8px;
}
.border-radius-12 {
  border-radius: 12px;
}
.border-radius-40 {
  border-radius: 40px;
}
@media (max-width: 767px) {
  .border-radius-mobile-20 {
    border-radius: 20px !important;
  }
}


/*----------------------------------------*/
/*---------- Responsive Classes ----------*/
.justify-center {
  justify-content: center;
}
.space-between {
	justify-content: space-between;
}
@media (max-width: 1024px) {
  .stack-on-tablet {
    flex-direction: column;
  }
  .left-align-tablet {
    align-items: flex-start;
  }
}
@media (min-width: 768px) {
  .mobile-only {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .desktop-only {
    display: none !important;
  }
  body .column-reverse-mobile {
    flex-wrap: wrap-reverse !important;
  }
  .stack-on-mobile {
    flex-direction: column;
  }
  .left-align-mobile {
    align-items: flex-start;
  }
}


/*----------------------------------------*/
/*---------- Typography Classes ----------*/
h3.small {
  font-size: clamp(20px, 13.136px + 0.893vw, 26px);
  line-height: 1.2em;
}
.preheader, .preheader-small {
  font-family: 'DIN Pro', sans-serif;
  font-size: var(--wp--preset--font-size--preheader);
  line-height: 1.4em;
  letter-spacing: .11em;
}
.preheader-small {
  font-weight: 100;
}


/*----------------------------------*/
/*---------- Link Classes ----------*/
a:focus, a:active {
  outline: 0 !important;
}
.no-underline, .no-underline a {
  text-decoration: none !important;
}
.no-underline:hover, .no-underline:hover a {
  text-decoration: underline !important;
  cursor: pointer;
}
.semi-bold-link a {
  font-weight: 600;
}
body.single-post p a {
  word-wrap: break-word;
}

li.backslash-link a::before {
  content: "\005C";
  margin-right: 10px;
}
li.backslash-link a {
  text-decoration: none;
}

/*-------------------------------------------*/
/*---------- Button Styles/Classes ----------*/
/* Hover States */
.wp-block-button a {
  transition: all 0.2s;
}
.wp-block-button a.has-background.has-contrast-background-color:hover {
  background: color-mix(in srgb, var(--wp--preset--color--contrast) 80%, transparent) !important;
}
.wp-block-button.is-style-outline a:not(.has-border-color):hover {
  color: var(--wp--preset--color--base-2) !important;
  background: color-mix(in srgb, var(--wp--preset--color--contrast) 80%, transparent);
}
.wp-block-button a.has-border-color.has-accent-4-border-color:hover {
  color: var(--wp--preset--color--base-2) !important;
  background: color-mix(in srgb, var(--wp--preset--color--accent-4) 80%, transparent);
}

/* Approach Button Styles */
.approach-button a {
  display: flex;
  flex-flow: row;
  justify-content: center;
  align-items: center;
  gap: 10px;
  transition: all 0.3s;
}
.approach-button a:hover {
  text-decoration: underline;
}
.approach-button a::before {
  content: '';
  display: inline-block;
  aspect-ratio: 1;
  width: 2em;
  background: url('/wp-content/uploads/2024/09/play-button.svg');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  transition: all 0.3s;
}
.approach-button a:hover::before {
  opacity: 0.7;
}

/* Slash Button */
.wp-block-button.slash-button a {
  display: flex;
  flex-flow: row;
  gap: 0.5em;
  transition: all 0.3s;
}
.wp-block-button.slash-button a:hover {
  transform: translatex(3px);
}
.wp-block-button.slash-button a::before {
  content: '\\';
  transition: all 0.3s;
}
.wp-block-button.slash-button a:hover::before {
  transform: translatex(-3px);
}
/* Utility Classes */
.wp-block-button.button-no-padding a {
  padding: 0;
}
.wp-block-button.button-no-bg a {
  background-color: transparent;
}

/* Check Status Button */
.check-status-btn a::before {
  content: '';
  background: url(/wp-content/uploads/2024/10/check-status.svg);
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
  aspect-ratio: 1;
  width: 28px;
  margin-right: 5px;
}
.check-status-btn a {
  display: flex;
  line-height: 1.4em;  
  padding: 8px 15px 6px;
}

/* Override the mobile full width button styles */
.button-width-auto, .stacked-button-width-auto > .wp-block-button {
  width: auto !important;
}

@media (max-width: 767px ) {
  .wp-block-buttons, .wp-block-buttons .wp-block-button, .wp-block-buttons .wp-block-button a {
    width: 100%;
  }
  .wp-block-buttons .wp-block-button a {
    text-align: center;
  }
}

/*------------------------------------*/
/*---------- Search Styles ----------*/
.jet-smart-filters-search .jet-search-filter__input-wrapper{
  border: solid 1px #1E1B1D;
  border-radius: 40px;
  padding: 12px 20px;
  max-width: 250px;
  margin: auto;
  display: flex;
 }
 .jet-smart-filters-search .jet-search-filter__input {
  background: transparent;
  font-size: 1.1em;
  line-height: 1em;
  border: none;
  padding: 5px;
 }
 .jet-search-filter__input-wrapper::before {
  content: '';
  background: url(/wp-content/uploads/2024/10/search-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  aspect-ratio: 1;
  display: inline-block;
  width: 20px;  
  margin: 7px 6px 2px 0px;
}
.jet-smart-filters-search .jet-search-filter__input-clear {
  right: 10px !important;
}

.wp-block-search__input {
  padding: 0 20px !important;
}

/*------------------------------------*/
/*---------- Filter Styles ----------*/
input:focus, select:focus {
  outline: none;
}
.jet-checkboxes-list__decorator {
  display: none;
}
.jet-checkboxes-list__button{
  border: 1px solid var(--wp--preset--color--contrast-2) !important;
  padding: 4px 15px;
  border-radius: 50px;
  width: auto;
 }
 .active .jet-checkboxes-list__button {
  background-color: var(--wp--preset--color--contrast-2);
  color: var(--wp--preset--color--contrast);
 }
 .jet-checkboxes-list__row {
  display: inline-block;
 }

.jet-select__control {
  background: none;
  border: none;
  padding: 0px;
  font-size: 1em;
  line-height: 28px;
  color: var(--wp--preset--color--contrast);
  -moz-appearance: none;
  -webkit-appearance: none;
} 
.jet-select {
  background: var(--wp--preset--color--base-2);
  padding: 4px 20px;
  border-radius: 50px;
  font-size: 1em;
  line-height: 25px;
  display: inline-flex;
} 
.jet-smart-filters-select {
  margin-top: 0px !important;
  color: var(--wp--preset--color--contrast);
}
.jet-select::after {
  content: '';
  background: url(/wp-content/uploads/2024/10/filter-icon.svg);
  background-repeat: no-repeat;
  background-size: contain;
  aspect-ratio: 1;
  display: inline-block;
  width: 18px;  
  margin-top: 6px;
}


/*---------------------------------------*/
/*---------- Jet Engine Styles ----------*/
.jet-listing-grid--blocks {
  width: 100%;
}
.jet-listing-grid.jet-listing .jet-listing-grid__items {
  margin: -10px;
  row-gap: 20px;
}


/*---------------------------------*/
/*---------- Card Styles ----------*/
.post-type-bubble {
  padding: 5px 12px !important;
  border-radius: 999px;
  text-align: left;
  width: fit-content !important;
}

.related-solution-bubble {
  width: fit-content !important;
  padding: 0;
  text-align: left;
  background-color: transparent !important;
  border-radius: 999px;
}
.related-solution-bubble a {
  padding: 5px 12px  !important;
  border-radius: 999px;
  background-color: var(--wp--preset--color--accent-4);
  text-decoration: none;
  text-align: left;
  transition: all 0.3s;
}
.related-solution-bubble a:hover {
  background-color: color-mix(in srgb, var(--wp--preset--color--accent-4) 90%, transparent);
}

.card * {
  text-align: left !important;
}
.card .title a {
  transition: all 0.2s;
}
.card .title a:hover {
  opacity: 0.7;
}
.card {
  border-radius: 40px;  
}
.card.purple {
  border: 2px solid var(--wp--preset--color--accent-4);
}
@media (max-width: 767px) {
  .card {
    border-radius: 20px !important;
  }
  .card .content-container {
    padding: 15px 10px !important;
  }
}

/* Success Story Card */
.success-story-card .image img {
  max-height: 70px;
  width: auto;
}

/* Team */
.team-member-card .image img {
  aspect-ratio: 1;
  height: auto;
  width: 100%;
  max-width: 275px;
  border-radius: 12px;
}
.team-member-card .role {
  font-size: clamp(14px, 9.44px + 0.594vw, 18px);
}

/* Resource */
.resource-card div.is-vertical {
  flex-flow: column nowrap;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
}
.resource-card > div.is-vertical {
  gap: var(--wp--preset--spacing--30);
  height: 100%;
}
.resource-card > div.is-vertical > div.is-vertical {
  gap: var(--wp--preset--spacing--10);
}
@media (max-width: 767px) {
  .resource-card .content-container {
    border-radius: 18px !important;
  }
}


/* Partner Page */
@media (max-width: 920px) {
  .grid-4-2 {
    grid-template-columns: repeat(2, minmax(0, 2fr))
  }
  .no-border-mobile {
    border: none;
  }
}

/* Solutions Cards */
@media (min-width: 450px) and (max-width: 674px) {
  .grid-4-3-2 {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* Solutions Single Template Cards */
body.single-solutions .grid-4-3-2 {
  grid-template-columns: 1fr 1fr 1fr 1fr !important;
}
@media (max-width: 1024px) {
  body.single-solutions .grid-4-3-2 {
    grid-template-columns: 1fr 1fr !important;
  }
}
@media (max-width: 450px) {
  body.single-solutions .grid-4-3-2 {
    grid-template-columns: 1fr !important;
  }
}

/* Image Outline Card */
.image-outline-card {
  padding: 8px;
  border-radius: 30px;
  border: 1px solid var(--wp--preset--color--accent-4) !important;
}
.image-outline-card img {
  border-radius: 23px;
}


/*----------------------------------------------------*/
/*---------- Video Image Placeholder Styles ----------*/
.video-image-placeholder {
  position: relative;
  cursor: pointer;
  z-index: 0;
}
.video-image-placeholder::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background: rgba(0,0,0,0);
  border-radius: 40px;
  z-index: 1;
  transition: all 0.3s;
}
.video-image-placeholder .play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  aspect-ratio: 1;
  width: 100px;
  transform: translate(-50%, -50%);
  cursor: pointer;
  opacity: 0.9;
  z-index: 2;
  transition: all 0.6s;
}
.video-image-placeholder:hover::after {
  background: rgba(0,0,0,0.5);
}
.video-image-placeholder:hover .play-button {
  opacity: 0.9;
}
@media (max-width: 767px) {
  .video-image-placeholder img {
    border-radius: 20px !important;
  }
  .video-image-placeholder::after {
    background: rgba(0,0,0,0.4);
  }
  .video-image-placeholder .play-button {
    opacity: 0.9;
    width: 50px;
  }
}

/* Video Modal */
.video-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.video-modal-content {
  position: relative;
  width: 90vw;
  max-width: 800px;
  height: 45vw;
  max-height: 450px;
}

.video-modal-content iframe {
  width: 100%;
  height: 100%;
}

/* Close button */
.video-close-button {
  position: absolute;
  top: -35px;
  right: -35px;
  aspect-ratio: 1;
  width: 40px;
  background: none;
  border: none;
  cursor: pointer;
}
.video-close-button svg path {
  stroke: var(--wp--preset--color--base);
}



/*------------------------------------*/
/*---------- Section Styles ----------*/
/* Main Section Border Radius and Adjustments */
body main > div > section {
    margin-bottom: clamp(-60px, calc(-4.255vw + 1.275px), -20px) !important;
}
body main > div > section {
  border-bottom-left-radius: clamp(20px,  -1.275px + 4.255vw, 60px);
  border-bottom-right-radius: clamp(20px,  -1.275px + 4.255vw, 60px);
}

body main > div > section { position: relative; }
body main > div > section:nth-of-type(1) { z-index: 20; }
body main > div > section:nth-of-type(2) { z-index: 19; }
body main > div > section:nth-of-type(3) { z-index: 18; }
body main > div > section:nth-of-type(4) { z-index: 17; }
body main > div > section:nth-of-type(5) { z-index: 16; }
body main > div > section:nth-of-type(6) { z-index: 15; }
body main > div > section:nth-of-type(7) { z-index: 14; }
body main > div > section:nth-of-type(8) { z-index: 13; }
body main > div > section:nth-of-type(9) { z-index: 12; }
body main > div > section:nth-of-type(10) { z-index: 11; }
body main > div > section:nth-of-type(11) { z-index: 10; }
body main > div > section:nth-of-type(12) { z-index: 9; }
body main > div > section:nth-of-type(13) { z-index: 8; }
body main > div > section:nth-of-type(14) { z-index: 7; }
body main > div > section:nth-of-type(15) { z-index: 6; }
body main > div > section:nth-of-type(16) { z-index: 5; }
body main > div > section:nth-of-type(17) { z-index: 4; }
body main > div > section:nth-of-type(18) { z-index: 3; }
body main > div > section:nth-of-type(19) { z-index: 2; }
body main > div > section:nth-of-type(20) { z-index: 1; }

/* Quote Section */
.quote-container .icon-quote-inner {
  background-size: auto 70% !important;
  background-position: bottom left !important;
}
.quote-cite-inner p {
  margin-block-start: 0px;
  margin-block-end: 0px;
}

/* Slash BG Sections */
.slash-bg {
  background-size: auto 70% !important;
  background-position: bottom left !important;
}
.form-slash-bg::before{
  content: '';
  aspect-ratio: 1;
  width: 300px;
  position: absolute;
  left: -150px;
  top: -400px;
  z-index: -1;
  background: url('/wp-content/uploads/2024/09/slash-purple.svg');
}


/* Trusted Partner Section */
.trusted-partners-image-row .partner-image {
  width: 45%;
}
.trusted-partners-image-row .partner-image img {
  position: relative;
  max-height: 120px;
  width: auto;
}
.trusted-partners-image-row .partner-image:nth-child(3) {
  width: 100%;
  text-align: center;
}
.trusted-partners-image-row .partner-image:nth-child(3) img {
  max-height: 100px;
}
.trusted-partners-image-row .partner-image:nth-child(4) img {
  max-height: 90px;
}
@media (max-width: 767px) {
  .trusted-partners-image-row {
    max-width: 450px;
  }
}
/* Sticky Side Bar */
@media (min-width: 768px) {
  .side-bar-column {
    position: relative; /* Ensures the fixed position is relative to this container */
  }
  .side-bar-content {
    position: sticky; /* Makes the content "stick" at a specified offset */
    top: 90px; /* Adds 20px padding from the top when scrolled */
  }
}

/*--------------------------------------------*/
/*---------- Banner Gradient Styles ----------*/
.banner-graphic {
  background-position: top right;
  background-repeat: no-repeat;
  background-size: auto;
}
.banner-graphic.purple-homepage {
  background-image: url(/wp-content/uploads/2024/10/purple-banner-graphic-gradient.svg);
}
.banner-graphic.purple {
  background-image: linear-gradient(to bottom, rgba(255, 0, 0, 0), rgb(229 227 212)), url(/wp-content/uploads/2024/11/purple-banner-graphic.svg);
}
.banner-graphic.green {
  background-image: linear-gradient(to bottom, rgba(255, 0, 0, 0), rgb(229 227 212)), url(/wp-content/uploads/2024/11/green-banner-graphic.svg);
}
@media (max-width: 2500px) {
  .banner-graphic {
    background-size: auto 90%;
  }
}
@media (max-width: 1600px) {
  .banner-graphic {
    background-size: auto 80%;
  }
}
@media (max-width: 1024px) {
  .banner-graphic {
    background-size: auto 70%;
  }
}
@media (max-width: 767px) {
  .banner-graphic {
    background-size: auto 80%;
    background-position: 60vw 0%;
  }
}

/*---------------------------------------*/
/*---------- Utility Classes ------------*/
.no-wrap-text {
  text-wrap: nowrap;
  white-space: nowrap;
}
.z-index-50 {
  z-index: 50;
}
/* Prevent scrolling */
.no-scroll {
  overflow: hidden;
}
header .wp-block-buttons, header .wp-block-buttons .wp-block-button, header .wp-block-buttons .wp-block-button a {
  /* width: auto; */
}

/*-----------------------------------*/
/*---------- Header Styles ----------*/

/* Z-Index for Header Sections */
header .top-bar-container {
  z-index: 998 !important;
}
header .nav-container {
  z-index: 999 !important;
}
/* Sticky Nav */
header .nav-container.sticky {
  position: fixed;
  top: 0;
  width: 100%;
  box-shadow: 0px 0px 15px -4px rgba(0, 0, 0, 0.25);
  z-index: 1000;
}

header *:focus, header *:active {
  outline: 0 !important;
}
body > .wp-site-blocks > header {
  position: relative;
  z-index: 999;
}
header nav .wp-block-navigation__responsive-container-content {
  align-items: center !important;
}
header nav .wp-block-navigation__responsive-container-content > ul > li {
  padding: 3px 8px;
  border-radius: 5px;
  transition: all 0.3s;
}
header nav .wp-block-navigation__responsive-container-content > ul > li:hover {
  background-color: color-mix(in srgb, var(--wp--preset--color--base-2) 40%, transparent);
}
header nav .wp-block-navigation__responsive-container-content > ul > li .wp-block-navigation__submenu-icon.wp-block-navigation-submenu__toggle {
  background-color: transparent;
}
header nav .wp-block-navigation__responsive-container-content > ul > li > a {
  text-decoration: none !important;
}
header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li a {
  position: relative;
  text-decoration: none !important;
  transition: all 0.3s;
}
header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li a span {
  transition: all 0.3s;
}
header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li a:hover span {
  transform: translatex(3px);
}
header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li a::before {
  content: "\005C";
  margin-right: 10px;
}

/* Active Links */
header nav .wp-block-navigation__responsive-container-content a.current-menu-item {
  color: var(--wp--preset--color--accent-5) !important;
}

header nav .menu-slash-spacer {
  height: auto !important;
  width: auto !important;
  flex-basis: unset;
}
header nav .menu-slash-spacer::after{
  content: "\005C";
}
@media (min-width: 931px) {
  header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu {
    min-width: 375px !important;
    padding-top: 25px;
    border: 0;
    background-color: transparent;
  }
  header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li {
    background-color:  var(--wp--preset--color--base);
    border-left: 1px solid var(--wp--preset--color--contrast);
    border-right: 1px solid var(--wp--preset--color--contrast);
    overflow: hidden !important;
  }
  header nav .wp-block-navigation__responsive-container-content > ul > li.resources > ul {
    left: unset !important;
    right: -1px !important;
  }
  header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li:first-child {
    padding-top: 12px;
    border-top: 1px solid var(--wp--preset--color--contrast);
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
  }
  header nav .wp-block-navigation__responsive-container-content > ul > li > ul.wp-block-navigation__submenu-container.wp-block-navigation-submenu > li:last-child {
    padding-bottom: 12px;
    border-bottom: 1px solid var(--wp--preset--color--contrast);
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
  }
}
@media screen and (max-width: 930px) {
  .nav-container > .nav-row {
    justify-content: flex-end;
    gap: 20px;
  }
  .nav-container > .nav-row .site-logo-group {
    flex-grow: 1;
  }
  header .main-nav {
    order: 3;
  }
  /* hamburger button */
  .wp-block-navigation__responsive-container-open  {
    display: block !important;
  }
  /* full menu */
  .wp-block-navigation__responsive-container:not(.is-menu-open.has-modal-open) {
    display: none !important;
  } 
}

@media (max-width: 500px) {
  header .custom-logo {
    max-width: 115px;
  }
  header .contact-button {
    display: none;
  }
}
@media (max-width: 360px) {
  header .contact-button {
    display: none;
  }
}


/* Mobile Menu */
nav .wp-block-navigation__responsive-container button,
nav .wp-block-navigation__responsive-container.is-menu-open button {
  cursor: pointer !important;
}

html.has-modal-open .top-bar {
  /* display: none !important; */
}

html.has-modal-open header, html.has-modal-open header div.nav-container {
  height: 100vh;
}
header nav > .wp-block-navigation__responsive-container.has-modal-open {
  height: var(--nav-height);
  bottom: unset !important;
  z-index: 999;
}
html.has-modal-open {
  position: fixed;
  width: 100%;
  overflow-y: scroll;
}
header .wp-block-navigation__responsive-container.is-menu-open {
  align-items: flex-start !important;
  background-color: var(--wp--preset--color--base-2) !important;
  background-image: url(/wp-content/uploads/2024/10/purple-banner-graphic-gradient-opacity.svg);
  background-position: top right;
  background-repeat: no-repeat;
  animation: fadeIn 3s ease-in-out;
  -webkit-animation: fadeIn .3s ease-in-out; /* For Safari */
}
.wp-block-navigation__responsive-container-close {
  top: 15px;
  right: 15px;
}
.wp-block-navigation__responsive-container-close svg {
  height: 40px !important;
  width: 40px !important;
}
header .wp-block-navigation__responsive-container.is-menu-open li {
  align-items: flex-start !important;
  border: 0 !important;
}
header .wp-block-navigation__responsive-container.is-menu-open li:after {
  display: none !important;
}
header .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-dialog {
  display: flex;
  justify-content: center;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content {
  align-items: flex-start !important;
  padding: 40px;
  width: fit-content;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul {
  align-items: flex-start !important;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li {
  gap: 15px;
  border: 0 !important;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li > a {
  font-family: 'DIN Pro';
  font-size: 24px;
  font-weight: 600;
  transition: all 0.3s;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li > a:hover {
  opacity: 0.8;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li > ul {
  padding: 0px 0px 0px 5px !important;
  gap: 10px !important;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li > ul > li a {
  font-size: 18px;
}

header .wp-block-navigation__responsive-container.is-menu-open .menu-slash-spacer {
  display: none !important;
}

header .wp-block-navigation__responsive-container  .wp-block-navigation__responsive-container-content > ul > li.contact-us {
  display: none;
  padding: 0 !important;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li.contact-us {
  width: 100%;
  display: flex;
}
header .wp-block-navigation__responsive-container  .wp-block-navigation__responsive-container-content > ul > li.contact-us a {
  width: 100%;
  padding: 8px 30px !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  text-align: center;
  background-color: var(--wp--preset--color--contrast-2) !important;
  border-radius: 999px;
  transition: all 0.3s;
}
header .wp-block-navigation__responsive-container.is-menu-open  .wp-block-navigation__responsive-container-content > ul > li.contact-us a:hover {
  background-color: color-mix(in srgb, var(--wp--preset--color--contrast-2) 80%, transparent) !important;
}

/* Animation */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fadeIn { /* For Safari */
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}


/*-----------------------------------*/
/*---------- Footer Styles ----------*/
footer h2.wp-block-heading {
  font-size: clamp(30px, -8.352px + 3.913vw, 48px) !important;
}
footer .nav-social .wp-block-social-links {
  display: none;
}
@media (max-width: 980px) {
  footer .main-content {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    row-gap: 30px;
  }
  .contact-row {
    width: 100%;
  }
  .contact-row .wp-block-buttons {
    flex-direction: column;
    align-items: flex-start;
  }
  .contact-row .wp-block-buttons .wp-block-button a {
    max-width: 100%;
    width: 300px;
  }
  .contact-row .wp-block-social-links {
    display: none;
  }
  footer .nav-social .wp-block-social-links {
    display: flex;
  }
  footer .logo img {
    width: 150px !important;
  }
  footer .copyright-row {
    flex-direction: column;
    align-items: flex-start;
  }
  footer .copyright-row .bar {
    display: none;
  }
}


/*------------------------------------------*/
/*-------------- FORM STYLES ---------------*/
.gform-body input, .gform-body textarea {
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
}
.gform_fields {
  row-gap: 15px !important;
}
.gform_required_legend {
  display: none;
}
.gform_footer input.gform_button {
  width: 100% !important;
  border-radius: 55px !important;
  font-size: var(--wp--preset--font-size--small) !important;
  padding: 15px 20px !important;
  background-color: var(--wp--preset--color--contrast-2) !important;
  color: var(--wp--preset--color--contrast) !important;
}
.gform_footer input.gform_button:hover {
  background: color-mix(in srgb, #8DA000 80%, transparent) !important;
}
.gform-body .gform-field-label>.gfield_required {
  color: var(--wp--preset--color--contrast); 
  font-size: var(--wp--preset--font-size--small) !important;
}
.gform-body .gform-field-label {
  gap: 2px;
  font-size: var(--wp--preset--font-size--small) !important;
}
.gform-body select {
  border: none;
  border-radius: 0;
  box-shadow: none;
}


/* Hubspot Form */
.hbspt-form {
	display: flex;
	flex-flow: column nowrap;
}
.hbspt-form fieldset {
  width: 100% !important;
  max-width: unset !important;
}
.hs-form, .hs-dependent-field {
	display: flex;
	flex-flow: column nowrap;
	gap: 20px;
}
.hbspt-form .hs-form-field {
	display: flex;
	flex-flow: column nowrap;
	gap: 8px;
}
.hbspt-form label, .hbspt-form label span {
	display: flex;
	color: var(--wp--preset--color--contrast) !important;
	font-size: var(--wp--preset--font-size--small) !important;
	gap: 5px;
}
.hbspt-form ::marker {
	color: var(--wp--preset--color--contrast) !important;
}
.hbspt-form input, .hbspt-form textarea, .hbspt-form select {
	padding: 8px 12px;
	width: 100% !important;
	box-sizing: border-box;
	-webkit-box-sizing:border-box;
	-moz-box-sizing: border-box;
	font-size: 16px;
	font-family: 'Helvetica Neue', sans-serif;
	line-height: 1.5em;
	outline: 0;
	border: 0;
}
.hbspt-form textarea {
	min-height: 125px;
}
.hbspt-form .hs-submit input {
	width: 100%;
	padding: 12px 20px;
  font-size: 18px;
  font-family: 'Helvetica Neue', serif;
  font-weight: 400;
  background-color: var(--wp--preset--color--contrast-2);
	cursor: pointer;
  border-radius: 999px;
	transition: all 0.3s;
}
.hbspt-form .hs-error-msgs {
	display: flex;
	margin: 0;
	flex-flow: column nowrap;
	gap: 10px;
}
.hbspt-form .hs-error-msgs label {
	font-size: 14px !important;
	font-style: italic;
}

.hbspt-form .hs-submit input:hover {
	background-color: color-mix(in srgb, var(--wp--preset--color--contrast-2) 80%, transparent);
}

.hbspt-form .submitted-message {
  color: var(--wp--preset--color--contrast);
  font-size: 20px;
}

/* Landing Page Hubspot Form */
@media (min-width: 768px) {
    .lphs-form {
    position: absolute;
    width: calc(40% - var(--wp--preset--spacing--global-horizontal-padding));
    max-width: 570px;
  }
}

/*------------------------------------------*/
/*---------- PAGE SPECIFIC STYLES ----------*/

/* Home Page */
.home-banner .video-container {
  margin-bottom: clamp(-385px, calc(-27.8947vw - 22.37px), -120px);
}
.scaleable-solutions-section {
  padding-top: clamp(130px, 21.312px + 31.053vw, 425px) !important;
}

/* About Page */
.values-grid .role {
  font-size: clamp(14px, 9.44px + 0.594vw, 18px);
}
@media (max-width: 767px) {
  .values-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

/* Partner Page */
@media (min-width: 768px) {
  .bleed-image-right {
    margin-top: -500px !important;
    align-content: center;
  }
  .bleed-image-right div{
    position: absolute;
    right: 0;
    width: 40vw;
    max-width: 700px;
  }
  .bleed-image-right img {
    max-width: 700px;
  }
}
@media (max-width: 767px) {
  .bleed-image-right div{
    margin-right: -20px;
  }
}

/* Resources Page */

.resources-filter-row .jet-select {
  min-width: 150px;
}

@media (max-width: 767px) {
  .resources-filter-row {
    flex-direction: column-reverse;
    align-items: center;
    gap: 15px;
  }
  .resources-filter-row fieldset {
    text-align: center;
  }
  .jet-checkboxes-list .jet-checkboxes-list__label {
    font-size: 14px;
  }
}

@media (min-width: 576px) {
  .resources-filter-row .jet-smart-filters-select:nth-of-type(1) {
    display: none !important;
  }
}
@media (max-width: 575px) {
  .resources-filter-row .jet-smart-filters-checkboxes {
    display: none !important;
  }
  .resources-filter-row .select-group {
    justify-content: center;
  }
  .resources-filter-row .jet-filter {
    display: flex;
    width: 100%;
    max-width: 400px;
  }
  .resources-filter-row .jet-filter:nth-of-type(2) {
    width: calc(100% - 30px);
    max-width: 350px;
  }
  .resources-filter-row .jet-select {
    min-width: unset;
    width: 100%;
  }
}

/* Success Story Singles */
@media (max-width: 400px) {
  .success-story-banner .wp-block-button {
    width: 100% !important;
  }
}
