/*! 
Theme Name: Boilerplate Starter
Author: 1p21

--------------

for future friendly editing and to avoid possibility of change overrides, DO:
- For smaller and or quick fixes, put css changes in post-live.css 
OR
- For complex and or elaborate rebuilds/ Site build, modify sass files locally with a compiler and output as the style.css
*/
/* ================================================================================
* Resets.css
================================================================================ */
/***
    The new CSS reset - version 1.8.3 (last updated 21.1.2023)
    GitHub page: https://github.com/elad2412/the-new-css-reset
***/
/*
    Remove all the styles of the "User-Agent-Stylesheet", except for the 'display' property
    - The "symbol *" part is to solve Firefox SVG sprite bug
 */
/*
    Remove all the styles of the "User-Agent-Stylesheet", except for the 'display' property
    - The "symbol *" part is to solve Firefox SVG sprite bug
 */
*:where(:not(html,
iframe, canvas,
img, svg, video, audio,
input, textarea, select, button,
table, caption, tbody, tfoot, thead, tr, th, td):not(svg *, symbol *)) {
  all: unset;
  display: revert;
}

/* Reset form elements while keeping essential ui styles */
:where(input, textarea, select, option, button, optgroup) {
  all: revert;
  margin: unset;
  -webkit-appearance: auto;
     -moz-appearance: auto;
          appearance: auto;
}

/* resets table styles nicely so html attribute features are still preserved */
:where(table, caption, tbody, tfoot, thead, tr, th, td) {
  margin: unset;
  padding: unset;
  border: unset;
  background: unset;
  border-collapse: collapse;
  border-spacing: 0;
}

/* Reapply the pointer cursor for anchor tags */
a, button {
  cursor: revert;
}

/* Remove list styles (bullets/numbers) */
ol, ul, menu {
  list-style: none;
}

/* For images to not be able to exceed their container */
img {
  max-inline-size: 100%;
  max-block-size: 100%;
}

/* Safari - solving issue when using user-select:none on the <body> text input doesn't working */
input, textarea {
  -webkit-user-select: auto;
}

/* revert the 'white-space' property for textarea elements on Safari */
textarea {
  white-space: revert;
}

/* minimum style to allow to style meter element */
meter {
  -webkit-appearance: revert;
  -moz-appearance: revert;
       appearance: revert;
}

/* preformatted text - use only for this feature */
:where(pre) {
  all: revert;
}

/* reset default text opacity of input placeholder */
::-moz-placeholder {
  color: unset;
}
::placeholder {
  color: unset;
}

/* remove default dot (•) sign */
::marker {
  content: initial;
}

/* fix the feature of 'hidden' attribute.
   display:revert; revert to element instead of attribute */
:where([hidden]) {
  display: none;
}

/* revert for bug in Chromium browsers
   - fix for the content editable attribute will work properly.
   - webkit-user-select: auto; added for Safari in case of using user-select:none on wrapper element*/
:where([contenteditable]:not([contenteditable=false])) {
  -moz-user-modify: read-write;
  -webkit-user-modify: read-write;
  overflow-wrap: break-word;
  -webkit-line-break: after-white-space;
  -webkit-user-select: auto;
}

/* apply back the draggable feature - exist only in Chromium and Safari */
:where([draggable=true]) {
  -webkit-user-drag: element;
}

/* Revert Modal native behavior */
:where(dialog:modal) {
  all: revert;
}

/* Preferred box-sizing value */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* ================================================================================
* Native Custom CSS Properties
================================================================================ */
/* css vars because internet explorer can no longer hold us back <3 */
:root {
  /* Core Vars DO NOT EDIT. */
  /* Design Reference - Breakpoints This will be used by javascript to track media queries on stuff like sliders */
  --br-xxs: 22.4375rem;
  --br-xs: 47.9375rem;
  --br-sm: 74.9375rem;
  --br-md: 87.4375rem;
  --br-lg: 119.9375rem;
  --br-xl: 179.9375rem;
  --br-xxl: 239rem;
  /* Design Reference: Comps/Design Sizes based on given XD Files' artboards */
  --comp: 22.5rem;
  /* unit in case for padding to push to negative margins (ie overlaps). Best to keep as tiny as possible */
  --overlap-buffer: 1px;
  /* Styleguide - Fonts */
  --font-primary: Funnel Sans, Helvetica, Arial, sans-serif, Primary Fallback;
  --font-secondary: Oleo Script, Times, serif, Secondary Fallback;
  --font-accent: Funnel Display, var(--font-primary), Accent Fallback;
  --font-monospace: monospace;
  /* Styleguide - colors */
  --color-dark: #003543;
  --color-dark-alt: #00485A;
  --color-light: #FFFFFF;
  --color-light-alt: #FFFDFA;
  --color-primary: #FF523E;
  --color-primary-alt: var(--color-primary);
  --color-primary-gradient-start: var(--color-primary);
  --color-primary-gradient-end: var(--color-primary-alt);
  --color-secondary: #FFBD59;
  --color-secondary-alt: var(--color-secondary);
  --color-secondary-gradient-start: var(--color-secondary);
  --color-secondary-gradient-end: var(--color-secondary-alt);
  --color-accent: #298AA4;
  --color-accent-alt: #08C4D0;
  --color-accent-gradient-start: #CECECE;
  --color-accent-gradient-end: var(--color-accent-alt);
  --color-neutral: #9CB3B9;
  --color-neutral-light: #DDEEF0;
  --color-neutral-lighter: #D6E8E9;
  --color-neutral-lightest: rgba(221, 238, 240, 0.4);
  --color-neutral-dark: #457180;
  --color-neutral-darker: var(--color-neutral-dark);
  --color-neutral-darkest: var(--color-neutral-darker);
  --color-success: #00CC00;
  --color-caution: #CC6600;
  --color-error: var(--color-primary);
  /* add more native vars as needed */
  --global-radius: 1.25rem;
  --global-radius-large: 2.5rem;
  --global-radius-small: .5rem;
  --global-radius-micro: .375rem;
  --color-dark-alt-alt: #022630;
  --icon-arrow: url('data:image/svg+xml,<svg width="14" height="14" viewBox="0 0 14 14" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 12.7099L12.7098 1.00008M12.7096 10.0582L12.7098 1.00008L3.65145 1" stroke="%23003543" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>');
  --icon-elesi: url('data:image/svg+xml,<svg width="22" height="22" viewBox="0 0 22 22" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M10.1528 6.65981C10.0846 6.66498 10.0236 6.61743 10.0122 6.55128C9.69901 4.82926 9.07574 3.26228 8.14133 1.85034C8.0328 1.68599 7.94598 1.50614 7.88189 1.31078C7.69791 0.760893 8.00386 0.248213 8.55995 0.140715C10.2344 -0.187979 12.2655 0.0962694 13.8511 0.609983C14.3948 0.784666 14.6811 1.16194 14.709 1.74284C14.8031 3.67469 14.0547 5.559 13.0335 7.14459C12.956 7.26449 12.7978 7.30066 12.6769 7.22728C11.9317 6.77351 11.0903 6.58436 10.1538 6.66085L10.1528 6.65981Z" fill="white"/><path d="M8.39767 7.30066C7.53976 7.68724 6.98057 8.49037 6.60019 9.30384C6.56815 9.37102 6.49063 9.40203 6.42241 9.37722C5.58207 9.06817 4.72106 8.83767 3.8404 8.68676C3.00523 8.54412 1.74524 8.65058 1.00723 8.61647C-0.204187 8.56066 0.0841953 7.36165 0.478008 6.63397C1.07131 5.53626 1.82276 4.50987 2.73029 3.55273C3.00523 3.26331 3.29465 3.02661 3.59853 2.84366C4.04093 2.58008 4.66421 2.83332 5.119 3.15064C6.60536 4.18531 7.70618 5.5466 8.42248 7.23555C8.43282 7.26139 8.42248 7.29033 8.39767 7.3017V7.30066Z" fill="white"/><path d="M14.1684 8.49864C14.1385 8.43972 14.155 8.3684 14.2077 8.32809C15.323 7.48465 16.2274 6.41691 16.921 5.12488C17.1722 4.65871 17.4574 3.91656 17.8037 3.6902C19.3211 2.70308 21.0514 7.30893 21.3284 8.26194C21.4235 8.5865 21.4596 8.85318 21.4369 9.063C21.3863 9.52814 20.7258 9.91575 20.2679 10.1266C18.6461 10.876 16.9272 11.2067 15.109 11.1199C15.0408 11.1158 14.986 11.062 14.9829 10.9949C14.9592 10.5059 14.8806 10.0512 14.7462 9.63046C14.615 9.22011 14.3586 8.87798 14.1684 8.49761V8.49864Z" fill="white"/><path d="M14.2573 11.0248C14.2573 11.1437 14.2511 11.2626 14.2397 11.3804C14.2284 11.4993 14.2108 11.6161 14.187 11.7329C14.1643 11.8497 14.1353 11.9644 14.1012 12.0781C14.0671 12.1918 14.0268 12.3034 13.9813 12.413C13.9359 12.5226 13.8852 12.6301 13.8294 12.7345C13.7736 12.8399 13.7116 12.9412 13.6464 13.0404C13.5803 13.1396 13.51 13.2347 13.4335 13.3267C13.3581 13.4187 13.2785 13.5066 13.1947 13.5913C13.111 13.6761 13.0232 13.7546 12.9312 13.8301C12.8392 13.9056 12.7441 13.9758 12.6449 14.042C12.5467 14.1081 12.4443 14.1691 12.3399 14.2249C12.2355 14.2808 12.128 14.3324 12.0185 14.3769C11.9089 14.4224 11.7962 14.4627 11.6836 14.4968C11.5699 14.5309 11.4541 14.5598 11.3383 14.5836C11.2215 14.6064 11.1037 14.6239 10.9859 14.6363C10.868 14.6477 10.7492 14.6539 10.6303 14.6539C10.5114 14.6539 10.3926 14.6487 10.2747 14.6363C10.1559 14.625 10.0391 14.6074 9.92228 14.5836C9.80548 14.5609 9.69074 14.5309 9.57705 14.4968C9.46335 14.4627 9.35171 14.4224 9.24215 14.3769C9.13259 14.3314 9.02509 14.2808 8.92069 14.2249C8.81629 14.1691 8.71396 14.1081 8.61577 14.042C8.51654 13.9758 8.42145 13.9056 8.32946 13.8301C8.23746 13.7546 8.1496 13.6751 8.06588 13.5913C7.98216 13.5076 7.90257 13.4187 7.82608 13.3267C7.75062 13.2347 7.68034 13.1396 7.61418 13.0404C7.54803 12.9412 7.48705 12.8399 7.43123 12.7345C7.37542 12.6301 7.32477 12.5226 7.27929 12.413C7.23381 12.3034 7.1935 12.1918 7.15939 12.0781C7.12528 11.9644 7.09634 11.8497 7.0736 11.7329C7.04982 11.6161 7.03225 11.4993 7.02088 11.3804C7.00951 11.2615 7.00331 11.1437 7.00331 11.0248C7.00331 10.906 7.00951 10.7871 7.02088 10.6693C7.03225 10.5504 7.04982 10.4336 7.0736 10.3168C7.09634 10.2 7.12528 10.0853 7.15939 9.97156C7.1935 9.85786 7.23381 9.74623 7.27929 9.63667C7.32477 9.5271 7.37542 9.4196 7.43123 9.31521C7.48705 9.20978 7.54907 9.10848 7.61418 9.00925C7.68034 8.91002 7.75062 8.81493 7.82608 8.72294C7.90153 8.63095 7.98216 8.54309 8.06588 8.45833C8.1496 8.37357 8.23746 8.29502 8.32946 8.21956C8.42145 8.1441 8.51654 8.07382 8.61577 8.00767C8.71396 7.94151 8.81629 7.88053 8.92069 7.82471C9.02509 7.7689 9.13259 7.71722 9.24215 7.67277C9.35171 7.62729 9.46438 7.58698 9.57705 7.55287C9.69074 7.51876 9.80651 7.48982 9.92228 7.46604C10.0391 7.4433 10.1569 7.42573 10.2747 7.41333C10.3926 7.40196 10.5114 7.39576 10.6303 7.39576C10.7492 7.39576 10.868 7.40093 10.9859 7.41333C11.1047 7.4247 11.2215 7.44227 11.3383 7.46604C11.4551 7.48878 11.5699 7.51876 11.6836 7.55287C11.7973 7.58698 11.9089 7.62729 12.0185 7.67277C12.128 7.71825 12.2355 7.7689 12.3399 7.82471C12.4443 7.88053 12.5467 7.94151 12.6449 8.00767C12.7441 8.07382 12.8392 8.1441 12.9312 8.21956C13.0232 8.29502 13.111 8.3746 13.1947 8.45833C13.2785 8.54205 13.3581 8.63095 13.4335 8.72294C13.509 8.81493 13.5803 8.91002 13.6464 9.00925C13.7126 9.10848 13.7736 9.20978 13.8294 9.31521C13.8852 9.4196 13.9359 9.5271 13.9813 9.63667C14.0268 9.74623 14.0671 9.85786 14.1012 9.97156C14.1353 10.0853 14.1643 10.2 14.187 10.3168C14.2108 10.4336 14.2284 10.5504 14.2397 10.6693C14.2511 10.7881 14.2573 10.906 14.2573 11.0248Z" fill="white"/><path d="M7.15939 13.7805C6.34902 14.6219 5.40428 15.4405 4.83786 16.4483C4.57325 16.9207 4.26419 17.4902 3.91276 18.1558C3.55926 18.8246 2.6786 18.6044 2.27756 18.1176C1.13643 16.7315 0.389116 15.2214 0.0356148 13.5882C-0.0832526 13.0383 0.0955653 12.597 0.570001 12.2631C2.08323 11.2026 4.4151 10.8388 6.17434 10.9359C6.22395 10.939 6.26323 10.9804 6.2622 11.031C6.24773 11.9809 6.54955 12.8502 7.16559 13.6409C7.19866 13.6823 7.19556 13.7422 7.15835 13.7805H7.15939Z" fill="white"/><path d="M12.9787 14.688C13.7519 14.1423 14.3245 13.5717 14.6315 12.6518C14.6511 12.5928 14.7152 12.5598 14.7741 12.5804C14.7783 12.5815 14.7814 12.5835 14.7855 12.5846C16.3246 13.2792 17.874 13.5593 19.4348 13.427C20.1077 13.3701 20.5314 13.3805 20.7051 13.458C21.5609 13.8425 21.164 14.7469 20.8095 15.4715C20.2751 16.562 19.5443 17.5894 18.6151 18.5569C17.9732 19.2225 17.4326 19.5884 16.5272 18.9972C14.8506 17.9026 13.9173 16.6395 12.9456 14.8276C12.9198 14.779 12.9332 14.719 12.9777 14.688H12.9787Z" fill="white"/><path d="M8.43178 14.8689C8.46589 14.8193 8.53101 14.8027 8.58373 14.8307C9.39616 15.2648 10.2778 15.4188 11.2257 15.2927C11.3053 15.2823 11.3776 15.3382 11.389 15.4178C11.5699 16.6881 11.9999 17.9171 12.6769 19.1037C12.7896 19.3001 13.017 19.6474 13.3581 20.1456C13.57 20.4567 13.6837 20.6934 13.6971 20.8536C13.7436 21.4417 13.2619 21.7549 12.7017 21.8521C11.0148 22.1446 9.32691 22.003 7.64002 21.4293C7.10047 21.2454 6.78314 20.8743 6.76247 20.2562C6.69942 18.3574 7.38472 16.4038 8.43075 14.8699L8.43178 14.8689Z" fill="white"/></svg>');
  --icon-clock: url('data:image/svg+xml,<svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M9.14119 0H10.8528C11.0882 0.107364 11.554 0.106024 11.8187 0.16071C12.2515 0.25015 12.6725 0.342855 13.095 0.476311C15.905 1.39235 18.1694 3.49877 19.2859 6.23533C19.5244 6.8401 19.7045 7.46631 19.8234 8.10543C19.8932 8.48797 19.885 8.75453 20 9.14568V10.8767C19.8801 11.2903 19.9016 11.4892 19.8322 11.8676C19.775 12.1794 19.6385 12.7368 19.5461 13.0404C18.875 15.1697 17.5046 17.01 15.6569 18.263C14.4414 19.0992 13.3155 19.5701 11.8779 19.8313C11.7046 19.8627 11.0891 19.9188 10.9708 20H9.0884C8.89531 19.9002 8.22342 19.8572 7.97539 19.809C4.14191 19.0655 0.939627 15.8946 0.20291 12.0534C0.15672 11.8126 0.096251 11.1034 0 10.9166V9.10736C0.0690643 9.0018 0.159487 8.1876 0.193927 8.00352C0.925113 4.09504 4.15269 0.886369 8.06443 0.172293C8.27197 0.13441 8.99152 0.0895273 9.14119 0ZM10.4983 18.2961C15.0777 18.0197 18.5667 14.0845 18.2926 9.50496C18.0185 4.92545 14.085 1.4345 9.50539 1.70626C4.92244 1.97822 1.42842 5.9151 1.70272 10.4979C1.97701 15.0807 5.91566 18.5727 10.4983 18.2961Z" fill="white"/><path d="M9.85868 5.00639C10.0775 4.98688 10.2767 5.02295 10.4676 5.13828C10.9102 5.40574 10.8273 6.02016 10.8267 6.47334L10.8242 8.39363C10.8239 8.67172 10.8088 9.33854 10.8623 9.5768C11.0838 9.84633 11.4357 10.1795 11.6872 10.4263L12.4924 11.2322C12.6706 11.4081 12.9752 11.6936 13.1226 11.8866C13.2012 11.9879 13.2596 12.1034 13.2947 12.2267C13.4169 12.6712 13.2172 13.1722 12.7474 13.2949C12.6981 13.3077 12.6479 13.3233 12.5983 13.3366C12.4116 13.3595 12.1457 13.3213 11.9941 13.2044C11.6602 12.9451 11.3756 12.6297 11.0808 12.3266C10.5218 11.752 9.93344 11.1968 9.38748 10.6104C9.29461 10.5107 9.21596 10.3901 9.19297 10.2548C9.13471 9.91166 9.14922 9.5559 9.14905 9.20805L9.14956 6.64524C9.14868 6.00322 9.03094 5.1544 9.85868 5.00639Z" fill="white"/></svg>');
}
@media only screen and (min-width: 48rem) {
  :root {
    /* Core Vars DO NOT EDIT. */
    --comp: 48rem;
    /* add more native vars as needed */
  }
}
@media only screen and (min-width: 75rem) {
  :root {
    /* Core Vars DO NOT EDIT. */
    --comp: 75rem;
    /* add more native vars as needed */
  }
}
@media only screen and (min-width: 87.5rem) {
  :root {
    /* Core Vars DO NOT EDIT. */
    --comp: 87.5rem;
    /* add more native vars as needed */
  }
}
@media only screen and (min-width: 120rem) {
  :root {
    /* Core Vars DO NOT EDIT. */
    --comp: 120rem;
    /* add more native vars as needed */
  }
}

/* ================================================================================
* Global Styles/Normalize:
* Custom reset and global styles for the site html tags
================================================================================ */
/* Custom scaffolding and normalizing styles
--------------------------------------------------------------- */
html,
body {
  /* prevent document from shrinking to window sizes that are too small */
  min-inline-size: 20rem;
  /* cascade global font family, color, and to reduce appearance of broken styles */
  font-family: var(--font-primary);
  font-weight: 400;
  color: var(--scheme-fg, var(--color-dark));
  /* make sure there are no edge case words that overflow the layout or make blocks too wide*/
  word-wrap: break-word;
  /* smoothen scroll */
  scroll-behavior: smooth;
  /* mobile viewport bug fix */
  min-block-size: 100vb;
  min-block-size: -webkit-fill-available;
  /* accent color for form stuff */
  accent-color: var(--color-primary);
  /* trim text boxes. if font is designed with weird baseline to ascender space, this might help??? */
  text-box-trim: trim-both;
}

/* position sticky friendly way to cut off any horizontal scrolls but also allow y to still scroll. Apply only on html element or everything will jiggle for safari ios.
 + overflox fix for chrome's responsive inspector -_-
--------------------------------------------------------------- */
html {
  overflow-inline: hidden;
  overflow-block: scroll;
  container-name: document;
}

body {
  overflow-inline: clip;
  /* container support */
  container-name: document;
  container-type: inline-size;
  /* global background. webkit seems to slow down the page it when it's applied to the root element so isolate it to the body for now */
  background: var(--scheme-bg, var(--color-light));
}

/* Remove scrollbar ONLY on touch devices
--------------------------------------------------------------- */
@media (pointer: coarse) {
  html,
  body {
    scrollbar-width: none;
  }
  ::-webkit-scrollbar {
    display: none;
  }
}
/* disable browser focus default styles: Note: customize focus styles as well for accessibility. recommended to set as the same styles as hovers on elements 
--------------------------------------------------------------- */
:focus {
  outline: none;
}

/* Critical sizing and fonts fixes
--------------------------------------------------------------- */
html {
  -webkit-text-size-adjust: 100%;
}

*,
*::before,
*::after {
  /* fix animation flickering issues for webkit browsers */
  -webkit-backspace-visibility: hidden;
  /* box sizing */
  box-sizing: border-box;
  /* font fixes */
  -webkit-font-smoothing: antialiased;
  /* Firefox 25*/
  -moz-osx-font-smoothing: grayscale;
}

/* Transition page load so it looks smoother (beta)
--------------------------------------------------------------- */
@view-transition {
  navigation: auto;
}
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 380ms;
  animation-timing-function: ease;
}

::view-transition-old(root) {
  animation-name: onep21-template-out;
}

::view-transition-new(root) {
  animation-name: onep21-template-in;
}

@keyframes onep21-template-out {
  to {
    opacity: 0;
  }
}
@keyframes onep21-template-in {
  from {
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(root),
  ::view-transition-new(root) {
    animation: none;
  }
}
/* Form control resets. Note: will not entirely prettify Gravity forms styles for the design... yet. To view the rest of the form control scaffoldings, including gravity forms' go to vendor/_gforms styles
--------------------------------------------------------------- */
input:not(:is([type=checkbox], [type=radio])),
textarea,
select,
button {
  -webkit-appearance: none;
  border-radius: 0;
  border: none;
  resize: none;
  display: block;
  font: inherit;
  color: inherit;
  margin: 0;
}

input:is([type=checkbox], [type=radio]) {
  -webkit-appearance: auto;
  -moz-appearance: auto;
       appearance: auto;
}

input::-webkit-input-placeholder,
select::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
  /* placeholder stuff. adjust as needed */
  color: inherit;
  opacity: 0.5;
  -webkit-transition: all 0.25s ease-in-out;
  transition: all 0.25s ease-in-out;
}
input::-moz-placeholder,
select::-moz-placeholder,
textarea::-moz-placeholder {
  /* placeholder stuff. adjust as needed */
  color: inherit;
  opacity: 0.5;
  -moz-transition: all 0.25s ease-in-out;
  transition: all 0.25s ease-in-out;
}
input::-ms-input-placeholder,
select::-ms-input-placeholder,
textarea::-ms-input-placeholder {
  /* placeholder stuff. adjust as needed */
  color: inherit;
  opacity: 0.5;
  -ms-transition: all 0.25s ease-in-out;
  transition: all 0.25s ease-in-out;
}
input:focus::-webkit-input-placeholder,
select:focus::-webkit-input-placeholder,
textarea:focus::-webkit-input-placeholder {
  /* placeholder stuff. adjust as needed */
  opacity: 0.2;
}
input:focus::-moz-placeholder,
select:focus::-moz-placeholder,
textarea:focus::-moz-placeholder {
  /* placeholder stuff. adjust as needed */
  opacity: 0.2;
}
input:focus::-ms-input-placeholder,
select:focus::-ms-input-placeholder,
textarea:focus::-ms-input-placeholder {
  /* placeholder stuff. adjust as needed */
  opacity: 0.2;
}

:is(a, button):hover {
  cursor: pointer;
}

button {
  border: none;
}

/* Remove default ugly blue links. NOTE: Make sure to style a tags appropiately for accessibility while maintianing styleguide
--------------------------------------------------------------- */
:where(a) {
  text-decoration: none;
  color: inherit;
}

/* Monospace elements
--------------------------------------------------------------- */
:where(pre, code, kbd, tt) {
  font-family: var(--font-monospace);
  background: rgba(0, 0, 0, 0.05);
}

:where(code, kbd, tt) {
  padding: 0.125em;
}

:where(pre) {
  padding: 1em;
  max-inline-size: 100%;
  line-height: 1;
  overflow: auto;
}
:where(pre) * {
  border: 0;
  margin: 0;
  padding: 0;
}

/* Other critical element styles
--------------------------------------------------------------- */
:where(strong, b) {
  font-family: inherit;
  font-weight: bolder;
}

:where(em, cite, i, var) {
  font-family: inherit;
  font-style: italic;
}

:where(u) {
  text-decoration: underline;
}

:where(var) {
  font-family: var(--font-secondary);
}

:where(sup, sub, small) {
  font-size: 0.75em;
}

:where(sup) {
  vertical-align: top;
}

:where(sub) {
  vertical-align: bottom;
}

:where(hr) {
  outline: 0;
  border: 0;
  display: block;
}

/* Images
* Note: best practice to let images only expand within available space 
--------------------------------------------------------------- */
:where(img, svg) {
  max-inline-size: 100%;
}

:where(img) {
  block-size: auto;
}

/* Embeds
* Note: best practice to let images only expand within available space 
--------------------------------------------------------------- */
:where(video, audio, iframe, object, embed) {
  max-inline-size: 100%;
}

/* Other custom global scaffolding here....
--------------------------------------------------------------- */
/* Normalize template main and asides' vertical padding. adjust as needed then customize in certain template styles.
You can use classes for other elements that need to share the same padding as well
--------------------------------------------------------------- */
:is(main, .main, aside, .aside) {
  padding-block: 3.75rem;
}
@media only screen and (min-width: 48rem) {
  :is(main, .main, aside, .aside) {
    padding-block: 5.625rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(main, .main, aside, .aside) {
    padding-block: 7.5rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(main, .main, aside, .aside) {
    padding-block: 9.375rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(main, .main, aside, .aside) {
    padding-block: 11.5625rem;
  }
}
.banner-no-background-image :is(main, .main, aside, .aside) {
  -webkit-padding-before: 0rem;
          padding-block-start: 0rem;
}
/* ...Or separate normalize template main and asides' vertical padding.
--------------------------------------------------------------- */
/* Catch fancy/weird/whatever positioned elements into custom templates' content area only + prevent clipping issues
--------------------------------------------------------------- */
.template-wrapper {
  position: relative;
}

/* Other scaffolding styles you might need. NOTE: these will apply globaly. use body classes as needed. refer to functions/function-body-class
--------------------------------------------------------------- */
/* global templating classes .section
--------------------------------------------------------------- */
main:has(> :is(.section, section):is(.section-style-margined, .section-style-padded)) {
  padding-block: 0;
}

:where(.section, section):where(.section-style-padded) {
  padding-block: 3.75rem;
}
:where(.section, section):where(.section-style-margined) {
  margin-block: 3.75rem;
}
@media only screen and (min-width: 48rem) {
  :where(.section, section):where(.section-style-padded) {
    padding-block: 4.5rem;
  }
  :where(.section, section):where(.section-style-margined) {
    margin-block: 4.5rem;
  }
}
/* global per section scaffolding - useful when design is consistent per sections
--------------------------------------------------------------- */
.section-block:where(.section-content):where(:has(.columns), .columns) {
  grid-column: 1/-1;
}
.section-block:where(.section-content):is(.columns) {
  justify-content: center;
  justify-items: center;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  justify-self: center;
}
.section-block:where(.section-content):is(.columns) > .content:only-child {
  grid-column: 1/-1;
}
.section-block:where(.section-content):not(:has(.columns), .columns) > :is(.content:only-child) {
  inline-size: 45rem;
  justify-self: center;
  margin-inline: auto;
}
@media only screen and (min-width: 75rem) {
  .section-block:where(.section-content):is(.columns) {
    --columns-number: 2;
    --columns-gap-x: 5rem;
    --columns-gap-y: 0;
  }
}
@media only screen and (min-width: 75rem) and (max-height: 800px) {
  :where(.section-block):is(.section-image):is(.section-image-can-sticky) {
    align-self: stretch;
  }
  :where(.section-block):is(.section-image):is(.section-image-can-sticky) .section-image-sticky {
    position: -webkit-sticky;
    position: sticky;
    inset-block-start: calc(var(--layout-header-height) + 4vb);
  }
  :where(.section-block):is(.section-image):is(.section-image-can-sticky) .section-image-picture {
    display: block;
    max-block-size: calc(86vb - var(--layout-header-height));
    overflow: clip;
  }
  :where(.section-block):is(.section-image):is(.section-image-can-sticky) .section-image-img {
    -o-object-fit: cover;
       object-fit: cover;
    block-size: 100%;
    inline-size: 100%;
  }
}
/* ================================================================================
* Vendor Overrides ( CSS Library/ Plugin related stuff. EG: animated,slick,gravity forms etc. )
================================================================================ */
/* Vendor - Gravity Forms
--------------------------------------------------------------- */
/* Reset, skeletons, and normalize for gravity forms and form control elements. No need to edit.
--------------------------------------------------------------- */
.gform_wrapper.gravity-theme {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
}
.gform_wrapper.gravity-theme .gfield :is(:is(input, select).large,
textarea) {
  inline-size: 100%;
}
:is(input:not([type=radio]):not([type=checkbox]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]),
:is(.gform_wrapper, .gfield_required) .gfield_required, .gform_wrapper.gravity-theme .gfield_required .gfield_required_custom, .gform_wrapper.gravity-theme .gfield_label, .gform_wrapper.gravity-theme :is(.gfield, .field_description_above) :is(.description,
.gfield_description,
.gsection_description,
.instruction), .gform_wrapper.gravity-theme :is(.gfield_validation_message,
.validation_message) {
  font: inherit;
  color: inherit;
  margin: 0;
  padding: 0;
  overflow: unset;
  block-size: auto;
  max-block-size: none;
  border: 0;
}

.gfield:is(.gfield-custom-box-label-inset, .gfield-custom-box-label-adjacent) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]) {
  line-height: var(--field-line-height, inherit);
  border-radius: var(--field-border-radius, 0);
  color: var(--color-dark);
  padding-inline: calc(var(--field-padding-x, 1em) - var(--field-border-width, 1px));
  padding-block: calc(var(--field-padding-y, 1em) - var(--field-border-width, 1px));
  background: none;
  background-size: calc(100% + var(--field-border-width, 1px) * 2) calc(100% + var(--field-border-width, 1px) * 2);
  background-position: calc(var(--field-border-width, 1px) * -1) calc(var(--field-border-width, 1px) * -1);
  max-inline-size: 100%;
}

.gfield:is(.gfield-custom-box-label-adjacent) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]) {
  border-width: var(--field-border-width, 1px);
  border-style: solid;
  min-block-size: 0;
}

.gfield:is(.gfield-custom-box-label-adjacent):is(.focus) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]):focus {
  border-width: var(--field-border-width, 2px);
}

.gfield:is(.gfield-custom-box-label-inset) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]) {
  background-color: var(--color-light);
  color: var(--color-dark);
}

.gform_wrapper.gravity-theme :is(.gfield_validation_message, .validation_message) {
  /* reset validation messages enough to make matching design more bearable */
  background: none;
  border: 0;
}
.gform_wrapper.gravity-theme .gfield :is(.description, .gfield_description, .gsection_description, .instruction) {
  -webkit-margin-before: 0.5em;
          margin-block-start: 0.5em;
}
.gform_wrapper.gravity-theme .field_description_above :is(.description, .gfield_description, .gsection_description, .instruction) {
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 0.5em;
          margin-block-end: 0.5em;
}

/*  .ginput_ scaffolding. No need to edit 
--------------------------------------------------------------- */
.gform_wrapper.gravity-theme .ginput {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
}
.gform_wrapper.gravity-theme .ginput_container_time {
  min-inline-size: calc(var(--field-padding-x) * 2 + 5ch);
  max-inline-size: calc(var(--field-padding-x) * 2 + 5ch);
}
:is(.field_sublabel_below) .gform_wrapper.gravity-theme .ginput_complex {
  align-items: center;
}
.gform_wrapper.gravity-theme .ginput_container_date input {
  inline-size: 100%;
}

/*  .gfield_ scaffolding. No need to edit
--------------------------------------------------------------- */
.gfield.gfield_error :is(label, legend), .gfield_validation_message,
.gfield .validation_message,
.gfield [aria-invalid=true] + label,
.gfield .gform_wrapper label + [aria-invalid=true] {
  color: var(--field-error-color) !important;
}
.gfield:is(.gfield-custom-box-label-adjacent):is(.gfield_error) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea):is([aria-invalid=true]) {
  border-color: var(--field-error-color) !important;
  /* box-shadow: inset 0 -4px 0 0 var(--field-error-color); */
}

.gfield .gchoice {
  margin: 0 0 0.5em;
}
.gform_wrapper.gravity-theme .gfield :is(.gfield_radio, .gfield_checkbox) label {
  font: unset;
  line-height: unset;
}

/* gfield customize colors
--------------------------------------------------------------- */
/* Form Customizations: Custom gravity forms and form control elements. Adjust as needed.
--------------------------------------------------------------- */
/* Variables. Will put in the form so non-gravity forms form control elements can utilize too */
:is(form, .gfield) {
  /* height of form field. designers will prefer to design form fields based on their height. this is to better support the wonders they create while being able to use padding to support multi-line/ edge case form fields */
  --field-border-width: 1px;
  /* duh */
  --field-border-radius: var(--global-radius-micro);
  /* horizontal padding for the form field */
  --field-padding-x: 1.125em;
  /* color for required indicators */
  --field-padding-y: .875em;
  /* color for required indicators */
  --field-required-color: var(--color-primary);
  /* color for errors */
  --field-error-color: var(--color-error);
  /* Note: this value has to be unitless for calc values to work.
  	* modify this value if the font seems a little too high or low in vertical alignment. 1 moves the text to the very top. 0 moves the text to the very bottom. 0.5 will center it based on the fonts' basline alignment */
  --field-line-height: 1.125;
  font-size: 1rem;
  font-family: var(--font-primary);
  color: inherit;
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: normal;
  text-align: initial;
  text-decoration: none;
}
:is(form, .gfield) select:has(option.gf_placeholder:checked) {
  color: var(--color-neutral) !important;
}
:is(form, .gfield):is(.gfield-custom-box-label-adjacent) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea) {
  border-color: var(--color-accent-gradient-start);
}

:is(form, .gfield):is(.focus, .gfield_error), :is(form, .gfield):is(.gfield-custom-box-label-adjacent):is(.gfield_error) .gfield_label,
:is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea):is([aria-invalid=true], :focus) {
  --field-border-width: 2px;
}

:is(form, .gfield):is(.focus):is(.gfield-custom-box-label-adjacent):is(.focus) .gfield_label,
:is(form, .gfield):is(.focus) :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]):is(:focus) {
  border-color: var(--color-primary);
}

/*  .gfield - multiline
--------------------------------------------------------------- */
.gform_wrapper.gravity-theme .gfield:is(.gfield--type-textarea, .gfield--type-multiselect) :is(textarea, select) {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
}
.gform_wrapper.gravity-theme .gfield:is(.gfield--type-textarea, .gfield--type-multiselect) :is(textarea, select).large {
  block-size: 6.25rem;
}
.gform_wrapper.gravity-theme .gfield:is(.gfield--type-textarea, .gfield--type-multiselect) :is(textarea, select).medium {
  block-size: 5.25rem;
}
.gform_wrapper.gravity-theme .gfield:is(.gfield--type-textarea, .gfield--type-multiselect) :is(textarea, select).small {
  block-size: 4.25rem;
}
/*  .gfield - label
--------------------------------------------------------------- */
.gform_wrapper.gravity-theme .gfield_label {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
  /* customize type for .gfield and scaffolding for descending elements */
  /* custom font styles for gfield_label */
  line-height: var(--field-line-height, inherit);
  -webkit-margin-after: 0.3125rem;
          margin-block-end: 0.3125rem;
}
.gform_wrapper.gravity-theme .gfield :is(.gfield_description, .gfield_consent_description) {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
  /* customize type for .gfield and scaffolding for descending elements */
  /* custom font styles for gfield_label */
  font-size: 0.5625rem;
  line-height: 1.33;
  font-weight: 500;
}
/*  .gform_ overrides. Adjust as needed
--------------------------------------------------------------- */
.gform_wrapper.gravity-theme .gform {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
}
.gform_wrapper.gravity-theme .gform_fields {
  -moz-column-gap: 1rem;
       column-gap: 1rem;
  row-gap: 0.5625rem;
}

/* .gfield_required / .required-glyph Required Indicator
--------------------------------------------------------------- */
.required-glyph,
.gfield-custom-label-indicator.ginput_container::after,
.gform_wrapper.gravity-theme .gfield_required {
  /* adjust required styles  */
  font-size: 1em;
  line-height: var(--field-line-height, inherit);
  color: var(--field-required-color);
  font-style: normal;
  font-weight: 700;
  align-self: center;
  padding: 0;
  order: 99;
}
/* custom helpers - Required Message
--------------------------------------------------------------- */
.required-message {
  font-size: 0.75rem;
  color: var(--field-required-color);
  text-transform: uppercase;
  font-weight: 700;
}
/* custom helpers - Disclaimer Message
--------------------------------------------------------------- */
.disclaimer-message {
  font-size: 1rem;
}
/* Theme Options custom helpers - label required indicator
--------------------------------------------------------------- */
/* required and custom label indicator */
.gfield-custom-label-indicator:is(.ginput_container::before,
.ginput_container::after,
.gfield_label::after,
.gfield_label > .gfield_required) {
  display: block;
  pointer-events: none;
}
.ginput_container {
  position: relative;
}
.ginput_container::before, .ginput_container::after {
  position: absolute;
  inset-inline-end: var(--field-padding-x);
  inset-block-start: calc((var(--field-height) - 1em * var(--field-line-height)) * 0.5);
  z-index: 3;
  pointer-events: none;
}

.gfield_label > .gfield_required, .gfield_label::after {
  -webkit-margin-start: 0.25em;
          margin-inline-start: 0.25em;
}

.gfield_contains_required .gfield-custom-label-indicator[data-required-glyph] {
  /* field ui indicator */
}
.gfield_contains_required .gfield-custom-label-indicator[data-required-glyph]::before {
  inset-inline-end: calc(var(--field-padding-x) + 3em);
}
.gfield_contains_required .gfield-custom-label-indicator[data-required-glyph] {
  /* required indicator */
}
.gfield_contains_required .gfield-custom-label-indicator[data-required-glyph]::after {
  content: attr(data-required-glyph);
}
.gfield-custom-label-indicator.ginput_container::before {
  color: var(--color-dark-alt);
}
.gfield-custom-label-indicator.ginput_container::after, .gfield-custom-label-indicator.gfield_label > .gfield_required {
  color: var(--field-required-color);
}

.gfield-custom-no-label-indicator.gfield_label > .gfield_required {
  display: none;
}

/* related indicators. Make sure required indicator does not conflict
--------------------------------------------------------------- */
.gfield--type-select select {
  -webkit-padding-end: calc(var(--field-padding-x) + 1em);
          padding-inline-end: calc(var(--field-padding-x) + 1em);
}

/* single line select indicator
--------------------------------------------------------------- */
.gfield--type-select .ginput_container::before {
  display: inline-block;
  order: 9;
  align-self: center;
  -webkit-margin-start: 0.75em;
          margin-inline-start: 0.75em;
  -webkit-margin-end: var(--field-padding-x);
          margin-inline-end: var(--field-padding-x);
  transform-origin: center center;
  flex: 0 0 auto;
  content: "";
  font-size: 0.5rem;
  transform-origin: 67% 67%;
  width: 1em;
  height: 1em;
  border: 2px solid var(--color-dark);
  border-top: 0;
  border-left: 0;
  transform: rotate(45deg);
  inset-block: 0;
  margin-block: auto;
}

/* phone indicator
--------------------------------------------------------------- */
.gfield--type-phone.gfield-custom-box-label-inset .gfield_label::after {
  content: "(___) ___-____";
  position: static;
}

/* Theme Options custom helpers - ilawyer custom styles
--------------------------------------------------------------- */
/* custom styles skeletons. No need to edit */
.gform_wrapper.gravity-theme .gfield.gfield-custom-box {
  /* If styles are getting overriden by default gforms styles, prepend `.gform_wrapper.gravity-theme` on field selectors -_- */
  position: relative;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box .gfield_label {
  align-self: start;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset {
  /* Overlay label on the input field NOTE: May soon be deprecated. enable or disable via theme options as needed  */
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset .gfield_label {
  position: absolute;
  inset-block-start: var(--field-border-width);
  inset-inline: var(--field-border-width);
  z-index: 1;
  -webkit-margin-after: 0;
          margin-block-end: 0;
  pointer-events: none;
  /* Take care of edge case overflowing labels */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-inline-size: calc(100% - var(--field-border-width) * 2);
  -webkit-padding-end: calc(var(--field-padding-x) * 2 - var(--field-border-width));
          padding-inline-end: calc(var(--field-padding-x) * 2 - var(--field-border-width));
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset:is(.active, .focus, :focus-within) .gfield_label {
  opacity: 0;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]):not(:focus)::-webkit-input-placeholder {
  /* fix multiline placeholders from peeking behind the label */
  color: transparent;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]):not(:focus)::-moz-placeholder {
  /* fix multiline placeholders from peeking behind the label */
  color: transparent;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-inset :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
[aria-invalid=true]):not(:focus)::-ms-input-placeholder {
  /* fix multiline placeholders from peeking behind the label */
  color: transparent;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent {
  /* set label beside input field. not to be confused with left align labels settingf for forms. this is our custom stuff and it's prettier than how gravity forms does it.  */
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: -webkit-max-content;
  grid-template-rows: max-content;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent .gfield_label,
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent .ginput_container {
  /* grid/flex fix */
  min-inline-size: 0;
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent .gfield_label {
  -webkit-margin-after: 0;
          margin-block-end: 0;
  background-color: var(--color-light-alt);
}
.gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent *:not(.gfield_label):not(.ginput_container) {
  grid-column: 1/-1;
}
@media only screen and (min-width: 48rem) {
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:is(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) :is(.gfield_label, .ginput_container) {
    grid-column: 1/-1;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:is(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) .gfield_label {
    border-end-start-radius: 0;
    border-end-end-radius: 0;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:is(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) .ginput_container {
    grid-column: 2;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:is(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
  select,
  textarea) {
    border-start-start-radius: 0;
    border-start-end-radius: 0;
    -webkit-border-before: 0;
            border-block-start: 0;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:not(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) :is(.gfield_label, .ginput_container) {
    grid-row: 1;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:not(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) .gfield_label {
    grid-column: 1;
    max-inline-size: -webkit-max-content;
    max-inline-size: -moz-max-content;
    max-inline-size: max-content;
    border-start-end-radius: 0;
    border-end-end-radius: 0;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:not(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) .ginput_container {
    grid-column: 2;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent:not(.gfield--type-textarea,
  .gfield--type-multiselect,
  .gfield--type-post_title,
  .gfield--type-post_content,
  .gfield--type-post_excerpt) :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
  select,
  textarea) {
    border-start-start-radius: 0;
    border-end-start-radius: 0;
    -webkit-border-start: 0;
            border-inline-start: 0;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent :is(.gfield_label, .ginput_container) {
    grid-column: 1/-1;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent .gfield_label {
    border-end-start-radius: 0;
    border-end-end-radius: 0;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent .ginput_container {
    grid-column: 2;
  }
  .gform_wrapper.gravity-theme .gfield.gfield-custom-box.gfield-custom-box-label-adjacent :is(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
  select,
  textarea,
  [aria-invalid=true]) {
    border-start-start-radius: 0;
    border-start-end-radius: 0;
    -webkit-border-before: 0;
            border-block-start: 0;
  }
}

/* Inline Choice Form controls
--------------------------------------------------------------- */
.gfield.gfield-custom-inline-choices :is(.gfield_radio) {
  display: flex;
  justify-content: space-evenly;
  flex-direction: row;
}
.gfield.gfield-custom-inline-choices :is(.gchoice) {
  display: inline-flex;
  gap: 1ch;
}
.gfield.gfield-custom-inline-choices :is(.gfield-choice-input + label) {
  flex: 0 0 auto;
  max-inline-size: none;
}

/* Hidden Gravity Forms Stuff
--------------------------------------------------------------- */
.gform_hidden,
.gform_validation_container,
.gform_validation_errors,
.gform_ajax_spinner,
.gform_required_legend {
  /* must hide elements */
  display: none !important;
}

/* custom styles by type
--------------------------------------------------------------- */
.gfield--type-captcha {
  justify-self: center;
}
.gfield--type-consent .gfield_consent_label {
  font-size: 0.8125rem;
}
/* Vendor - Swiper
--------------------------------------------------------------- */
/* Swiper Customizations
Variable docs: https://oxygen4fun.supadezign.com/tips/swiperjs-tips-and-good-practice/#customcss
--------------------------------------------------------------- */
:root {
  --swiper-theme-color: var(--scheme-sp, var(--color-primary));
  --swiper-navigation-sides-offset: 0px;
  --swiper-pagination-bottom: 1.5rem;
  --swiper-pagination-top: auto;
  --swiper-pagination-right: 1rem;
  --swiper-pagination-left: auto;
  --swiper-pagination-bullet-size: 0.375rem;
  --swiper-pagination-bullet-width: var(--swiper-pagination-bullet-size);
  --swiper-pagination-bullet-height: var(--swiper-pagination-bullet-size);
  --swiper-pagination-bullet-border-radius: 9999em;
  --swiper-pagination-bullet-horizontal-gap: calc(
  	var(--swiper-pagination-bullet-size) * 1.5
  );
  --swiper-pagination-bullet-vertical-gap: var(--swiper-pagination-bullet-size);
  --swiper-pagination-bullet-opacity: 1;
  --swiper-pagination-bullet-inactive-opacity: 1;
  --swiper-pagination-bullet-inactive-color: currentColor;
  --swiper-pagination-progressbar-size: var(--swiper-pagination-bullet-size);
  --swiper-pagination-progressbar-bg-color: var(--color-neutral-lighter);
  --swiper-scrollbar-border-radius: calc(var(--swiper-pagination-bullet-size) * 0.5);
  --swiper-scrollbar-bg-color: var(--swiper-pagination-progressbar-bg-color);
  --swiper-scrollbar-drag-bg-color: var(--color-neutral);
  --swiper-scrollbar-size: 2px;
  --swiper-scrollbar-sides-offset: 1rem;
  --swiper-scrollbar-bottom: 1.5rem;
  --swiper-scrollbar-top: auto;
  /* distance of arrows from the slider. set as a padding  */
  /* distance to compensate the arrow distance against the width of the .carousels and the width of the component's container
  	Tip: setting equal to --swiper-custom-arrow-offset-x will align the slides to the container. so pretty. */
}
:where(.content-palette-dark) {
  --swiper-theme-color: var(--scheme-fg, var(--color-primary-alt));
}

/* Swiper Enhancements
--------------------------------------------------------------- */
.swiper {
  opacity: 0;
}
.swiper.swiper-initialized {
  opacity: 1;
}
.swiper {
  padding-inline: var(--swiper-custom-arrow-offset-x, min(var(--container-fallback), var(--container-gutter)));
  margin-inline: calc(var(--swiper-custom-arrow-offset-x-negate, var(--swiper-custom-arrow-offset-x, min(var(--container-fallback), var(--container-gutter)))) * -1);
}
.swiper:has(.swiper-button-prev.swiper-button-disabled):has(.swiper-button-next.swiper-button-disabled):is(.swiper-button-prev,
.swiper-button-next).swiper-button-disabled {
  display: none;
}
:is(:where(.swiper-horizontal) > .swiper-pagination-bullets, .swiper-pagination-bullets:where(.swiper-pagination-horizontal), .swiper-pagination-custom, .swiper-pagination-fraction):not(.swiper-pagination-lock) {
  inset-block-end: var(--swiper-pagination-bottom);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--swiper-pagination-bullet-horizontal-gap);
}

.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0;
}

.swiper-button-next, .swiper-button-prev {
  /* customize swiper buttons to utilize theme's styles for the button */
  --button-baseline-offset: 0.5 !important;
  --swiper-navigation-size: var(--button-height);
  z-index: 1;
  inline-size: auto;
}
.swiper-button-next::before, .swiper-button-next::after, .swiper-button-prev::before, .swiper-button-prev::after {
  content: none;
}
.swiper-scrollbar-drag {
  block-size: calc(var(--swiper-scrollbar-size) * 2);
  inset-block: -50%;
  margin-block: auto;
}

/* Swiper Custom Helpers
--------------------------------------------------------------- */
.swiper-custom-scrollbar-static .swiper-scrollbar {
  position: static;
  -webkit-margin-before: var(--swiper-scrollbar-bottom);
          margin-block-start: var(--swiper-scrollbar-bottom);
  -webkit-margin-after: var(--swiper-scrollbar-size);
          margin-block-end: var(--swiper-scrollbar-size);
  margin-inline: auto;
  -webkit-margin-start: var(--swiper-scrollbar-sides-offset, 1%);
          margin-inline-start: var(--swiper-scrollbar-sides-offset, 1%);
}
.swiper-custom-pagination-static .swiper-pagination {
  position: static;
  -webkit-margin-before: var(--swiper-pagination-bottom);
          margin-block-start: var(--swiper-pagination-bottom);
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .swiper-custom-pagination-static-sm .swiper-pagination {
    position: static;
    -webkit-margin-before: var(--swiper-pagination-bottom);
            margin-block-start: var(--swiper-pagination-bottom);
  }
}
@media only screen and (max-width: 47.9375rem) {
  .swiper-custom-pagination-static-xs .swiper-pagination {
    position: static;
    -webkit-margin-before: var(--swiper-pagination-bottom);
            margin-block-start: var(--swiper-pagination-bottom);
  }
}
.swiper-custom-buttons-static .swiper-wrapper {
  block-size: auto;
}
.swiper-custom-buttons-static .swiper-custom-buttons {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
}
.swiper-custom-buttons-static .swiper-custom-buttons .swiper-button-prev, .swiper-custom-buttons-static .swiper-custom-buttons .swiper-button-next {
  margin-inline: 0;
}
.swiper-custom-buttons-static .swiper-button-next, .swiper-custom-buttons-static .swiper-button-prev {
  position: static;
  transform: none;
  margin: 0;
  -webkit-margin-before: 1.75rem;
          margin-block-start: 1.75rem;
}
.swiper-custom-buttons-static .swiper-button-next ~ .swiper-pagination, .swiper-custom-buttons-static .swiper-button-prev ~ .swiper-pagination {
  display: inline-flex;
  inline-size: auto;
}
.swiper-custom-buttons-static .swiper-button-prev {
  -webkit-margin-end: 0.375rem;
          margin-inline-end: 0.375rem;
}
.swiper-custom-buttons-static .swiper-button-next {
  -webkit-margin-start: 0.375rem;
          margin-inline-start: 0.375rem;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .swiper-custom-buttons-static-sm .swiper-wrapper {
    block-size: auto;
  }
  .swiper-custom-buttons-static-sm .swiper-custom-buttons {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
  }
  .swiper-custom-buttons-static-sm .swiper-custom-buttons .swiper-button-prev, .swiper-custom-buttons-static-sm .swiper-custom-buttons .swiper-button-next {
    margin-inline: 0;
  }
  .swiper-custom-buttons-static-sm .swiper-button-next, .swiper-custom-buttons-static-sm .swiper-button-prev {
    position: static;
    transform: none;
    margin: 0;
    -webkit-margin-before: 1.75rem;
            margin-block-start: 1.75rem;
  }
  .swiper-custom-buttons-static-sm .swiper-button-next ~ .swiper-pagination, .swiper-custom-buttons-static-sm .swiper-button-prev ~ .swiper-pagination {
    display: inline-flex;
    inline-size: auto;
  }
  .swiper-custom-buttons-static-sm .swiper-button-prev {
    -webkit-margin-end: 0.375rem;
            margin-inline-end: 0.375rem;
  }
  .swiper-custom-buttons-static-sm .swiper-button-next {
    -webkit-margin-start: 0.375rem;
            margin-inline-start: 0.375rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .swiper-custom-buttons-static-xs .swiper-wrapper {
    block-size: auto;
  }
  .swiper-custom-buttons-static-xs .swiper-custom-buttons {
    display: flex;
    justify-content: center;
    gap: 0.75rem;
  }
  .swiper-custom-buttons-static-xs .swiper-custom-buttons .swiper-button-prev, .swiper-custom-buttons-static-xs .swiper-custom-buttons .swiper-button-next {
    margin-inline: 0;
  }
  .swiper-custom-buttons-static-xs .swiper-button-next, .swiper-custom-buttons-static-xs .swiper-button-prev {
    position: static;
    transform: none;
    margin: 0;
    -webkit-margin-before: 1.75rem;
            margin-block-start: 1.75rem;
  }
  .swiper-custom-buttons-static-xs .swiper-button-next ~ .swiper-pagination, .swiper-custom-buttons-static-xs .swiper-button-prev ~ .swiper-pagination {
    display: inline-flex;
    inline-size: auto;
  }
  .swiper-custom-buttons-static-xs .swiper-button-prev {
    -webkit-margin-end: 0.375rem;
            margin-inline-end: 0.375rem;
  }
  .swiper-custom-buttons-static-xs .swiper-button-next {
    -webkit-margin-start: 0.375rem;
            margin-inline-start: 0.375rem;
  }
}
.swiper-custom-hide-slides:is(.swiper-initialized, :has(.swiper-initialized)) .swiper-slide:not(.swiper-slide-visible) {
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.25s ease-in-out;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .swiper-custom-hide-slides-sm:is(.swiper-initialized, :has(.swiper-initialized)) .swiper-slide:not(.swiper-slide-visible) {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity 0.25s ease-in-out;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .swiper-custom-hide-slides-xs:is(.swiper-initialized, :has(.swiper-initialized)) .swiper-slide:not(.swiper-slide-visible) {
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity 0.25s ease-in-out;
  }
}
.swiper-custom-ticker {
  --swiper-wrapper-transition-timing-function: linear;
}
@media only screen and (min-width: 75rem) {
  .swiper-custom-stagger :where(.swiper-slide > :only-child) {
    transition-duration: 0.1s;
    transition-property: transform, opacity;
    opacity: 0;
    transform: translateX(50px);
  }
  .swiper-custom-stagger.visible :where(.swiper-slide > :only-child) {
    transition-duration: 1s;
    transition-delay: calc(1s + 0.25s * var(--swiper-custom-slide-i, 0));
    opacity: 1;
    transform: translateX(0px);
  }
}
.swiper-custom-remove-background .swiper-slide {
  mix-blend-mode: multiply;
}
.swiper-custom-equal-heights .swiper-slide {
  block-size: auto;
  align-self: stretch;
  display: flex;
  flex-direction: column;
}
.swiper-custom-equal-heights .swiper-slide > :where(:only-child) {
  flex: 1 1;
}
@media only screen and (min-width: 75rem) {
  .swiper-custom-equal-heights-nontouch .swiper-wrapper {
    height: 100% !important;
  }
  .swiper-custom-equal-heights-nontouch .swiper-slide {
    block-size: auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
  .swiper-custom-equal-heights-nontouch .swiper-slide > :where(:only-child) {
    flex: 1 1;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .swiper-custom-equal-heights-touch .swiper-wrapper {
    height: 100% !important;
  }
  .swiper-custom-equal-heights-touch .swiper-slide {
    block-size: auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
  .swiper-custom-equal-heights-touch .swiper-slide > :where(:only-child) {
    flex: 1 1;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .swiper-custom-equal-heights-sm .swiper-wrapper {
    height: 100% !important;
  }
  .swiper-custom-equal-heights-sm .swiper-slide {
    block-size: auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
  .swiper-custom-equal-heights-sm .swiper-slide > :where(:only-child) {
    flex: 1 1;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .swiper-custom-equal-heights-xs .swiper-wrapper {
    height: 100% !important;
  }
  .swiper-custom-equal-heights-xs .swiper-slide-slide {
    block-size: auto;
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
  .swiper-custom-equal-heights-xs .swiper-slide-slide > :where(:only-child) {
    flex: 1 1;
  }
}

/* ================================================================================
* Content Styles
================================================================================ */
/* Schemes https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/schemes.md
--------------------------------------------------------------- */
/* H tag scaffolding
--------------------------------------------------------------- */
:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6) {
  -webkit-margin-after: var(--fancy-border-margin-y, 0);
          margin-block-end: var(--fancy-border-margin-y, 0);
}

:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)) {
  clear: both;
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)) :where(a) {
  font: inherit;
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)) :where(a):not(:hover, :focus) {
  color: inherit;
  text-decoration: none;
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-inherit {
  color: inherit;
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-primary {
  color: var(--color-primary);
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-primary-alt {
  color: var(--color-primary-alt);
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-secondary {
  color: var(--color-secondary);
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-secondary-alt {
  color: var(--color-secondary-alt);
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-accent {
  color: var(--color-accent);
}
:is(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6),
.content :where(h1, h2, h3, h4, h5, h6)).h-palette-accent-alt {
  color: var(--color-accent-alt);
}

/* H1 - can be reused by section titles, primary-heading etc.
--------------------------------------------------------------- */
:where(*.h1, :is(.content, .editor-styles-wrapper) :where(h1)) {
  font-size: 3.125rem;
  line-height: 1;
  font-family: var(--font-secondary);
  color: var(--color-dark-alt);
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: 500;
}
:where(.content-palette-dark) :where(*.h1, :is(.content, .editor-styles-wrapper) :where(h1)) {
  color: var(--scheme-fg, inherit);
}
@media only screen and (min-width: 48rem) {
  :where(*.h1, :is(.content, .editor-styles-wrapper) :where(h1)) {
    font-size: 3.4375rem;
  }
}
@media only screen and (min-width: 75rem) {
  :where(*.h1, :is(.content, .editor-styles-wrapper) :where(h1)) {
    font-size: 3.75rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :where(*.h1, :is(.content, .editor-styles-wrapper) :where(h1)) {
    font-size: 4.0625rem;
  }
}
/* H2 - can be reused by certain titles
--------------------------------------------------------------- */
:where(*.h2, :is(.content, .editor-styles-wrapper) :where(h2)) {
  font-size: 1.5rem;
  line-height: 1.25;
  font-family: var(--font-accent);
  color: var(--scheme-sp, var(--color-accent));
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: 700;
}
:where(*.h2, :is(.content, .editor-styles-wrapper) :where(h2)):is(.h2-alt) {
  font-size: 1.375rem;
  line-height: 1;
  font-family: var(--font-accent);
  color: var(--scheme-sp, var(--color-accent));
  letter-spacing: 0em;
  text-transform: uppercase;
  font-style: normal;
  font-weight: 800;
}
:where(.content-palette-dark) :where(*.h2, :is(.content, .editor-styles-wrapper) :where(h2)) {
  color: var(--scheme-sp, var(--color-accent-alt));
}
:where(.content-palette-dark) :where(*.h2, :is(.content, .editor-styles-wrapper) :where(h2)):is(.h2-alt) {
  color: var(--scheme-sp, var(--color-primary));
}
/* H3 - can be reused by certain titles
--------------------------------------------------------------- */
:where(*.h3, :is(.content, .editor-styles-wrapper) :where(h3)) {
  font-size: 1.3125rem;
  line-height: 1.28;
  font-family: var(--font-accent);
  color: var(--scheme-sp, var(--color-dark-alt));
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: 700;
}
:where(.content-palette-dark) :where(*.h3, :is(.content, .editor-styles-wrapper) :where(h3)) {
  color: var(--scheme-fg, inherit);
}
/* H4s - if not in the styleguide, can be repurposed for other smaller headings present in the design. commonly case result types/titles, blog post meta, etc
--------------------------------------------------------------- */
:where(*.h4, :is(.content, .editor-styles-wrapper) :where(h4)) {
  font-size: 1.0625rem;
  line-height: 0.88;
  font-family: var(--font-accent);
  color: var(--color-primary);
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: 700;
}
/* H5s - if not in the styleguide, can be repurposed for other smaller headings present in the design. commonly testimonial quote sources, contact info titles, etc
--------------------------------------------------------------- */
:where(*.h5, :is(.content, .editor-styles-wrapper) :where(h5)) {
  font-size: 0.9375rem;
  line-height: 1.27;
  font-family: var(--font-primary);
  color: var(--color-primary);
  letter-spacing: 0em;
  text-transform: uppercase;
  font-style: normal;
  font-weight: 700;
}
:where(.content-palette-dark) :where(*.h5, :is(.content, .editor-styles-wrapper) :where(h5)) {
  color: var(--scheme-fg, var(--color-secondary));
}
/* H6s - if not in the styleguide, can be repurposed for other smaller headings present in the design. commonly contact info titles, etc
--------------------------------------------------------------- */
:where(*.h6, :is(.content, .editor-styles-wrapper) :where(h6)) {
  font-size: 0.8125rem;
  line-height: calc(1em + 5px);
  font-family: var(--font-accent);
  color: var(--scheme-fg, inherit);
  letter-spacing: 0em;
  text-transform: uppercase;
  font-style: normal;
  font-weight: 700;
}
/* Blockquote -  can be reused in testimonial-highlights, long call to action sections, any general quote, etc.
--------------------------------------------------------------- */
:where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) {
  font-size: 1.875rem;
  line-height: 1.43;
  font-family: var(--font-accent);
  color: var(--scheme-sb-contrast, var(--color-dark-alt));
  text-transform: none;
  font-style: normal;
  font-weight: 700;
  text-wrap: balance;
  margin-block: var(--fancy-border-margin-y, 0);
}
:where(.content-palette-dark) :where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) {
  color: var(--scheme-sb-contrast, inherit);
}
:where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) > p {
  font: inherit;
  color: inherit;
  margin-block: 0 0.5em;
  padding: 0;
}
:where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) > p:is(:last-child, :has(+ cite)) {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
@media only screen and (min-width: 48rem) {
  :where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) {
    font-size: 1.875rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :where(*.blockquote, :is(.content, .editor-styles-wrapper) :where(blockquote)) {
    padding-inline: 0;
  }
}

/* Cite /  Blockquote Source - Optional
Note: Some designs may include a blockquote quote source. suprise, there's an html tag for that (:
can be reused in testimonial-source, any general quote source, etc.
--------------------------------------------------------------- */
:where(*.cite, :is(.content, .editor-styles-wrapper) :where(cite)) {
  font-size: 1.125rem;
  line-height: calc(1em + 5px);
  font-family: var(--font-accent);
  color: var(--scheme-sp, var(--color-primary));
  text-transform: uppercase;
  font-style: normal;
  font-weight: 800;
  text-align: inherit;
  display: inline-block;
}
:where(.content-palette-dark) :where(*.cite, :is(.content, .editor-styles-wrapper) :where(cite)) {
  color: var(--scheme-sp, var(--color-accent));
}
/* Lead - Optional
Note: Some designs may include another style for a little bit fancier body text that may not be tagged as a normal html element like blockquote or h tag
Use this if it helps
--------------------------------------------------------------- */
*.lead {
  font-size: 1.375rem;
  line-height: 1.27;
  font-family: var(--font-primary);
  color: inherit;
  letter-spacing: 0em;
  text-transform: none;
  font-style: normal;
  font-weight: 700;
}
:where(.content-palette-dark) *.lead {
  color: var(--scheme-sp-contrast, inherit);
}
/* Content - Anchor links
--------------------------------------------------------------- */
:where(:is(.content, .editor-styles-wrapper) :where(a)) {
  color: var(--scheme-sp, var(--color-primary));
  text-decoration: underline;
  transition: color 0.25s ease-in-out;
}
:where(:is(.content, .editor-styles-wrapper) :where(a)):where(:hover, :focus) {
  color: var(--scheme-sp, var(--color-primary));
  text-decoration: none;
}
:where(.content-palette-dark) :where(:is(.content, .editor-styles-wrapper) :where(a)):not(:where(:hover, :focus)) {
  color: var(--scheme-sp, var(--color-accent));
  text-decoration: none;
}
:where(.content-palette-dark) :where(:is(.content, .editor-styles-wrapper) :where(a)):where(:hover, :focus) {
  color: var(--scheme-sp, inherit);
  text-decoration: underline;
}

/* The Content - Lists Scaffolding
--------------------------------------------------------------- */
:is(:is(.content, .editor-styles-wrapper) :where(ol, ul, dd)) :is(ol, ul, dd) {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
:is(:is(.content, .editor-styles-wrapper) :where(ol, ul, dd)) {
  list-style-type: revert;
  -webkit-padding-start: 2ch;
          padding-inline-start: 2ch;
}

/* The Content - List Items
--------------------------------------------------------------- */
:is(:is(.content, .editor-styles-wrapper) :where(li, dd, dt)) {
  list-style: inherit;
  position: relative;
}
/* The Content - List Items Bulleted
--------------------------------------------------------------- */
:is(:is(.content, .editor-styles-wrapper) :where(li))::marker {
  display: inline-block;
  font-size: 1em;
  color: var(--scheme-sp, var(--color-primary));
}
:where(.content-palette-dark) :is(:is(.content, .editor-styles-wrapper) :where(li))::marker {
  color: var(--scheme-sp, var(--color-accent));
}

/* The Content - Unordered List
--------------------------------------------------------------- */
:is(:is(.content, .editor-styles-wrapper) :where(ul)) {
  list-style-type: disc;
}
/* The Content - Ordered List
--------------------------------------------------------------- */
:is(:is(.content, .editor-styles-wrapper) :where(ol)) {
  counter-reset: listItem;
}
:is(:is(.content, .editor-styles-wrapper) :where(ol)) > li {
  counter-increment: listItem;
}
/* The Content - Tables Skeletons. Do not edit
--------------------------------------------------------------- */
:where(:is(.content, .editor-styles-wrapper) table) {
  border-collapse: separate;
  table-layout: fixed;
  -webkit-hyphens: auto;
          hyphens: auto;
  font: inherit;
  border-color: var(--table-border-color);
  border-width: var(--table-border-width-y) var(--table-border-width-x);
}

:where(:is(.content, .editor-styles-wrapper) :where(th, td)) {
  border-style: solid;
}

:where(:is(.content, .editor-styles-wrapper) :where(tr):first-child > :where(th, td)) {
  border-block-start-color: var(--table-border-color);
}

:where(:is(.content, .editor-styles-wrapper) :where(th, td)) {
  border-width: var(--table-border-width-y) var(--table-border-width-x);
  border-color: var(--table-cell-border-color-y) var(--table-border-color);
  background-color: var(--table-cell-background);
}
:where(:is(.content, .editor-styles-wrapper) :where(th, td)):nth-last-child(n+2) {
  border-right-color: var(--table-cell-border-color-x);
}
:where(:is(.content, .editor-styles-wrapper) :where(th, td)) > *:last-child {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

.table-wrapper {
  overflow-inline: auto;
  max-inline-size: 100%;
}
.table-wrapper table {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}

/* The Content - Tables Customizations
--------------------------------------------------------------- */
:where(:is(.content, .editor-styles-wrapper) table) {
  /* left and right border width */
  --table-border-width-x: 0px;
  /* top and bottom border width */
  --table-border-width-y: 0px;
  /* table container color */
  --table-border-color: var(--scheme-md-bg, var(--color-neutral-lighter));
  /* background color for cells */
  --table-cell-background: var(--scheme-bg, transparent);
  /* border color for left and right */
  --table-cell-border-color-x: var(--scheme-bg-contrast, rgba(127, 127, 127, 0.3));
  /* border color fortop and bottom */
  --table-cell-border-color-y: transparent;
  min-inline-size: 40rem;
  color: var(--color-dark);
  font-size: 0.9em;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th, td) {
  padding-inline: 1.5em;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th, td):first-child {
  border-start-start-radius: var(--global-radius);
  border-end-start-radius: var(--global-radius);
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th, td):last-child {
  border-start-end-radius: var(--global-radius);
  border-end-end-radius: var(--global-radius);
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th) {
  --table-cell-background: var(--color-neutral-lightest);
  --table-cell-border-color-y: var(--table-border-color);
  --table-cell-border-color-x: var(--table-border-color);
  --table-border-width-x: 6px;
  --table-border-width-y: 6px;
  padding-block: 0.375em;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th):nth-child(n+2) {
  border-inline-start-width: 0px;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th):nth-last-child(n+2) {
  border-inline-end-width: 0px;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(th) {
  font-size: 1.125rem;
  font-family: var(--font-accent);
  color: var(--color-primary);
  font-style: normal;
  font-weight: 700;
  text-align: inherit;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(td) {
  padding-block: 0.75em;
}
:where(:is(.content, .editor-styles-wrapper) table) :where(tr:nth-child(even) td) {
  --table-cell-background: var(--color-neutral-lightest);
  --table-cell-border-color-y: var(--scheme-bg-contrast, transparent);
  --table-cell-border-color-x: var(--scheme-bg-contrast, rgba(127, 127, 127, 0.3));
  color: var(--scheme-fg, inherit);
}
:where(:is(.content, .editor-styles-wrapper) table) :where(caption) {
  padding: 0.5em;
}

/* The Content - Other Obscure tags in case it can be utilized for design
--------------------------------------------------------------- */
/* images.
- NOTE: DO NOT MANIPULATE THE MARGIN, PADDING, DISPLAY PROPERTIES. THIS WILL BREAK THE CORE CLASSES AND ANY OTHER CONTENT RELATED STYLES 
- USE TO ONLY PIZZAZZ THE IMAGES ACCORDING TO DESIGN
*/
:where(:is(.content, .editor-styles-wrapper) :where(img)) {
  -webkit-backdrop-filter: blur(5px);
          backdrop-filter: blur(5px);
}

/* bold, strong */
/* italic, em */
/* stacked bold, strong + italic, em. design will inevitably add another emphaized text styling in the content. use to leverage if needed */
/* address */
/* abbreviations */
/* acronym */
/* big */
/* code, kbd, pre */
:where(:is(.content, .editor-styles-wrapper) :where(kbd)) {
  padding-inline: 1em;
  border-radius: 0.2em;
  box-shadow: 0 0.2em 0 0 rgba(127, 127, 127, 0.4);
}
/* strike, del */
:where(:is(.content, .editor-styles-wrapper) :where(del, s)) {
  text-decoration: line-through;
}
/* ins */
/* ins */
/* small */
/* sub */
/* sup */
/* tt */
/* var */
/* The Content - Type Settings
--------------------------------------------------------------- */
:where(.content, .editor-styles-wrapper) {
  max-inline-size: 100%;
}
:where(.content, .editor-styles-wrapper) {
  font-size: 1.125rem;
  line-height: 1.5;
  font-family: var(--font-primary);
  color: inherit;
  font-weight: 500;
}
/* The Content - Margin Block specificities + .content-style-no-block-margins variation
	- Very specific margin block stuff.
--------------------------------------------------------------- */
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(p,
ul,
ol,
dl,
address,
input:not([type=checkbox]):not([type=radio]):not([type=submit]),
select,
textarea,
form,
pre,
.table-wrapper,
table,
.wistia_responsive_padding) {
  -webkit-margin-after: 0.9375em;
          margin-block-end: 0.9375em;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(hr:nth-last-child(n+2)) {
  -webkit-margin-after: 2em;
          margin-block-end: 2em;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(hr:nth-child(n+2)) {
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(li, dd, dt) :where(ul, ol, dd), :where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(li, dd, dt):nth-child(n+2) {
  /* space out each item. Note: some designs may or may not have this. comment out if not needed */
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(li, dd, dt):last-child > *:last-child {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(:where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6, h1, h2, h3, h4, h5, h6, hr):not(:is(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6, *.blockquote, *.cite, h1, h2, h3, h4, h5, h6, blockquote, cite, hr) + *)) {
  -webkit-margin-before: 2.1875rem;
          margin-block-start: 2.1875rem;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(*.h1, *.h2, *.h3, *.h4, *.h5, *.h6, h1, h2, h3, h4, h5, h6) {
  -webkit-margin-after: min(1rem, 0.5em);
          margin-block-end: min(1rem, 0.5em);
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(*.blockquote, blockquote) {
  margin-block: 2.1875rem;
}
:where(.content:not(:is(.content-style-no-block-margins, .content-style-no-block-margins *)),
.editor-styles-wrapper) :where(*.blockquote, blockquote) :where(cite, *.cite) {
  -webkit-margin-before: 1.25em;
          margin-block-start: 1.25em;
}
/* Content/Styleguide Overrides https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/global/content.md#content-utility-classes
Depending on how much versions the designer variates/overrides/customizes the styleguide, you add as much classes here as needed but it WILL bloat and eventully get flagged for performance
--------------------------------------------------------------- */
/* Other Content No Margin Block Variations- Remove first child margin. Note: Do not apply first child margin 0 globally as this causes more unintended issues down the line (content import, post launch, etc.)
* .content-style-no-first-margin - No first margin. Can be also used for specific breakpoints only because some breakdowns forget to take account of these margins eg: .content-style-no-first-margin-[BREAKPOINT]
*/
.content.content-style-no-first-margin > :where(*:first-child) {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
@media only screen and (max-width: 47.9375rem) {
  .content.content-style-no-first-margin-xs > :where(*:first-child) {
    -webkit-margin-before: 0;
            margin-block-start: 0;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .content.content-style-no-first-margin-sm > :where(*:first-child) {
    -webkit-margin-before: 0;
            margin-block-start: 0;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  .content.content-style-no-first-margin-md > :where(*:first-child) {
    -webkit-margin-before: 0;
            margin-block-start: 0;
  }
}
@media only screen and (min-width: 87.5rem) and (max-width: 119.9375rem) {
  .content.content-style-no-first-margin-lg > :where(*:first-child) {
    -webkit-margin-before: 0;
            margin-block-start: 0;
  }
}
@media only screen and (min-width: 120rem) and (max-width: 179.9375rem) {
  .content.content-style-no-first-margin-xl > :where(*:first-child) {
    -webkit-margin-before: 0;
            margin-block-start: 0;
  }
}

/* .content-style-no-first-margin - No first margin. Can be also used for specific breakpoints only because some breakdowns forget to take account of these margins eg: .content-style-no-first-margin-[BREAKPOINT] */
.content.content-style-no-last-margin > :where(*:last-child) {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
@media only screen and (max-width: 47.9375rem) {
  .content.content-style-no-last-margin-xs > :where(*:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .content.content-style-no-last-margin-sm > :where(*:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  .content.content-style-no-last-margin-md > :where(*:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
@media only screen and (min-width: 87.5rem) and (max-width: 119.9375rem) {
  .content.content-style-no-last-margin-lg > :where(*:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
@media only screen and (min-width: 120rem) and (max-width: 179.9375rem) {
  .content.content-style-no-last-margin-xl > :where(*:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}

/* Content/Styleguide Overrides https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/global/content.md#content-utility-classes
Depending on how much versions the designer variates/overrides/customizes the styleguide, you add as much classes here as needed but it WILL bloat and eventully get flagged for performance
--------------------------------------------------------------- */
/* Content Color Palette Helpers: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/global/content.md#content-palette-name

support content styles for dark schemes. 
Note: To aply dark mode styles, use @extends to select optional scheme component.
example of styles:

h2 {
	color: something;

	@include inDark &{
		color: somethingelse
	}
}
--------------------------------------------------------------- */
:where(.content-palette-dark) {
  /* inherit white color: NOTE: for this to work, best practice is for a) text color to be modified alongside dark background styles of containing section for accessibility/ and or b) Use and enabling _schemes.scss */
  color: var(--scheme-fg, var(--color-light));
}

.content-palette-dark :where(ol, ul, table) {
  color: var(--scheme-fg, inherit);
}
.content-palette-dark table {
  --table-border-color: var(--color-neutral-darkest);
}

/* Content Size Variations - Sometimes designs will have random font sizes for content styleguide. idk utilize this
--------------------------------------------------------------- */
.content.content-size-micro {
  font-size: 0.625rem;
}
.content.content-size-small {
  font-size: 0.875rem;
}
.content.content-size-large {
  font-size: 1.125rem;
}
/* Content Weight Variations - For when the design needs a different weight for like 10 different sections
--------------------------------------------------------------- */
/* for content with thicker weight than usual. Less specific */
.content.content-weight-thick {
  font-weight: bolder;
}

/* for content with more specific weights because the design says so */
.content.content-weight-thin {
  font-weight: 100;
}

.content.content-weight-light {
  font-weight: 300;
}

.content.content-weight-regular {
  font-weight: 400;
}

.content.content-weight-medium {
  font-weight: 500;
}

.content.content-weight-semibold {
  font-weight: 600;
}

.content.content-weight-bold {
  font-weight: 700;
}

.content.content-weight-extrabold {
  font-weight: 800;
}

/* Content No List Style Variation - Useful for when they want no bullets on certains ections
--------------------------------------------------------------- */
.content.content-style-no-list :is(.content :where(ol, ul, dd)) {
  -webkit-padding-start: 0;
          padding-inline-start: 0;
  list-style: none;
}
.content.content-style-no-list :is(.content :where(li, dd, dt))::before, .content.content-style-no-list :is(.content :where(li, dd, dt))::marker {
  display: none !important;
}

/* Content line height Variation - for instances of content where they want less line height from the already established styleguide :|
--------------------------------------------------------------- */
.content.content-style-compact {
  line-height: 1.29;
}
.content.content-style-compact li, .content.content-style-compact li :where(ul, ol) {
  margin-block: 0;
}

.content.content-style-expanded {
  line-height: 2;
}
.content.content-style-expanded li, .content.content-style-expanded li :where(ul, ol) {
  margin-block: 0;
}

.content.content-style-constricted {
  line-height: 1;
}
.content.content-style-constricted li, .content.content-style-constricted li :where(ul, ol) {
  margin-block: 0;
}

/* Designs with fancy first letters. adjust styles as needed */
.content.content-style-drop-caps > p:first-of-type::first-letter {
  font-size: 2.75rem;
  font-family: var(--font-accent);
  color: var(--color-primary);
  float: inline-start;
  margin: 0 0.1em -0.25em 0;
}
.content.content-style-drop-caps > p:first-of-type + * {
  clear: inline-start;
}
/* ================================================================================
* Supported WP Core Classes/ Styles
================================================================================ */
/* Wordpress Core Classes.
--------------------------------------------------------------- */
/* Align Classes */
*.alignleft,
*.align-left,
*.alignright,
*.align-right,
*.aligncenter,
*.align-center {
  -webkit-margin-after: 1.25em;
          margin-block-end: 1.25em;
  max-inline-size: 100%;
  block-size: auto;
  inline-size: auto;
}
@media only screen and (max-width: 74.9375rem) {
  *.alignleft,
  *.align-left,
  *.alignright,
  *.align-right,
  *.aligncenter,
  *.align-center {
    display: block;
  }
}

@media only screen and (min-width: 75rem) {
  *.alignleft,
  *.align-left {
    display: inline;
    float: inline-start;
    clear: inline-end;
    -webkit-margin-end: 3em;
            margin-inline-end: 3em;
    margin-block: 1.5em;
  }
  *.alignright,
  *.align-right {
    display: inline;
    float: inline-end;
    clear: inline-end;
    -webkit-margin-start: 3em;
            margin-inline-start: 3em;
    margin-block: 0.5em;
  }
  *.aligncenter,
  *.align-center {
    clear: both;
    display: block;
    -webkit-margin-start: auto;
            margin-inline-start: auto;
    -webkit-margin-end: auto;
            margin-inline-end: auto;
    text-align: center;
  }
}
/* WP Captions */
.wp-caption {
  background: var(--color-light);
  border: 1px solid var(--color-light-alt);
  max-inline-size: 100%;
  padding: 0.5em;
  text-align: center;
}
.wp-caption img {
  border: 0 none;
  block-size: auto;
  margin: 0;
  padding: 0;
  inline-size: auto;
}
.wp-caption p.wp-caption-text {
  font-size: 0.75em;
  line-height: 1.25;
  margin: 0;
}

/* Gutenberg classes */
.has-text-align-center {
  text-align: center;
}

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

.wp-block-cover,
.wp-block-cover-image {
  display: flex;
  align-items: center;
  justify-content: center;
  background-position: center center;
  min-block-size: 26.875rem;
  overflow: clip;
  padding: 1em;
  position: relative;
}

/* ================================================================================
* Global Helpers CSS - These styles are critical to the build and its template parts. They don't usually need edits and will work as is
================================================================================ */
/* Helpers: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/helper.md
Note: Styles already prebuilt in this sass file must not be omitted
--------------------------------------------------------------- */
/* Clearfix stuff
--------------------------------------------------------------- */
.clearfix::after {
  content: "";
  font-size: 0;
  visibility: hidden;
  block-size: 0;
  clear: both;
  display: table;
  inline-size: 100%;
  flex: 0 0 auto;
}

/* hide element while being ADA and SEO friendly
--------------------------------------------------------------- */
.sr-only,
.screen-reader-text {
  border: 0 !important;
  clip: rect(0, 0, 0, 0) !important;
  block-size: 1px !important;
  margin: -1px !important;
  overflow: hidden !important;
  padding: 0 !important;
  position: absolute !important;
  inset-block-start: 0 !important;
  inset-inline-start: 0 !important;
  inline-size: 1px !important;
  word-wrap: normal !important; /* Many screen reader and browser combinations announce broken words as they would appear visually. */
}

/* Screen reader */
.screen-reader-text:focus, *:focus-within > .screen-reader-text {
  background-color: var(--color-light-alt);
  clip: auto !important;
  -webkit-clip-path: none;
          clip-path: none;
  color: var(--color-dark);
  position: fixed;
  display: block;
  font-size: 1em;
  block-size: auto;
  inset-inline-start: 0.25rem;
  inset-block-start: 4rem;
  line-height: normal;
  padding-inline: 0.5rem;
  padding-block: 0.25rem;
  text-decoration: none;
  inline-size: auto;
  z-index: 9999999;
  pointer-events: none;
}

/* emulate background cover on image tags
--------------------------------------------------------------- */
.cover {
  /* containing element */
}
.cover {
  position: relative;
  border-radius: inherit;
  overflow: hidden;
  overflow: clip;
  display: block;
  max-inline-size: 100%;
  inline-size: 100%;
}
.cover:is(.cover-constricted, .cover-contain) {
  /* constrict element. all children will have to be absolute for this element to maintain its size */
}
@supports not (aspect-ratio: var(--cover-aspect-w, 4)/var(--cover-aspect-l, 3)) {
  .cover:is(.cover-constricted, .cover-contain)::before {
    content: "";
    display: block;
    -webkit-padding-after: calc(100% * var(--cover-aspect-l, 3) / var(--cover-aspect-w, 4));
            padding-block-end: calc(100% * var(--cover-aspect-l, 3) / var(--cover-aspect-w, 4));
  }
}
@supports (aspect-ratio: var(--cover-aspect-w, 4)/var(--cover-aspect-l, 3)) {
  .cover:is(.cover-constricted, .cover-contain) {
    aspect-ratio: var(--cover-aspect-w, 4)/var(--cover-aspect-l, 3);
  }
}
.cover > :where(*), .cover-child {
  /* element to emulate background-size cover. Add important in case wistia is somehow in this descendancy */
  position: absolute !important;
  inset: 0 !important;
  inline-size: 100% !important;
  block-size: 100% !important;
  display: block;
}
.cover-constricted .cover-child {
  -o-object-fit: cover !important;
     object-fit: cover !important;
}
.cover-contain .cover-child {
  -o-object-fit: contain !important;
     object-fit: contain !important;
}

/* wrap svgs in this helper to control sizing like font glyphs. Sets an svg to align to the bottom left. Set a font size to it to align heights. ie Case Results Icon, Selling Points, Testimonial stars, Social Media, iLawyer Logo, etc.
--------------------------------------------------------------- */
.content-icon {
  height: 1em;
  display: inline-flex;
  flex-direction: column;
  justify-content: flex-end;
  flex: 0 0 auto;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  text-overflow: ellipsis;
}
.content-icon :where(img, picture, svg, object) {
  max-height: 100%;
  width: auto;
  height: 100%;
  flex: 1 1;
  -o-object-fit: contain;
     object-fit: contain;
}

/* clamp blocks of texts to up to a certain height only, NO scroll. complete cut off. NOTE: for this to work there should be no custom line height on the text or any of its block children. if any, they should be passed to --line-height
--------------------------------------------------------------- */
.clamp-text-ellipsis {
  display: -webkit-box;
  box-orient: vertical;
  -webkit-box-orient: vertical;
  overflow: hidden;
  overflow: clip;
  -webkit-line-clamp: var(--clamp-text-cap, 3);
  line-clamp: var(--clamp-text-cap, 3);
}

/* clamp blocks of texts to up to a certain height only, with scroll.
--------------------------------------------------------------- */
.clamp-text-scroll {
  overflow-inline: clip;
  overflow-block: scroll;
  max-block-size: calc(var(--clamp-text-cap, 3) * var(--clamp-text-mask-height, 1.5em));
  scrollbar-width: none;
  -webkit-mask-image: linear-gradient(to top, transparent 0%, white calc(var(--clamp-text-mask-height, 1.5em) * 1.5), white calc(100% - var(--clamp-text-mask-height, 1.5em) * 0.5), transparent 100%);
          mask-image: linear-gradient(to top, transparent 0%, white calc(var(--clamp-text-mask-height, 1.5em) * 1.5), white calc(100% - var(--clamp-text-mask-height, 1.5em) * 0.5), transparent 100%);
  -webkit-padding-after: var(--clamp-text-mask-height, 1.5em);
          padding-block-end: var(--clamp-text-mask-height, 1.5em);
}
.clamp-text-scroll::-webkit-scrollbar {
  display: none;
}

/* nikky's script to fade text to the right for scrolling
--------------------------------------------------------------- */
.fade-text {
  -webkit-mask-image: linear-gradient(to left, transparent 0em, black var(--fade-text-offset, 2em), black 100%);
          mask-image: linear-gradient(to left, transparent 0em, black var(--fade-text-offset, 2em), black 100%);
  overflow-inline: scroll;
  scrollbar-width: none;
  white-space: nowrap;
  inline-size: 100%;
  -webkit-padding-end: var(--fade-text-offset, 2em);
          padding-inline-end: var(--fade-text-offset, 2em);
}
.fade-text::-webkit-scrollbar {
  display: none;
}

/* like content-icon except friendlier styles for logos to support styleable svg logos while allowing for an img tag for SEO to exist in the same block
--------------------------------------------------------------- */
.logo {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  align-self: stretch;
  justify-content: center;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
}
.logo-wrapper {
  position: relative;
  overflow: hidden;
  block-size: 100%;
  inline-size: auto;
}
.logo-wrapper :where(img, picture, svg, object) {
  max-inline-size: 100%;
  max-block-size: 100%;
  inline-size: auto;
  block-size: 100%;
}
.logo-wrapper :where(svg, object):not(:only-child) {
  pointer-events: none;
  position: absolute;
  margin: auto;
  inset: 0;
  margin: auto;
  inline-size: 100%;
}
.logo-wrapper :is(svg, object) ~ :where(img, picture:not(.inline-svg)) {
  opacity: 0;
}

/* Responsive Global Helpers. Integrated to PHP template parts. Proceed with caution when modifying.
* Note: if the element relies on being set as another display type that's not block (flex, inline-block, inline-flex, etc. ) on  breakpoint/s it is suppose to show, using the *-hide helpers is recommended (eg: instead of xs-only, use sm-hide md-hide lg-hide xl-hide)

* Info to what everything means:
-----------------------------------------------
Tag 	Device		min				max	  
-----------------------------------------------
xs: 	mobile		0				47.9375rem
sm: 	tablet		48rem	74.9375rem
md: 	laptop		75rem	87.4375rem
lg: 	desktop		87.5rem	119.9375rem
xl: 	hd			120rem	999999999999+
--------------------------------------------------------------- */
.xl-only,
.lg-only,
.md-only,
.sm-only,
.xs-only,
.home-only,
.internal-only,
.print-only {
  display: none !important;
}

.onep21-template-home .home-only {
  display: block !important;
}
.onep21-template-home .home-hide {
  display: none !important;
}

body:not(.onep21-template-home) .internal-only {
  display: block !important;
}
body:not(.onep21-template-home) .internal-hide {
  display: none !important;
}

@media only print {
  .print-only {
    display: block !important;
  }
  .print-hide {
    display: none !important;
  }
}
@media only screen and (min-width: 120rem) {
  .xl-only {
    display: block !important;
  }
  .xl-hide {
    display: none !important;
  }
}
@media only screen and (min-width: 87.5rem) and (max-width: 119.9375rem) {
  .lg-only {
    display: block !important;
  }
  .lg-hide {
    display: none !important;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  .md-only {
    display: block !important;
  }
  .md-hide {
    display: none !important;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .sm-only {
    display: block !important;
  }
  .sm-hide {
    display: none !important;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .xs-only {
    display: block !important;
  }
  .xs-hide {
    display: none !important;
  }
}
/* Add more helpers as needed */
/* color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .color-inherit,
.color-inherit-hover:is(:hover, :focus),
.color-inherit-init:not(:is(:hover, :focus)) {
  color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .color-transparent,
.color-transparent-hover:is(:hover, :focus),
.color-transparent-init:not(:is(:hover, :focus)) {
  color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .color-currentColor,
.color-currentColor-hover:is(:hover, :focus),
.color-currentColor-init:not(:is(:hover, :focus)) {
  color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .color-dark,
.color-dark-hover:is(:hover, :focus),
.color-dark-init:not(:is(:hover, :focus)) {
  color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .color-dark-alt,
.color-dark-alt-hover:is(:hover, :focus),
.color-dark-alt-init:not(:is(:hover, :focus)) {
  color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .color-light,
.color-light-hover:is(:hover, :focus),
.color-light-init:not(:is(:hover, :focus)) {
  color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .color-light-alt,
.color-light-alt-hover:is(:hover, :focus),
.color-light-alt-init:not(:is(:hover, :focus)) {
  color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .color-neutral,
.color-neutral-hover:is(:hover, :focus),
.color-neutral-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .color-neutral-light,
.color-neutral-light-hover:is(:hover, :focus),
.color-neutral-light-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .color-neutral-lighter,
.color-neutral-lighter-hover:is(:hover, :focus),
.color-neutral-lighter-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .color-neutral-lightest,
.color-neutral-lightest-hover:is(:hover, :focus),
.color-neutral-lightest-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .color-neutral-dark,
.color-neutral-dark-hover:is(:hover, :focus),
.color-neutral-dark-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .color-neutral-darker,
.color-neutral-darker-hover:is(:hover, :focus),
.color-neutral-darker-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .color-neutral-darkest,
.color-neutral-darkest-hover:is(:hover, :focus),
.color-neutral-darkest-init:not(:is(:hover, :focus)) {
  color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .color-primary,
.color-primary-hover:is(:hover, :focus),
.color-primary-init:not(:is(:hover, :focus)) {
  color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .color-primary-alt,
.color-primary-alt-hover:is(:hover, :focus),
.color-primary-alt-init:not(:is(:hover, :focus)) {
  color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .color-primary-gradient-start,
.color-primary-gradient-start-hover:is(:hover, :focus),
.color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .color-primary-gradient-end,
.color-primary-gradient-end-hover:is(:hover, :focus),
.color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .color-secondary,
.color-secondary-hover:is(:hover, :focus),
.color-secondary-init:not(:is(:hover, :focus)) {
  color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .color-secondary-alt,
.color-secondary-alt-hover:is(:hover, :focus),
.color-secondary-alt-init:not(:is(:hover, :focus)) {
  color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .color-secondary-gradient-start,
.color-secondary-gradient-start-hover:is(:hover, :focus),
.color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .color-secondary-gradient-end,
.color-secondary-gradient-end-hover:is(:hover, :focus),
.color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .color-accent,
.color-accent-hover:is(:hover, :focus),
.color-accent-init:not(:is(:hover, :focus)) {
  color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .color-accent-alt,
.color-accent-alt-hover:is(:hover, :focus),
.color-accent-alt-init:not(:is(:hover, :focus)) {
  color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .color-accent-gradient-start,
.color-accent-gradient-start-hover:is(:hover, :focus),
.color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .color-accent-gradient-end,
.color-accent-gradient-end-hover:is(:hover, :focus),
.color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  color: var(--color-accent-gradient-end);
}

/* background-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .background-color-inherit,
.background-color-inherit-hover:is(:hover, :focus),
.background-color-inherit-init:not(:is(:hover, :focus)) {
  background-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .background-color-transparent,
.background-color-transparent-hover:is(:hover, :focus),
.background-color-transparent-init:not(:is(:hover, :focus)) {
  background-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .background-color-currentColor,
.background-color-currentColor-hover:is(:hover, :focus),
.background-color-currentColor-init:not(:is(:hover, :focus)) {
  background-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .background-color-dark,
.background-color-dark-hover:is(:hover, :focus),
.background-color-dark-init:not(:is(:hover, :focus)) {
  background-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .background-color-dark-alt,
.background-color-dark-alt-hover:is(:hover, :focus),
.background-color-dark-alt-init:not(:is(:hover, :focus)) {
  background-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .background-color-light,
.background-color-light-hover:is(:hover, :focus),
.background-color-light-init:not(:is(:hover, :focus)) {
  background-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .background-color-light-alt,
.background-color-light-alt-hover:is(:hover, :focus),
.background-color-light-alt-init:not(:is(:hover, :focus)) {
  background-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .background-color-neutral,
.background-color-neutral-hover:is(:hover, :focus),
.background-color-neutral-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .background-color-neutral-light,
.background-color-neutral-light-hover:is(:hover, :focus),
.background-color-neutral-light-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .background-color-neutral-lighter,
.background-color-neutral-lighter-hover:is(:hover, :focus),
.background-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .background-color-neutral-lightest,
.background-color-neutral-lightest-hover:is(:hover, :focus),
.background-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .background-color-neutral-dark,
.background-color-neutral-dark-hover:is(:hover, :focus),
.background-color-neutral-dark-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .background-color-neutral-darker,
.background-color-neutral-darker-hover:is(:hover, :focus),
.background-color-neutral-darker-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .background-color-neutral-darkest,
.background-color-neutral-darkest-hover:is(:hover, :focus),
.background-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  background-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .background-color-primary,
.background-color-primary-hover:is(:hover, :focus),
.background-color-primary-init:not(:is(:hover, :focus)) {
  background-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .background-color-primary-alt,
.background-color-primary-alt-hover:is(:hover, :focus),
.background-color-primary-alt-init:not(:is(:hover, :focus)) {
  background-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .background-color-primary-gradient-start,
.background-color-primary-gradient-start-hover:is(:hover, :focus),
.background-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  background-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .background-color-primary-gradient-end,
.background-color-primary-gradient-end-hover:is(:hover, :focus),
.background-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  background-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .background-color-secondary,
.background-color-secondary-hover:is(:hover, :focus),
.background-color-secondary-init:not(:is(:hover, :focus)) {
  background-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .background-color-secondary-alt,
.background-color-secondary-alt-hover:is(:hover, :focus),
.background-color-secondary-alt-init:not(:is(:hover, :focus)) {
  background-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .background-color-secondary-gradient-start,
.background-color-secondary-gradient-start-hover:is(:hover, :focus),
.background-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  background-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .background-color-secondary-gradient-end,
.background-color-secondary-gradient-end-hover:is(:hover, :focus),
.background-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  background-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .background-color-accent,
.background-color-accent-hover:is(:hover, :focus),
.background-color-accent-init:not(:is(:hover, :focus)) {
  background-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .background-color-accent-alt,
.background-color-accent-alt-hover:is(:hover, :focus),
.background-color-accent-alt-init:not(:is(:hover, :focus)) {
  background-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .background-color-accent-gradient-start,
.background-color-accent-gradient-start-hover:is(:hover, :focus),
.background-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  background-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .background-color-accent-gradient-end,
.background-color-accent-gradient-end-hover:is(:hover, :focus),
.background-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  background-color: var(--color-accent-gradient-end);
}

/* border-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-color-inherit,
.border-color-inherit-hover:is(:hover, :focus),
.border-color-inherit-init:not(:is(:hover, :focus)) {
  border-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-color-transparent,
.border-color-transparent-hover:is(:hover, :focus),
.border-color-transparent-init:not(:is(:hover, :focus)) {
  border-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-color-currentColor,
.border-color-currentColor-hover:is(:hover, :focus),
.border-color-currentColor-init:not(:is(:hover, :focus)) {
  border-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-color-dark,
.border-color-dark-hover:is(:hover, :focus),
.border-color-dark-init:not(:is(:hover, :focus)) {
  border-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-color-dark-alt,
.border-color-dark-alt-hover:is(:hover, :focus),
.border-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-color-light,
.border-color-light-hover:is(:hover, :focus),
.border-color-light-init:not(:is(:hover, :focus)) {
  border-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-color-light-alt,
.border-color-light-alt-hover:is(:hover, :focus),
.border-color-light-alt-init:not(:is(:hover, :focus)) {
  border-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-color-neutral,
.border-color-neutral-hover:is(:hover, :focus),
.border-color-neutral-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-color-neutral-light,
.border-color-neutral-light-hover:is(:hover, :focus),
.border-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-color-neutral-lighter,
.border-color-neutral-lighter-hover:is(:hover, :focus),
.border-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-color-neutral-lightest,
.border-color-neutral-lightest-hover:is(:hover, :focus),
.border-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-color-neutral-dark,
.border-color-neutral-dark-hover:is(:hover, :focus),
.border-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-color-neutral-darker,
.border-color-neutral-darker-hover:is(:hover, :focus),
.border-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-color-neutral-darkest,
.border-color-neutral-darkest-hover:is(:hover, :focus),
.border-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-color-primary,
.border-color-primary-hover:is(:hover, :focus),
.border-color-primary-init:not(:is(:hover, :focus)) {
  border-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-color-primary-alt,
.border-color-primary-alt-hover:is(:hover, :focus),
.border-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-color-primary-gradient-start,
.border-color-primary-gradient-start-hover:is(:hover, :focus),
.border-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-color-primary-gradient-end,
.border-color-primary-gradient-end-hover:is(:hover, :focus),
.border-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-color-secondary,
.border-color-secondary-hover:is(:hover, :focus),
.border-color-secondary-init:not(:is(:hover, :focus)) {
  border-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-color-secondary-alt,
.border-color-secondary-alt-hover:is(:hover, :focus),
.border-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-color-secondary-gradient-start,
.border-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-color-secondary-gradient-end,
.border-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-color-accent,
.border-color-accent-hover:is(:hover, :focus),
.border-color-accent-init:not(:is(:hover, :focus)) {
  border-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-color-accent-alt,
.border-color-accent-alt-hover:is(:hover, :focus),
.border-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-color-accent-gradient-start,
.border-color-accent-gradient-start-hover:is(:hover, :focus),
.border-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-color-accent-gradient-end,
.border-color-accent-gradient-end-hover:is(:hover, :focus),
.border-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-color: var(--color-accent-gradient-end);
}

/* border-block-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-block-color-inherit,
.border-block-color-inherit-hover:is(:hover, :focus),
.border-block-color-inherit-init:not(:is(:hover, :focus)) {
  border-block-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-block-color-transparent,
.border-block-color-transparent-hover:is(:hover, :focus),
.border-block-color-transparent-init:not(:is(:hover, :focus)) {
  border-block-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-block-color-currentColor,
.border-block-color-currentColor-hover:is(:hover, :focus),
.border-block-color-currentColor-init:not(:is(:hover, :focus)) {
  border-block-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-block-color-dark,
.border-block-color-dark-hover:is(:hover, :focus),
.border-block-color-dark-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-block-color-dark-alt,
.border-block-color-dark-alt-hover:is(:hover, :focus),
.border-block-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-block-color-light,
.border-block-color-light-hover:is(:hover, :focus),
.border-block-color-light-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-block-color-light-alt,
.border-block-color-light-alt-hover:is(:hover, :focus),
.border-block-color-light-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-block-color-neutral,
.border-block-color-neutral-hover:is(:hover, :focus),
.border-block-color-neutral-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-block-color-neutral-light,
.border-block-color-neutral-light-hover:is(:hover, :focus),
.border-block-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-block-color-neutral-lighter,
.border-block-color-neutral-lighter-hover:is(:hover, :focus),
.border-block-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-block-color-neutral-lightest,
.border-block-color-neutral-lightest-hover:is(:hover, :focus),
.border-block-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-block-color-neutral-dark,
.border-block-color-neutral-dark-hover:is(:hover, :focus),
.border-block-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-block-color-neutral-darker,
.border-block-color-neutral-darker-hover:is(:hover, :focus),
.border-block-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-block-color-neutral-darkest,
.border-block-color-neutral-darkest-hover:is(:hover, :focus),
.border-block-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-block-color-primary,
.border-block-color-primary-hover:is(:hover, :focus),
.border-block-color-primary-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-block-color-primary-alt,
.border-block-color-primary-alt-hover:is(:hover, :focus),
.border-block-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-block-color-primary-gradient-start,
.border-block-color-primary-gradient-start-hover:is(:hover, :focus),
.border-block-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-block-color-primary-gradient-end,
.border-block-color-primary-gradient-end-hover:is(:hover, :focus),
.border-block-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-block-color-secondary,
.border-block-color-secondary-hover:is(:hover, :focus),
.border-block-color-secondary-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-block-color-secondary-alt,
.border-block-color-secondary-alt-hover:is(:hover, :focus),
.border-block-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-block-color-secondary-gradient-start,
.border-block-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-block-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-block-color-secondary-gradient-end,
.border-block-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-block-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-block-color-accent,
.border-block-color-accent-hover:is(:hover, :focus),
.border-block-color-accent-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-block-color-accent-alt,
.border-block-color-accent-alt-hover:is(:hover, :focus),
.border-block-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-block-color-accent-gradient-start,
.border-block-color-accent-gradient-start-hover:is(:hover, :focus),
.border-block-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-block-color-accent-gradient-end,
.border-block-color-accent-gradient-end-hover:is(:hover, :focus),
.border-block-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-gradient-end);
}

/* border-inline-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-inline-color-inherit,
.border-inline-color-inherit-hover:is(:hover, :focus),
.border-inline-color-inherit-init:not(:is(:hover, :focus)) {
  border-inline-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-inline-color-transparent,
.border-inline-color-transparent-hover:is(:hover, :focus),
.border-inline-color-transparent-init:not(:is(:hover, :focus)) {
  border-inline-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-inline-color-currentColor,
.border-inline-color-currentColor-hover:is(:hover, :focus),
.border-inline-color-currentColor-init:not(:is(:hover, :focus)) {
  border-inline-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-inline-color-dark,
.border-inline-color-dark-hover:is(:hover, :focus),
.border-inline-color-dark-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-inline-color-dark-alt,
.border-inline-color-dark-alt-hover:is(:hover, :focus),
.border-inline-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-inline-color-light,
.border-inline-color-light-hover:is(:hover, :focus),
.border-inline-color-light-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-inline-color-light-alt,
.border-inline-color-light-alt-hover:is(:hover, :focus),
.border-inline-color-light-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-inline-color-neutral,
.border-inline-color-neutral-hover:is(:hover, :focus),
.border-inline-color-neutral-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-inline-color-neutral-light,
.border-inline-color-neutral-light-hover:is(:hover, :focus),
.border-inline-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-inline-color-neutral-lighter,
.border-inline-color-neutral-lighter-hover:is(:hover, :focus),
.border-inline-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-inline-color-neutral-lightest,
.border-inline-color-neutral-lightest-hover:is(:hover, :focus),
.border-inline-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-inline-color-neutral-dark,
.border-inline-color-neutral-dark-hover:is(:hover, :focus),
.border-inline-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-inline-color-neutral-darker,
.border-inline-color-neutral-darker-hover:is(:hover, :focus),
.border-inline-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-inline-color-neutral-darkest,
.border-inline-color-neutral-darkest-hover:is(:hover, :focus),
.border-inline-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-inline-color-primary,
.border-inline-color-primary-hover:is(:hover, :focus),
.border-inline-color-primary-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-inline-color-primary-alt,
.border-inline-color-primary-alt-hover:is(:hover, :focus),
.border-inline-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-inline-color-primary-gradient-start,
.border-inline-color-primary-gradient-start-hover:is(:hover, :focus),
.border-inline-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-inline-color-primary-gradient-end,
.border-inline-color-primary-gradient-end-hover:is(:hover, :focus),
.border-inline-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-inline-color-secondary,
.border-inline-color-secondary-hover:is(:hover, :focus),
.border-inline-color-secondary-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-inline-color-secondary-alt,
.border-inline-color-secondary-alt-hover:is(:hover, :focus),
.border-inline-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-inline-color-secondary-gradient-start,
.border-inline-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-inline-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-inline-color-secondary-gradient-end,
.border-inline-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-inline-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-inline-color-accent,
.border-inline-color-accent-hover:is(:hover, :focus),
.border-inline-color-accent-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-inline-color-accent-alt,
.border-inline-color-accent-alt-hover:is(:hover, :focus),
.border-inline-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-inline-color-accent-gradient-start,
.border-inline-color-accent-gradient-start-hover:is(:hover, :focus),
.border-inline-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-inline-color-accent-gradient-end,
.border-inline-color-accent-gradient-end-hover:is(:hover, :focus),
.border-inline-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-gradient-end);
}

/* border-block-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-block-color-inherit,
.border-block-color-inherit-hover:is(:hover, :focus),
.border-block-color-inherit-init:not(:is(:hover, :focus)) {
  border-block-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-block-color-transparent,
.border-block-color-transparent-hover:is(:hover, :focus),
.border-block-color-transparent-init:not(:is(:hover, :focus)) {
  border-block-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-block-color-currentColor,
.border-block-color-currentColor-hover:is(:hover, :focus),
.border-block-color-currentColor-init:not(:is(:hover, :focus)) {
  border-block-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-block-color-dark,
.border-block-color-dark-hover:is(:hover, :focus),
.border-block-color-dark-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-block-color-dark-alt,
.border-block-color-dark-alt-hover:is(:hover, :focus),
.border-block-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-block-color-light,
.border-block-color-light-hover:is(:hover, :focus),
.border-block-color-light-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-block-color-light-alt,
.border-block-color-light-alt-hover:is(:hover, :focus),
.border-block-color-light-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-block-color-neutral,
.border-block-color-neutral-hover:is(:hover, :focus),
.border-block-color-neutral-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-block-color-neutral-light,
.border-block-color-neutral-light-hover:is(:hover, :focus),
.border-block-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-block-color-neutral-lighter,
.border-block-color-neutral-lighter-hover:is(:hover, :focus),
.border-block-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-block-color-neutral-lightest,
.border-block-color-neutral-lightest-hover:is(:hover, :focus),
.border-block-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-block-color-neutral-dark,
.border-block-color-neutral-dark-hover:is(:hover, :focus),
.border-block-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-block-color-neutral-darker,
.border-block-color-neutral-darker-hover:is(:hover, :focus),
.border-block-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-block-color-neutral-darkest,
.border-block-color-neutral-darkest-hover:is(:hover, :focus),
.border-block-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-block-color-primary,
.border-block-color-primary-hover:is(:hover, :focus),
.border-block-color-primary-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-block-color-primary-alt,
.border-block-color-primary-alt-hover:is(:hover, :focus),
.border-block-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-block-color-primary-gradient-start,
.border-block-color-primary-gradient-start-hover:is(:hover, :focus),
.border-block-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-block-color-primary-gradient-end,
.border-block-color-primary-gradient-end-hover:is(:hover, :focus),
.border-block-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-block-color-secondary,
.border-block-color-secondary-hover:is(:hover, :focus),
.border-block-color-secondary-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-block-color-secondary-alt,
.border-block-color-secondary-alt-hover:is(:hover, :focus),
.border-block-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-block-color-secondary-gradient-start,
.border-block-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-block-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-block-color-secondary-gradient-end,
.border-block-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-block-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-block-color-accent,
.border-block-color-accent-hover:is(:hover, :focus),
.border-block-color-accent-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-block-color-accent-alt,
.border-block-color-accent-alt-hover:is(:hover, :focus),
.border-block-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-block-color-accent-gradient-start,
.border-block-color-accent-gradient-start-hover:is(:hover, :focus),
.border-block-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-block-color-accent-gradient-end,
.border-block-color-accent-gradient-end-hover:is(:hover, :focus),
.border-block-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-color: var(--color-accent-gradient-end);
}

/* border-inline-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-inline-color-inherit,
.border-inline-color-inherit-hover:is(:hover, :focus),
.border-inline-color-inherit-init:not(:is(:hover, :focus)) {
  border-inline-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-inline-color-transparent,
.border-inline-color-transparent-hover:is(:hover, :focus),
.border-inline-color-transparent-init:not(:is(:hover, :focus)) {
  border-inline-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-inline-color-currentColor,
.border-inline-color-currentColor-hover:is(:hover, :focus),
.border-inline-color-currentColor-init:not(:is(:hover, :focus)) {
  border-inline-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-inline-color-dark,
.border-inline-color-dark-hover:is(:hover, :focus),
.border-inline-color-dark-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-inline-color-dark-alt,
.border-inline-color-dark-alt-hover:is(:hover, :focus),
.border-inline-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-inline-color-light,
.border-inline-color-light-hover:is(:hover, :focus),
.border-inline-color-light-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-inline-color-light-alt,
.border-inline-color-light-alt-hover:is(:hover, :focus),
.border-inline-color-light-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-inline-color-neutral,
.border-inline-color-neutral-hover:is(:hover, :focus),
.border-inline-color-neutral-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-inline-color-neutral-light,
.border-inline-color-neutral-light-hover:is(:hover, :focus),
.border-inline-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-inline-color-neutral-lighter,
.border-inline-color-neutral-lighter-hover:is(:hover, :focus),
.border-inline-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-inline-color-neutral-lightest,
.border-inline-color-neutral-lightest-hover:is(:hover, :focus),
.border-inline-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-inline-color-neutral-dark,
.border-inline-color-neutral-dark-hover:is(:hover, :focus),
.border-inline-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-inline-color-neutral-darker,
.border-inline-color-neutral-darker-hover:is(:hover, :focus),
.border-inline-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-inline-color-neutral-darkest,
.border-inline-color-neutral-darkest-hover:is(:hover, :focus),
.border-inline-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-inline-color-primary,
.border-inline-color-primary-hover:is(:hover, :focus),
.border-inline-color-primary-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-inline-color-primary-alt,
.border-inline-color-primary-alt-hover:is(:hover, :focus),
.border-inline-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-inline-color-primary-gradient-start,
.border-inline-color-primary-gradient-start-hover:is(:hover, :focus),
.border-inline-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-inline-color-primary-gradient-end,
.border-inline-color-primary-gradient-end-hover:is(:hover, :focus),
.border-inline-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-inline-color-secondary,
.border-inline-color-secondary-hover:is(:hover, :focus),
.border-inline-color-secondary-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-inline-color-secondary-alt,
.border-inline-color-secondary-alt-hover:is(:hover, :focus),
.border-inline-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-inline-color-secondary-gradient-start,
.border-inline-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-inline-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-inline-color-secondary-gradient-end,
.border-inline-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-inline-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-inline-color-accent,
.border-inline-color-accent-hover:is(:hover, :focus),
.border-inline-color-accent-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-inline-color-accent-alt,
.border-inline-color-accent-alt-hover:is(:hover, :focus),
.border-inline-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-inline-color-accent-gradient-start,
.border-inline-color-accent-gradient-start-hover:is(:hover, :focus),
.border-inline-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-inline-color-accent-gradient-end,
.border-inline-color-accent-gradient-end-hover:is(:hover, :focus),
.border-inline-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-color: var(--color-accent-gradient-end);
}

/* border-block-start-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-block-start-color-inherit,
.border-block-start-color-inherit-hover:is(:hover, :focus),
.border-block-start-color-inherit-init:not(:is(:hover, :focus)) {
  border-block-start-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-block-start-color-transparent,
.border-block-start-color-transparent-hover:is(:hover, :focus),
.border-block-start-color-transparent-init:not(:is(:hover, :focus)) {
  border-block-start-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-block-start-color-currentColor,
.border-block-start-color-currentColor-hover:is(:hover, :focus),
.border-block-start-color-currentColor-init:not(:is(:hover, :focus)) {
  border-block-start-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-block-start-color-dark,
.border-block-start-color-dark-hover:is(:hover, :focus),
.border-block-start-color-dark-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-block-start-color-dark-alt,
.border-block-start-color-dark-alt-hover:is(:hover, :focus),
.border-block-start-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-block-start-color-light,
.border-block-start-color-light-hover:is(:hover, :focus),
.border-block-start-color-light-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-block-start-color-light-alt,
.border-block-start-color-light-alt-hover:is(:hover, :focus),
.border-block-start-color-light-alt-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-block-start-color-neutral,
.border-block-start-color-neutral-hover:is(:hover, :focus),
.border-block-start-color-neutral-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-block-start-color-neutral-light,
.border-block-start-color-neutral-light-hover:is(:hover, :focus),
.border-block-start-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-block-start-color-neutral-lighter,
.border-block-start-color-neutral-lighter-hover:is(:hover, :focus),
.border-block-start-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-block-start-color-neutral-lightest,
.border-block-start-color-neutral-lightest-hover:is(:hover, :focus),
.border-block-start-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-block-start-color-neutral-dark,
.border-block-start-color-neutral-dark-hover:is(:hover, :focus),
.border-block-start-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-block-start-color-neutral-darker,
.border-block-start-color-neutral-darker-hover:is(:hover, :focus),
.border-block-start-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-block-start-color-neutral-darkest,
.border-block-start-color-neutral-darkest-hover:is(:hover, :focus),
.border-block-start-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-block-start-color-primary,
.border-block-start-color-primary-hover:is(:hover, :focus),
.border-block-start-color-primary-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-block-start-color-primary-alt,
.border-block-start-color-primary-alt-hover:is(:hover, :focus),
.border-block-start-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-block-start-color-primary-gradient-start,
.border-block-start-color-primary-gradient-start-hover:is(:hover, :focus),
.border-block-start-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-block-start-color-primary-gradient-end,
.border-block-start-color-primary-gradient-end-hover:is(:hover, :focus),
.border-block-start-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-block-start-color-secondary,
.border-block-start-color-secondary-hover:is(:hover, :focus),
.border-block-start-color-secondary-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-block-start-color-secondary-alt,
.border-block-start-color-secondary-alt-hover:is(:hover, :focus),
.border-block-start-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-block-start-color-secondary-gradient-start,
.border-block-start-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-block-start-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-block-start-color-secondary-gradient-end,
.border-block-start-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-block-start-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-block-start-color-accent,
.border-block-start-color-accent-hover:is(:hover, :focus),
.border-block-start-color-accent-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-block-start-color-accent-alt,
.border-block-start-color-accent-alt-hover:is(:hover, :focus),
.border-block-start-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-block-start-color-accent-gradient-start,
.border-block-start-color-accent-gradient-start-hover:is(:hover, :focus),
.border-block-start-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-block-start-color-accent-gradient-end,
.border-block-start-color-accent-gradient-end-hover:is(:hover, :focus),
.border-block-start-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-start-color: var(--color-accent-gradient-end);
}

/* border-block-end-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-block-end-color-inherit,
.border-block-end-color-inherit-hover:is(:hover, :focus),
.border-block-end-color-inherit-init:not(:is(:hover, :focus)) {
  border-block-end-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-block-end-color-transparent,
.border-block-end-color-transparent-hover:is(:hover, :focus),
.border-block-end-color-transparent-init:not(:is(:hover, :focus)) {
  border-block-end-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-block-end-color-currentColor,
.border-block-end-color-currentColor-hover:is(:hover, :focus),
.border-block-end-color-currentColor-init:not(:is(:hover, :focus)) {
  border-block-end-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-block-end-color-dark,
.border-block-end-color-dark-hover:is(:hover, :focus),
.border-block-end-color-dark-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-block-end-color-dark-alt,
.border-block-end-color-dark-alt-hover:is(:hover, :focus),
.border-block-end-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-block-end-color-light,
.border-block-end-color-light-hover:is(:hover, :focus),
.border-block-end-color-light-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-block-end-color-light-alt,
.border-block-end-color-light-alt-hover:is(:hover, :focus),
.border-block-end-color-light-alt-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-block-end-color-neutral,
.border-block-end-color-neutral-hover:is(:hover, :focus),
.border-block-end-color-neutral-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-block-end-color-neutral-light,
.border-block-end-color-neutral-light-hover:is(:hover, :focus),
.border-block-end-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-block-end-color-neutral-lighter,
.border-block-end-color-neutral-lighter-hover:is(:hover, :focus),
.border-block-end-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-block-end-color-neutral-lightest,
.border-block-end-color-neutral-lightest-hover:is(:hover, :focus),
.border-block-end-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-block-end-color-neutral-dark,
.border-block-end-color-neutral-dark-hover:is(:hover, :focus),
.border-block-end-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-block-end-color-neutral-darker,
.border-block-end-color-neutral-darker-hover:is(:hover, :focus),
.border-block-end-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-block-end-color-neutral-darkest,
.border-block-end-color-neutral-darkest-hover:is(:hover, :focus),
.border-block-end-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-block-end-color-primary,
.border-block-end-color-primary-hover:is(:hover, :focus),
.border-block-end-color-primary-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-block-end-color-primary-alt,
.border-block-end-color-primary-alt-hover:is(:hover, :focus),
.border-block-end-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-block-end-color-primary-gradient-start,
.border-block-end-color-primary-gradient-start-hover:is(:hover, :focus),
.border-block-end-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-block-end-color-primary-gradient-end,
.border-block-end-color-primary-gradient-end-hover:is(:hover, :focus),
.border-block-end-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-block-end-color-secondary,
.border-block-end-color-secondary-hover:is(:hover, :focus),
.border-block-end-color-secondary-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-block-end-color-secondary-alt,
.border-block-end-color-secondary-alt-hover:is(:hover, :focus),
.border-block-end-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-block-end-color-secondary-gradient-start,
.border-block-end-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-block-end-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-block-end-color-secondary-gradient-end,
.border-block-end-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-block-end-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-block-end-color-accent,
.border-block-end-color-accent-hover:is(:hover, :focus),
.border-block-end-color-accent-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-block-end-color-accent-alt,
.border-block-end-color-accent-alt-hover:is(:hover, :focus),
.border-block-end-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-block-end-color-accent-gradient-start,
.border-block-end-color-accent-gradient-start-hover:is(:hover, :focus),
.border-block-end-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-block-end-color-accent-gradient-end,
.border-block-end-color-accent-gradient-end-hover:is(:hover, :focus),
.border-block-end-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-block-end-color: var(--color-accent-gradient-end);
}

/* border-inline-start-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-inline-start-color-inherit,
.border-inline-start-color-inherit-hover:is(:hover, :focus),
.border-inline-start-color-inherit-init:not(:is(:hover, :focus)) {
  border-inline-start-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-inline-start-color-transparent,
.border-inline-start-color-transparent-hover:is(:hover, :focus),
.border-inline-start-color-transparent-init:not(:is(:hover, :focus)) {
  border-inline-start-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-inline-start-color-currentColor,
.border-inline-start-color-currentColor-hover:is(:hover, :focus),
.border-inline-start-color-currentColor-init:not(:is(:hover, :focus)) {
  border-inline-start-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-inline-start-color-dark,
.border-inline-start-color-dark-hover:is(:hover, :focus),
.border-inline-start-color-dark-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-inline-start-color-dark-alt,
.border-inline-start-color-dark-alt-hover:is(:hover, :focus),
.border-inline-start-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-inline-start-color-light,
.border-inline-start-color-light-hover:is(:hover, :focus),
.border-inline-start-color-light-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-inline-start-color-light-alt,
.border-inline-start-color-light-alt-hover:is(:hover, :focus),
.border-inline-start-color-light-alt-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-inline-start-color-neutral,
.border-inline-start-color-neutral-hover:is(:hover, :focus),
.border-inline-start-color-neutral-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-inline-start-color-neutral-light,
.border-inline-start-color-neutral-light-hover:is(:hover, :focus),
.border-inline-start-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-inline-start-color-neutral-lighter,
.border-inline-start-color-neutral-lighter-hover:is(:hover, :focus),
.border-inline-start-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-inline-start-color-neutral-lightest,
.border-inline-start-color-neutral-lightest-hover:is(:hover, :focus),
.border-inline-start-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-inline-start-color-neutral-dark,
.border-inline-start-color-neutral-dark-hover:is(:hover, :focus),
.border-inline-start-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-inline-start-color-neutral-darker,
.border-inline-start-color-neutral-darker-hover:is(:hover, :focus),
.border-inline-start-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-inline-start-color-neutral-darkest,
.border-inline-start-color-neutral-darkest-hover:is(:hover, :focus),
.border-inline-start-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-inline-start-color-primary,
.border-inline-start-color-primary-hover:is(:hover, :focus),
.border-inline-start-color-primary-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-inline-start-color-primary-alt,
.border-inline-start-color-primary-alt-hover:is(:hover, :focus),
.border-inline-start-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-inline-start-color-primary-gradient-start,
.border-inline-start-color-primary-gradient-start-hover:is(:hover, :focus),
.border-inline-start-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-inline-start-color-primary-gradient-end,
.border-inline-start-color-primary-gradient-end-hover:is(:hover, :focus),
.border-inline-start-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-inline-start-color-secondary,
.border-inline-start-color-secondary-hover:is(:hover, :focus),
.border-inline-start-color-secondary-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-inline-start-color-secondary-alt,
.border-inline-start-color-secondary-alt-hover:is(:hover, :focus),
.border-inline-start-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-inline-start-color-secondary-gradient-start,
.border-inline-start-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-inline-start-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-inline-start-color-secondary-gradient-end,
.border-inline-start-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-inline-start-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-inline-start-color-accent,
.border-inline-start-color-accent-hover:is(:hover, :focus),
.border-inline-start-color-accent-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-inline-start-color-accent-alt,
.border-inline-start-color-accent-alt-hover:is(:hover, :focus),
.border-inline-start-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-inline-start-color-accent-gradient-start,
.border-inline-start-color-accent-gradient-start-hover:is(:hover, :focus),
.border-inline-start-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-inline-start-color-accent-gradient-end,
.border-inline-start-color-accent-gradient-end-hover:is(:hover, :focus),
.border-inline-start-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-start-color: var(--color-accent-gradient-end);
}

/* border-inline-end-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .border-inline-end-color-inherit,
.border-inline-end-color-inherit-hover:is(:hover, :focus),
.border-inline-end-color-inherit-init:not(:is(:hover, :focus)) {
  border-inline-end-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .border-inline-end-color-transparent,
.border-inline-end-color-transparent-hover:is(:hover, :focus),
.border-inline-end-color-transparent-init:not(:is(:hover, :focus)) {
  border-inline-end-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .border-inline-end-color-currentColor,
.border-inline-end-color-currentColor-hover:is(:hover, :focus),
.border-inline-end-color-currentColor-init:not(:is(:hover, :focus)) {
  border-inline-end-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .border-inline-end-color-dark,
.border-inline-end-color-dark-hover:is(:hover, :focus),
.border-inline-end-color-dark-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .border-inline-end-color-dark-alt,
.border-inline-end-color-dark-alt-hover:is(:hover, :focus),
.border-inline-end-color-dark-alt-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .border-inline-end-color-light,
.border-inline-end-color-light-hover:is(:hover, :focus),
.border-inline-end-color-light-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .border-inline-end-color-light-alt,
.border-inline-end-color-light-alt-hover:is(:hover, :focus),
.border-inline-end-color-light-alt-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .border-inline-end-color-neutral,
.border-inline-end-color-neutral-hover:is(:hover, :focus),
.border-inline-end-color-neutral-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .border-inline-end-color-neutral-light,
.border-inline-end-color-neutral-light-hover:is(:hover, :focus),
.border-inline-end-color-neutral-light-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .border-inline-end-color-neutral-lighter,
.border-inline-end-color-neutral-lighter-hover:is(:hover, :focus),
.border-inline-end-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .border-inline-end-color-neutral-lightest,
.border-inline-end-color-neutral-lightest-hover:is(:hover, :focus),
.border-inline-end-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .border-inline-end-color-neutral-dark,
.border-inline-end-color-neutral-dark-hover:is(:hover, :focus),
.border-inline-end-color-neutral-dark-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .border-inline-end-color-neutral-darker,
.border-inline-end-color-neutral-darker-hover:is(:hover, :focus),
.border-inline-end-color-neutral-darker-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .border-inline-end-color-neutral-darkest,
.border-inline-end-color-neutral-darkest-hover:is(:hover, :focus),
.border-inline-end-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .border-inline-end-color-primary,
.border-inline-end-color-primary-hover:is(:hover, :focus),
.border-inline-end-color-primary-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .border-inline-end-color-primary-alt,
.border-inline-end-color-primary-alt-hover:is(:hover, :focus),
.border-inline-end-color-primary-alt-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .border-inline-end-color-primary-gradient-start,
.border-inline-end-color-primary-gradient-start-hover:is(:hover, :focus),
.border-inline-end-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .border-inline-end-color-primary-gradient-end,
.border-inline-end-color-primary-gradient-end-hover:is(:hover, :focus),
.border-inline-end-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .border-inline-end-color-secondary,
.border-inline-end-color-secondary-hover:is(:hover, :focus),
.border-inline-end-color-secondary-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .border-inline-end-color-secondary-alt,
.border-inline-end-color-secondary-alt-hover:is(:hover, :focus),
.border-inline-end-color-secondary-alt-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .border-inline-end-color-secondary-gradient-start,
.border-inline-end-color-secondary-gradient-start-hover:is(:hover, :focus),
.border-inline-end-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .border-inline-end-color-secondary-gradient-end,
.border-inline-end-color-secondary-gradient-end-hover:is(:hover, :focus),
.border-inline-end-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .border-inline-end-color-accent,
.border-inline-end-color-accent-hover:is(:hover, :focus),
.border-inline-end-color-accent-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .border-inline-end-color-accent-alt,
.border-inline-end-color-accent-alt-hover:is(:hover, :focus),
.border-inline-end-color-accent-alt-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .border-inline-end-color-accent-gradient-start,
.border-inline-end-color-accent-gradient-start-hover:is(:hover, :focus),
.border-inline-end-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .border-inline-end-color-accent-gradient-end,
.border-inline-end-color-accent-gradient-end-hover:is(:hover, :focus),
.border-inline-end-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  border-inline-end-color: var(--color-accent-gradient-end);
}

/* outline-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .outline-color-inherit,
.outline-color-inherit-hover:is(:hover, :focus),
.outline-color-inherit-init:not(:is(:hover, :focus)) {
  outline-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .outline-color-transparent,
.outline-color-transparent-hover:is(:hover, :focus),
.outline-color-transparent-init:not(:is(:hover, :focus)) {
  outline-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .outline-color-currentColor,
.outline-color-currentColor-hover:is(:hover, :focus),
.outline-color-currentColor-init:not(:is(:hover, :focus)) {
  outline-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .outline-color-dark,
.outline-color-dark-hover:is(:hover, :focus),
.outline-color-dark-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .outline-color-dark-alt,
.outline-color-dark-alt-hover:is(:hover, :focus),
.outline-color-dark-alt-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .outline-color-light,
.outline-color-light-hover:is(:hover, :focus),
.outline-color-light-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .outline-color-light-alt,
.outline-color-light-alt-hover:is(:hover, :focus),
.outline-color-light-alt-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .outline-color-neutral,
.outline-color-neutral-hover:is(:hover, :focus),
.outline-color-neutral-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .outline-color-neutral-light,
.outline-color-neutral-light-hover:is(:hover, :focus),
.outline-color-neutral-light-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .outline-color-neutral-lighter,
.outline-color-neutral-lighter-hover:is(:hover, :focus),
.outline-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .outline-color-neutral-lightest,
.outline-color-neutral-lightest-hover:is(:hover, :focus),
.outline-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .outline-color-neutral-dark,
.outline-color-neutral-dark-hover:is(:hover, :focus),
.outline-color-neutral-dark-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .outline-color-neutral-darker,
.outline-color-neutral-darker-hover:is(:hover, :focus),
.outline-color-neutral-darker-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .outline-color-neutral-darkest,
.outline-color-neutral-darkest-hover:is(:hover, :focus),
.outline-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .outline-color-primary,
.outline-color-primary-hover:is(:hover, :focus),
.outline-color-primary-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .outline-color-primary-alt,
.outline-color-primary-alt-hover:is(:hover, :focus),
.outline-color-primary-alt-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .outline-color-primary-gradient-start,
.outline-color-primary-gradient-start-hover:is(:hover, :focus),
.outline-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .outline-color-primary-gradient-end,
.outline-color-primary-gradient-end-hover:is(:hover, :focus),
.outline-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .outline-color-secondary,
.outline-color-secondary-hover:is(:hover, :focus),
.outline-color-secondary-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .outline-color-secondary-alt,
.outline-color-secondary-alt-hover:is(:hover, :focus),
.outline-color-secondary-alt-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .outline-color-secondary-gradient-start,
.outline-color-secondary-gradient-start-hover:is(:hover, :focus),
.outline-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .outline-color-secondary-gradient-end,
.outline-color-secondary-gradient-end-hover:is(:hover, :focus),
.outline-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .outline-color-accent,
.outline-color-accent-hover:is(:hover, :focus),
.outline-color-accent-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .outline-color-accent-alt,
.outline-color-accent-alt-hover:is(:hover, :focus),
.outline-color-accent-alt-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .outline-color-accent-gradient-start,
.outline-color-accent-gradient-start-hover:is(:hover, :focus),
.outline-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .outline-color-accent-gradient-end,
.outline-color-accent-gradient-end-hover:is(:hover, :focus),
.outline-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  outline-color: var(--color-accent-gradient-end);
}

/* fill helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .fill-inherit,
.fill-inherit-hover:is(:hover, :focus),
.fill-inherit-init:not(:is(:hover, :focus)) {
  fill: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .fill-transparent,
.fill-transparent-hover:is(:hover, :focus),
.fill-transparent-init:not(:is(:hover, :focus)) {
  fill: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .fill-currentColor,
.fill-currentColor-hover:is(:hover, :focus),
.fill-currentColor-init:not(:is(:hover, :focus)) {
  fill: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .fill-dark,
.fill-dark-hover:is(:hover, :focus),
.fill-dark-init:not(:is(:hover, :focus)) {
  fill: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .fill-dark-alt,
.fill-dark-alt-hover:is(:hover, :focus),
.fill-dark-alt-init:not(:is(:hover, :focus)) {
  fill: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .fill-light,
.fill-light-hover:is(:hover, :focus),
.fill-light-init:not(:is(:hover, :focus)) {
  fill: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .fill-light-alt,
.fill-light-alt-hover:is(:hover, :focus),
.fill-light-alt-init:not(:is(:hover, :focus)) {
  fill: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .fill-neutral,
.fill-neutral-hover:is(:hover, :focus),
.fill-neutral-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .fill-neutral-light,
.fill-neutral-light-hover:is(:hover, :focus),
.fill-neutral-light-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .fill-neutral-lighter,
.fill-neutral-lighter-hover:is(:hover, :focus),
.fill-neutral-lighter-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .fill-neutral-lightest,
.fill-neutral-lightest-hover:is(:hover, :focus),
.fill-neutral-lightest-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .fill-neutral-dark,
.fill-neutral-dark-hover:is(:hover, :focus),
.fill-neutral-dark-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .fill-neutral-darker,
.fill-neutral-darker-hover:is(:hover, :focus),
.fill-neutral-darker-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .fill-neutral-darkest,
.fill-neutral-darkest-hover:is(:hover, :focus),
.fill-neutral-darkest-init:not(:is(:hover, :focus)) {
  fill: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .fill-primary,
.fill-primary-hover:is(:hover, :focus),
.fill-primary-init:not(:is(:hover, :focus)) {
  fill: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .fill-primary-alt,
.fill-primary-alt-hover:is(:hover, :focus),
.fill-primary-alt-init:not(:is(:hover, :focus)) {
  fill: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .fill-primary-gradient-start,
.fill-primary-gradient-start-hover:is(:hover, :focus),
.fill-primary-gradient-start-init:not(:is(:hover, :focus)) {
  fill: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .fill-primary-gradient-end,
.fill-primary-gradient-end-hover:is(:hover, :focus),
.fill-primary-gradient-end-init:not(:is(:hover, :focus)) {
  fill: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .fill-secondary,
.fill-secondary-hover:is(:hover, :focus),
.fill-secondary-init:not(:is(:hover, :focus)) {
  fill: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .fill-secondary-alt,
.fill-secondary-alt-hover:is(:hover, :focus),
.fill-secondary-alt-init:not(:is(:hover, :focus)) {
  fill: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .fill-secondary-gradient-start,
.fill-secondary-gradient-start-hover:is(:hover, :focus),
.fill-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  fill: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .fill-secondary-gradient-end,
.fill-secondary-gradient-end-hover:is(:hover, :focus),
.fill-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  fill: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .fill-accent,
.fill-accent-hover:is(:hover, :focus),
.fill-accent-init:not(:is(:hover, :focus)) {
  fill: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .fill-accent-alt,
.fill-accent-alt-hover:is(:hover, :focus),
.fill-accent-alt-init:not(:is(:hover, :focus)) {
  fill: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .fill-accent-gradient-start,
.fill-accent-gradient-start-hover:is(:hover, :focus),
.fill-accent-gradient-start-init:not(:is(:hover, :focus)) {
  fill: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .fill-accent-gradient-end,
.fill-accent-gradient-end-hover:is(:hover, :focus),
.fill-accent-gradient-end-init:not(:is(:hover, :focus)) {
  fill: var(--color-accent-gradient-end);
}

/* stroke helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .stroke-inherit,
.stroke-inherit-hover:is(:hover, :focus),
.stroke-inherit-init:not(:is(:hover, :focus)) {
  stroke: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .stroke-transparent,
.stroke-transparent-hover:is(:hover, :focus),
.stroke-transparent-init:not(:is(:hover, :focus)) {
  stroke: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .stroke-currentColor,
.stroke-currentColor-hover:is(:hover, :focus),
.stroke-currentColor-init:not(:is(:hover, :focus)) {
  stroke: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .stroke-dark,
.stroke-dark-hover:is(:hover, :focus),
.stroke-dark-init:not(:is(:hover, :focus)) {
  stroke: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .stroke-dark-alt,
.stroke-dark-alt-hover:is(:hover, :focus),
.stroke-dark-alt-init:not(:is(:hover, :focus)) {
  stroke: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .stroke-light,
.stroke-light-hover:is(:hover, :focus),
.stroke-light-init:not(:is(:hover, :focus)) {
  stroke: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .stroke-light-alt,
.stroke-light-alt-hover:is(:hover, :focus),
.stroke-light-alt-init:not(:is(:hover, :focus)) {
  stroke: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .stroke-neutral,
.stroke-neutral-hover:is(:hover, :focus),
.stroke-neutral-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .stroke-neutral-light,
.stroke-neutral-light-hover:is(:hover, :focus),
.stroke-neutral-light-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .stroke-neutral-lighter,
.stroke-neutral-lighter-hover:is(:hover, :focus),
.stroke-neutral-lighter-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .stroke-neutral-lightest,
.stroke-neutral-lightest-hover:is(:hover, :focus),
.stroke-neutral-lightest-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .stroke-neutral-dark,
.stroke-neutral-dark-hover:is(:hover, :focus),
.stroke-neutral-dark-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .stroke-neutral-darker,
.stroke-neutral-darker-hover:is(:hover, :focus),
.stroke-neutral-darker-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .stroke-neutral-darkest,
.stroke-neutral-darkest-hover:is(:hover, :focus),
.stroke-neutral-darkest-init:not(:is(:hover, :focus)) {
  stroke: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .stroke-primary,
.stroke-primary-hover:is(:hover, :focus),
.stroke-primary-init:not(:is(:hover, :focus)) {
  stroke: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .stroke-primary-alt,
.stroke-primary-alt-hover:is(:hover, :focus),
.stroke-primary-alt-init:not(:is(:hover, :focus)) {
  stroke: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .stroke-primary-gradient-start,
.stroke-primary-gradient-start-hover:is(:hover, :focus),
.stroke-primary-gradient-start-init:not(:is(:hover, :focus)) {
  stroke: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .stroke-primary-gradient-end,
.stroke-primary-gradient-end-hover:is(:hover, :focus),
.stroke-primary-gradient-end-init:not(:is(:hover, :focus)) {
  stroke: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .stroke-secondary,
.stroke-secondary-hover:is(:hover, :focus),
.stroke-secondary-init:not(:is(:hover, :focus)) {
  stroke: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .stroke-secondary-alt,
.stroke-secondary-alt-hover:is(:hover, :focus),
.stroke-secondary-alt-init:not(:is(:hover, :focus)) {
  stroke: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .stroke-secondary-gradient-start,
.stroke-secondary-gradient-start-hover:is(:hover, :focus),
.stroke-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  stroke: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .stroke-secondary-gradient-end,
.stroke-secondary-gradient-end-hover:is(:hover, :focus),
.stroke-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  stroke: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .stroke-accent,
.stroke-accent-hover:is(:hover, :focus),
.stroke-accent-init:not(:is(:hover, :focus)) {
  stroke: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .stroke-accent-alt,
.stroke-accent-alt-hover:is(:hover, :focus),
.stroke-accent-alt-init:not(:is(:hover, :focus)) {
  stroke: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .stroke-accent-gradient-start,
.stroke-accent-gradient-start-hover:is(:hover, :focus),
.stroke-accent-gradient-start-init:not(:is(:hover, :focus)) {
  stroke: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .stroke-accent-gradient-end,
.stroke-accent-gradient-end-hover:is(:hover, :focus),
.stroke-accent-gradient-end-init:not(:is(:hover, :focus)) {
  stroke: var(--color-accent-gradient-end);
}

/* stop-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .stop-color-inherit,
.stop-color-inherit-hover:is(:hover, :focus),
.stop-color-inherit-init:not(:is(:hover, :focus)) {
  stop-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .stop-color-transparent,
.stop-color-transparent-hover:is(:hover, :focus),
.stop-color-transparent-init:not(:is(:hover, :focus)) {
  stop-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .stop-color-currentColor,
.stop-color-currentColor-hover:is(:hover, :focus),
.stop-color-currentColor-init:not(:is(:hover, :focus)) {
  stop-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .stop-color-dark,
.stop-color-dark-hover:is(:hover, :focus),
.stop-color-dark-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .stop-color-dark-alt,
.stop-color-dark-alt-hover:is(:hover, :focus),
.stop-color-dark-alt-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .stop-color-light,
.stop-color-light-hover:is(:hover, :focus),
.stop-color-light-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .stop-color-light-alt,
.stop-color-light-alt-hover:is(:hover, :focus),
.stop-color-light-alt-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .stop-color-neutral,
.stop-color-neutral-hover:is(:hover, :focus),
.stop-color-neutral-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .stop-color-neutral-light,
.stop-color-neutral-light-hover:is(:hover, :focus),
.stop-color-neutral-light-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .stop-color-neutral-lighter,
.stop-color-neutral-lighter-hover:is(:hover, :focus),
.stop-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .stop-color-neutral-lightest,
.stop-color-neutral-lightest-hover:is(:hover, :focus),
.stop-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .stop-color-neutral-dark,
.stop-color-neutral-dark-hover:is(:hover, :focus),
.stop-color-neutral-dark-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .stop-color-neutral-darker,
.stop-color-neutral-darker-hover:is(:hover, :focus),
.stop-color-neutral-darker-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .stop-color-neutral-darkest,
.stop-color-neutral-darkest-hover:is(:hover, :focus),
.stop-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .stop-color-primary,
.stop-color-primary-hover:is(:hover, :focus),
.stop-color-primary-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .stop-color-primary-alt,
.stop-color-primary-alt-hover:is(:hover, :focus),
.stop-color-primary-alt-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .stop-color-primary-gradient-start,
.stop-color-primary-gradient-start-hover:is(:hover, :focus),
.stop-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .stop-color-primary-gradient-end,
.stop-color-primary-gradient-end-hover:is(:hover, :focus),
.stop-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .stop-color-secondary,
.stop-color-secondary-hover:is(:hover, :focus),
.stop-color-secondary-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .stop-color-secondary-alt,
.stop-color-secondary-alt-hover:is(:hover, :focus),
.stop-color-secondary-alt-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .stop-color-secondary-gradient-start,
.stop-color-secondary-gradient-start-hover:is(:hover, :focus),
.stop-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .stop-color-secondary-gradient-end,
.stop-color-secondary-gradient-end-hover:is(:hover, :focus),
.stop-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .stop-color-accent,
.stop-color-accent-hover:is(:hover, :focus),
.stop-color-accent-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .stop-color-accent-alt,
.stop-color-accent-alt-hover:is(:hover, :focus),
.stop-color-accent-alt-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .stop-color-accent-gradient-start,
.stop-color-accent-gradient-start-hover:is(:hover, :focus),
.stop-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .stop-color-accent-gradient-end,
.stop-color-accent-gradient-end-hover:is(:hover, :focus),
.stop-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  stop-color: var(--color-accent-gradient-end);
}

/* flood-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .flood-color-inherit,
.flood-color-inherit-hover:is(:hover, :focus),
.flood-color-inherit-init:not(:is(:hover, :focus)) {
  flood-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .flood-color-transparent,
.flood-color-transparent-hover:is(:hover, :focus),
.flood-color-transparent-init:not(:is(:hover, :focus)) {
  flood-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .flood-color-currentColor,
.flood-color-currentColor-hover:is(:hover, :focus),
.flood-color-currentColor-init:not(:is(:hover, :focus)) {
  flood-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .flood-color-dark,
.flood-color-dark-hover:is(:hover, :focus),
.flood-color-dark-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .flood-color-dark-alt,
.flood-color-dark-alt-hover:is(:hover, :focus),
.flood-color-dark-alt-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .flood-color-light,
.flood-color-light-hover:is(:hover, :focus),
.flood-color-light-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .flood-color-light-alt,
.flood-color-light-alt-hover:is(:hover, :focus),
.flood-color-light-alt-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .flood-color-neutral,
.flood-color-neutral-hover:is(:hover, :focus),
.flood-color-neutral-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .flood-color-neutral-light,
.flood-color-neutral-light-hover:is(:hover, :focus),
.flood-color-neutral-light-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .flood-color-neutral-lighter,
.flood-color-neutral-lighter-hover:is(:hover, :focus),
.flood-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .flood-color-neutral-lightest,
.flood-color-neutral-lightest-hover:is(:hover, :focus),
.flood-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .flood-color-neutral-dark,
.flood-color-neutral-dark-hover:is(:hover, :focus),
.flood-color-neutral-dark-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .flood-color-neutral-darker,
.flood-color-neutral-darker-hover:is(:hover, :focus),
.flood-color-neutral-darker-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .flood-color-neutral-darkest,
.flood-color-neutral-darkest-hover:is(:hover, :focus),
.flood-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .flood-color-primary,
.flood-color-primary-hover:is(:hover, :focus),
.flood-color-primary-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .flood-color-primary-alt,
.flood-color-primary-alt-hover:is(:hover, :focus),
.flood-color-primary-alt-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .flood-color-primary-gradient-start,
.flood-color-primary-gradient-start-hover:is(:hover, :focus),
.flood-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .flood-color-primary-gradient-end,
.flood-color-primary-gradient-end-hover:is(:hover, :focus),
.flood-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .flood-color-secondary,
.flood-color-secondary-hover:is(:hover, :focus),
.flood-color-secondary-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .flood-color-secondary-alt,
.flood-color-secondary-alt-hover:is(:hover, :focus),
.flood-color-secondary-alt-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .flood-color-secondary-gradient-start,
.flood-color-secondary-gradient-start-hover:is(:hover, :focus),
.flood-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .flood-color-secondary-gradient-end,
.flood-color-secondary-gradient-end-hover:is(:hover, :focus),
.flood-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .flood-color-accent,
.flood-color-accent-hover:is(:hover, :focus),
.flood-color-accent-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .flood-color-accent-alt,
.flood-color-accent-alt-hover:is(:hover, :focus),
.flood-color-accent-alt-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .flood-color-accent-gradient-start,
.flood-color-accent-gradient-start-hover:is(:hover, :focus),
.flood-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .flood-color-accent-gradient-end,
.flood-color-accent-gradient-end-hover:is(:hover, :focus),
.flood-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  flood-color: var(--color-accent-gradient-end);
}

/* lighting-color helpers
--------------------------------------------------------------- */
:where(.content-palette-dark) .color-inherit-ondark, .lighting-color-inherit,
.lighting-color-inherit-hover:is(:hover, :focus),
.lighting-color-inherit-init:not(:is(:hover, :focus)) {
  lighting-color: inherit;
}

:where(.content-palette-dark) .color-transparent-ondark, .lighting-color-transparent,
.lighting-color-transparent-hover:is(:hover, :focus),
.lighting-color-transparent-init:not(:is(:hover, :focus)) {
  lighting-color: transparent;
}

:where(.content-palette-dark) .color-currentColor-ondark, .lighting-color-currentColor,
.lighting-color-currentColor-hover:is(:hover, :focus),
.lighting-color-currentColor-init:not(:is(:hover, :focus)) {
  lighting-color: currentColor;
}

:where(.content-palette-dark) .color-dark-ondark, .lighting-color-dark,
.lighting-color-dark-hover:is(:hover, :focus),
.lighting-color-dark-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-dark);
}

:where(.content-palette-dark) .color-dark-alt-ondark, .lighting-color-dark-alt,
.lighting-color-dark-alt-hover:is(:hover, :focus),
.lighting-color-dark-alt-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-dark-alt);
}

:where(.content-palette-dark) .color-light-ondark, .lighting-color-light,
.lighting-color-light-hover:is(:hover, :focus),
.lighting-color-light-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-light);
}

:where(.content-palette-dark) .color-light-alt-ondark, .lighting-color-light-alt,
.lighting-color-light-alt-hover:is(:hover, :focus),
.lighting-color-light-alt-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-light-alt);
}

:where(.content-palette-dark) .color-neutral-ondark, .lighting-color-neutral,
.lighting-color-neutral-hover:is(:hover, :focus),
.lighting-color-neutral-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral);
}

:where(.content-palette-dark) .color-neutral-light-ondark, .lighting-color-neutral-light,
.lighting-color-neutral-light-hover:is(:hover, :focus),
.lighting-color-neutral-light-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-light);
}

:where(.content-palette-dark) .color-neutral-lighter-ondark, .lighting-color-neutral-lighter,
.lighting-color-neutral-lighter-hover:is(:hover, :focus),
.lighting-color-neutral-lighter-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-lighter);
}

:where(.content-palette-dark) .color-neutral-lightest-ondark, .lighting-color-neutral-lightest,
.lighting-color-neutral-lightest-hover:is(:hover, :focus),
.lighting-color-neutral-lightest-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-lightest);
}

:where(.content-palette-dark) .color-neutral-dark-ondark, .lighting-color-neutral-dark,
.lighting-color-neutral-dark-hover:is(:hover, :focus),
.lighting-color-neutral-dark-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-dark);
}

:where(.content-palette-dark) .color-neutral-darker-ondark, .lighting-color-neutral-darker,
.lighting-color-neutral-darker-hover:is(:hover, :focus),
.lighting-color-neutral-darker-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-darker);
}

:where(.content-palette-dark) .color-neutral-darkest-ondark, .lighting-color-neutral-darkest,
.lighting-color-neutral-darkest-hover:is(:hover, :focus),
.lighting-color-neutral-darkest-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-neutral-darkest);
}

:where(.content-palette-dark) .color-primary-ondark, .lighting-color-primary,
.lighting-color-primary-hover:is(:hover, :focus),
.lighting-color-primary-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-primary);
}

:where(.content-palette-dark) .color-primary-alt-ondark, .lighting-color-primary-alt,
.lighting-color-primary-alt-hover:is(:hover, :focus),
.lighting-color-primary-alt-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-primary-alt);
}

:where(.content-palette-dark) .color-primary-gradient-start-ondark, .lighting-color-primary-gradient-start,
.lighting-color-primary-gradient-start-hover:is(:hover, :focus),
.lighting-color-primary-gradient-start-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-primary-gradient-start);
}

:where(.content-palette-dark) .color-primary-gradient-end-ondark, .lighting-color-primary-gradient-end,
.lighting-color-primary-gradient-end-hover:is(:hover, :focus),
.lighting-color-primary-gradient-end-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-primary-gradient-end);
}

:where(.content-palette-dark) .color-secondary-ondark, .lighting-color-secondary,
.lighting-color-secondary-hover:is(:hover, :focus),
.lighting-color-secondary-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-secondary);
}

:where(.content-palette-dark) .color-secondary-alt-ondark, .lighting-color-secondary-alt,
.lighting-color-secondary-alt-hover:is(:hover, :focus),
.lighting-color-secondary-alt-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-secondary-alt);
}

:where(.content-palette-dark) .color-secondary-gradient-start-ondark, .lighting-color-secondary-gradient-start,
.lighting-color-secondary-gradient-start-hover:is(:hover, :focus),
.lighting-color-secondary-gradient-start-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-secondary-gradient-start);
}

:where(.content-palette-dark) .color-secondary-gradient-end-ondark, .lighting-color-secondary-gradient-end,
.lighting-color-secondary-gradient-end-hover:is(:hover, :focus),
.lighting-color-secondary-gradient-end-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-secondary-gradient-end);
}

:where(.content-palette-dark) .color-accent-ondark, .lighting-color-accent,
.lighting-color-accent-hover:is(:hover, :focus),
.lighting-color-accent-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-accent);
}

:where(.content-palette-dark) .color-accent-alt-ondark, .lighting-color-accent-alt,
.lighting-color-accent-alt-hover:is(:hover, :focus),
.lighting-color-accent-alt-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-accent-alt);
}

:where(.content-palette-dark) .color-accent-gradient-start-ondark, .lighting-color-accent-gradient-start,
.lighting-color-accent-gradient-start-hover:is(:hover, :focus),
.lighting-color-accent-gradient-start-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-accent-gradient-start);
}

:where(.content-palette-dark) .color-accent-gradient-end-ondark, .lighting-color-accent-gradient-end,
.lighting-color-accent-gradient-end-hover:is(:hover, :focus),
.lighting-color-accent-gradient-end-init:not(:is(:hover, :focus)) {
  lighting-color: var(--color-accent-gradient-end);
}

/* ================================================================================
* Global Critical Components - UI/ Build Elements These need edits based on the design
================================================================================ */
/* Accordion: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/accordion.md#accordion
--------------------------------------------------------------- */
/* .accordion Skeletons. Do Not Edit */
.accordion:not(.open) {
  display: none;
}

/* .accordion-toggle Skeletons */
.accordion-trigger {
  cursor: pointer;
}
.accordion-trigger > * {
  pointer-events: none;
}

/* Accordion: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/accordion.md#accordion
--------------------------------------------------------------- */
/* there should be no need to add customizations to this class, but just in case */
.list:has(.accordion) {
  padding: 1.875rem 2.5rem;
  background: var(--color-neutral-lightest);
  border: 6px solid var(--color-neutral-lighter);
  border-radius: var(--global-radius);
  margin-block: 1.5rem;
}
.list:has(.accordion) .list-title {
  padding-block: 0 !important;
  margin-block: 0 !important;
  color: var(--color-accent);
  font-size: 1.3125rem;
}
.list:has(.accordion) .list-title:is(.open) {
  -webkit-margin-after: 0.9375rem !important;
          margin-block-end: 0.9375rem !important;
}
.list:has(.accordion) .list-items {
  padding-block: 0 !important;
}
.list:has(.accordion) .list-item-el :last-child {
  -webkit-margin-after: 0 !important;
          margin-block-end: 0 !important;
}

/* Accordion: Toggle  https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/accordion.md#data-toggle-accordion
--------------------------------------------------------------- */
.accordion-trigger {
  cursor: pointer;
  justify-content: space-between;
  display: flex;
}
.accordion-trigger::after {
  display: inline-block;
  align-self: center;
  flex: 0 0 auto;
  content: "\25BC\FE0E";
  content: "+";
  line-height: 0.5;
  font-weight: 100;
  font-size: 3rem;
  color: var(--color-primary);
}
.accordion-trigger.open {
  color: var(--color-primary);
}
.accordion-trigger.open::after {
  content: "\2013\FE0E";
}

/* Buttons: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/button.md#button
--------------------------------------------------------------- */
/* .button Skeletons. Do Not Edit */
.button {
  border: var(--button-border-width, 1px) solid;
  padding-inline: var(--button-padding-x, 1em);
  padding-block: calc(var(--button-padding-y, calc((var(--button-height, 4em) - var(--button-border-width, 2px) * 2 - 1em * var(--button-lines, 1) * var(--button-line-height, 1.25)) * 0.5)) - var(--button-border-width, 1px));
  line-height: var(--button-line-height, 1.5);
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  max-inline-size: 100%;
  background: none;
  text-align: center;
  transition: all 0.125s ease-in-out;
  border-radius: var(--button-border-radius, 0px);
}
.button:is(.button-style-legacy) {
  min-block-size: var(--button-height, 3em);
  padding-inline: calc(var(--button-padding-x, 1em) - var(--button-border-width, 1px));
  padding-block: calc((var(--button-height) - var(--button-border-width, 1px) * 2 - 1em * var(--button-lines) * var(--button-line-height)) * var(--button-baseline-offset)) calc((var(--button-height) - var(--button-border-width, 1px) * 2 - 1em * var(--button-lines) * var(--button-line-height)) * (1 - var(--button-baseline-offset)));
}
.button {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
  gap: 0.25em;
  background-clip: border-box;
  background-origin: border-box;
}
.button, .button:is(:hover, :focus) {
  text-decoration: none;
}

/* Buttons: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/buttons.md
--------------------------------------------------------------- */
/* Button Customizations: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/buttons.md#css-vars 
--------------------------------------------------------------- */
.button {
  --button-border-width: 0px;
  /* border width. This will be accounted for in calculating the button height as well */
  --button-border-radius: 10px;
  /* button radius */
  --button-padding-x: 1em;
  /* horizontal padding */
  --button-padding-y: .625em;
  /* vertical padding */
  --button-line-height: 1.25;
  /* line height
  * Usually there's no need to modify this unless a multiline button is present in the design and has a line height drastically different to what is set (currently 1.125).
  * NOTE: this value has to be unitless for calc values to work.
  * Formula is line-height-px / font-size-px 
  * font-size 16px and line-height at 20px
  * 20/16 = 1.25 (Note: Unitless value) */
  font-size: 1.125rem;
  line-height: var(--button-line-height);
  font-family: var(--font-primary);
  color: var(--color-primary);
  font-style: normal;
  font-weight: 700;
  text-decoration: none;
  min-inline-size: 12ch;
  gap: 0.5em;
}
/* Buttons Sizing Helpers: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/button.md#button-size-name
--------------------------------------------------------------- */
/* button w/ a height even more smaller than the default height */
.button.button-size-micro {
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 800;
  --button-padding-y: .57em;
  --button-padding-x: 1.25em;
  --button-border-width: 2px;
}
/* button w/ a height even more smaller than the default height */
.button.button-size-nano {
  font-size: 0.8125rem;
  text-transform: uppercase;
  font-weight: 800;
  --button-padding-y: .375em;
  --button-padding-x: .75em;
  --button-border-width: 2px;
}
/* button w/ a height smaller than the default height */
.button.button-size-small {
  font-size: 0.875rem;
  text-transform: uppercase;
  font-weight: 800;
  --button-padding-y: .875em;
  --button-border-width: 2px;
  --button-padding-x: 1.5em;
}
/* button w/ a height slightly larger than the default height but it's not that big */
.button.button-size-medium {
  font-size: 1.0625rem;
  text-transform: uppercase;
  font-weight: 800;
  --button-padding-y: 0.875rem;
  --button-border-width: 2px;
}
.button.button-size-medium:is(.button-size-equal) {
  --button-height: 3.25em;
}
/* button w/ a height larger than the default height */
.button.button-size-large {
  font-size: 1.25rem;
  text-transform: uppercase;
  font-weight: 800;
  --button-padding-y: 0.875rem;
  --button-border-width: 3px;
}
/* button w/ a height that's even larger for no reason than the larger height */
.button.button-size-larger {
  font-size: 1.25rem;
  --button-padding-y: 1.75em;
}
/* constricts the width equal to whatever size height is set*/
.button.button-size-equal {
  --button-padding-x: var(--button-padding-y);
  min-inline-size: 0;
  inline-size: var(--button-height, auto);
  aspect-ratio: 1/1;
  text-overflow: ellipsis;
  overflow: hidden;
}
.button.button-size-equal.button-size-large {
  --button-padding-y: .875em;
}
.button.button-size-equal .button-glyph {
  font-size: 0.72em;
}

/* Buttons Color Palette Helpers: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/button.md#button-palette-name
--------------------------------------------------------------- */
/* 
* Default - most frequent button palette in the comps
* Invert - reuses default's colors but palettes for hover vs not hover are reversed
* Outline - text w/ border influencing text color
* Minimal - no colors except for the text
Adjust as needed.
*/
.button:has(.button-glyph-elesi) {
  position: relative;
  padding-inline: calc(var(--button-padding-x) + 1em + 0.5em) var(--button-padding-x);
  transition: all 0.5s ease-in-out;
}
.button:has(.button-glyph-elesi) i.button-glyph-elesi {
  position: absolute;
  margin: auto;
  inset-block: 0;
  inset-inline-start: var(--button-padding-x);
  transition: all 0.5s ease-in-out;
}
.button:has(.button-glyph-elesi):is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *) {
  padding-inline: var(--button-padding-x) calc(var(--button-padding-x) + 1em + 0.5em);
}
.button:has(.button-glyph-elesi):is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *) i.button-glyph-elesi {
  inset-inline-start: calc(100% - (var(--button-padding-x) + 1em));
}
.button.button-palette-default, .button.button-palette-reverse:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover) {
  background-color: var(--color-primary);
  color: var(--color-light);
  border-color: var(--color-secondary);
}
.button.button-palette-default:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover), .button.button-palette-reverse {
  background-color: var(--color-secondary);
  color: var(--color-light);
  border-color: var(--color-secondary);
}
.button.button-palette-outline-secondary {
  background-color: transparent;
  color: currentColor;
  border-color: var(--color-secondary);
}
.button.button-palette-secondary, .button.button-palette-secondary-reverse:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover) {
  background-color: var(--color-secondary);
  color: var(--color-dark);
  border-color: var(--color-light);
}
.button.button-palette-outline-secondary:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover), .button.button-palette-secondary:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover), .button.button-palette-secondary-reverse {
  background-color: var(--color-light);
  color: var(--color-dark);
  border-color: var(--color-light);
}
.button.button-palette-accent {
  background-color: var(--color-accent-alt);
  color: var(--color-dark);
  border-color: transparent;
}
.button.button-palette-secondary-dark, .button.button-palette-secondary-dark-reverse:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover) {
  background-color: var(--color-secondary);
  color: var(--color-dark);
  border-color: var(--color-dark);
}
.button.button-palette-secondary-dark:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover), .button.button-palette-secondary-dark-reverse {
  background-color: var(--color-light);
  color: var(--color-dark);
  border-color: var(--color-dark);
}
.button.button-palette-secondary-secondary, .button.button-palette-secondary-secondary-reverse:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover) {
  background-color: var(--color-secondary);
  color: var(--color-dark);
  border-color: var(--color-secondary);
}
.button.button-palette-secondary-secondary:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover), .button.button-palette-secondary-secondary-reverse {
  background-color: var(--color-light);
  color: var(--color-dark);
  border-color: var(--color-secondary);
}
.button.button-palette-outline {
  background-color: transparent;
  color: var(--color-dark-alt);
  border-color: var(--color-accent);
}
:where(.content-palette-dark) .button.button-palette-outline,
.button.button-palette-outline-permanent-onDark {
  background-color: transparent;
  color: var(--color-accent-alt);
  border-color: var(--color-accent-alt);
}

.button.button-palette-outline:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover) {
  background-color: var(--color-accent);
  color: var(--color-light);
  border-color: transparent;
}
:where(.content-palette-dark) .button.button-palette-outline:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *):not(.button-style-no-hover),
.button.button-palette-outline-permanent-onDark:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *) {
  background-color: var(--color-accent-alt);
  color: var(--color-light);
  border-color: transparent;
}

/*
primary palette. adjust or omit as needed
* Tip: if both a flat and gradient version of the palette exists in the design, adding the class .button-style-flat to this .button-palette-* class will disable the gradient
*/
/*
secondary palette. adjust or omit as needed
* Tip: if both a flat and gradient version of the palette exists in the design, adding the class .button-style-flat to this .button-palette-* class will disable the gradient
*/
/*
accent palette. adjust or omit as needed
* Tip: if both a flat and gradient version of the palette exists in the design, adding the class .button-style-flat to this .button-palette-* class will disable the gradient
*/
/* Other Buttons Variations Helpers: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/button.md#button-style-name
--------------------------------------------------------------- */
/* link style legacy. for the old weirs we styled the button */
/* link style button. Usually the maps link or read more text for blog posts */
.button.button-style-link {
  --button-border-width: 2px;
  border-radius: 0;
  padding: 0 0 0.5em;
  border-inline-width: 0;
  border-block-width: 0 var(--button-border-width);
  min-block-size: 0;
  background: none;
  box-shadow: none;
  min-block-size: 0;
  min-inline-size: 0;
  color: inherit;
  letter-spacing: 0em;
  text-transform: none;
}
.button.button-style-link:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *) {
  background: none;
  border-color: var(--color-primary);
}

/* undo background gradients in favor for the flat background color for button-palette. will only work if backgrounds are setup with proper fallbacks (background-gradient with a background-color fallback) */
.button.button-style-flat, .button.button-style-flat:is(:hover, :focus, .button-pointer-reference:is(:hover, :focus) *) {
  background-image: none;
}

/* remove radius */
.button.button-style-no-radius {
  --button-border-radius: 0;
}

/* no corners for the button. only soft bbies */
.button.button-style-round {
  --button-border-radius: 999em;
}

/* very corners for the button. only pointy bbies */
.button.button-style-sharp {
  --button-border-radius: 0em;
}

/* button styles that have thicker borders than usual */
.button.button-style-thick-border {
  --button-border-width: 4px;
}

/* button styles that have thicker borders than usual */
.button.button-style-thin-border {
  --button-border-width: 1px;
}

/* button styles that have thicker borders than usual */
.button.button-style-no-border {
  --button-border-width: 0px;
}

/* diamond buttons. best if paired with .button-size-equal */
@supports ((-webkit-clip-path: polygon(0 0, 0 0, 0 0, 0 0)) or (clip-path: polygon(0 0, 0 0, 0 0, 0 0))) {
  .button.button-style-diamond {
    overflow: hidden;
    -webkit-clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
            clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
  }
}

/* if the slider buttons have unique overrides */
.button.button-style-slider.button-palette-minimal {
  --button-height: 2.5em;
  --button-padding-x: 0.4em;
}
/* Misc Button stuff. Add as needed
--------------------------------------------------------------- */
/* Glyph stuff. little arrow indicator for slider arrows: .button.button-size-equal.button-palette-default > i.button-slider-glyph */
.button-glyph:empty {
  align-self: center;
  display: flex;
  max-height: -webkit-max-content;
  max-height: -moz-max-content;
  max-height: max-content;
  transition: 0.25s ease-in-out all;
  will-change: order;
}
.button-glyph:empty::after {
  display: inline-block;
  order: 9;
  align-self: center;
  transform-origin: center center;
  /* slider glyph border arrow styles */
  content: "";
  width: 1em;
  height: 1em;
  flex: 0 0 auto;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center center;
          mask-position: center center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
}
.doc-images-loaded .button-glyph-arrow:empty::after {
  -webkit-mask-image: var(--icon-arrow);
          mask-image: var(--icon-arrow);
  background-color: currentColor;
}
:is(.prev, [rel=prev], .slick-prev, .swpier-button-prev) .button-glyph-arrow:empty {
  transform: scaleX(-1) rotate(90deg);
}

:is(.prev, [rel=prev], .slick-prev, .swpier-button-prev) .button-glyph-arrow {
  transform: scaleX(-1);
}

.doc-images-loaded .button-glyph-elesi:empty::after {
  -webkit-mask-image: var(--icon-elesi);
          mask-image: var(--icon-elesi);
  background-color: currentColor;
}
.doc-images-loaded .button-glyph-clock:empty::after {
  -webkit-mask-image: var(--icon-clock);
          mask-image: var(--icon-clock);
  background-color: currentColor;
}
.button-glyph-slider:empty::after {
  border: 2px solid currentColor;
  border-top: 0;
  border-left: 0;
  transform: rotate(-45deg);
  -webkit-margin-start: -0.375em;
          margin-inline-start: -0.375em;
}
:is(.prev, [rel=prev], .slick-prev, .swpier-button-prev) .button-glyph-slider {
  transform: scaleX(-1);
}

/* Columns: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/columns.md#columns
--------------------------------------------------------------- */
/* .columns Skeletons. Do Not Edit */
.columns {
  inline-size: 100%;
}
.columns,
.columns > :where(*) {
  min-inline-size: 0;
  max-inline-size: 100%;
  inline-size: 100%;
}
.columns:where(.columns-flex) {
  display: flex;
  flex-wrap: wrap;
  row-gap: var(--columns-gap-y, var(--column-gap, 0rem));
  -moz-column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
       column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
}
.columns:where(.columns-flex) > :where(*) {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: calc(100% / var(--columns-number, 1) - var(--columns-gap-x) * (var(--columns-number, 1) - 1) / var(--columns-number, 1));
}
.columns:where(.columns-grid) {
  display: grid;
  row-gap: var(--columns-gap-y, var(--column-gap, 0rem));
  -moz-column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
       column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
  grid-template-columns: repeat(var(--columns-number, 1), minmax(0, 1fr));
}
.columns.columns-masonry {
  -moz-column-count: var(--columns-number, 1);
       column-count: var(--columns-number, 1);
  -webkit-column-count: var(--columns-number, 1);
  -moz-column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
       column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
  -webkit-column-gap: var(--columns-gap-x, var(--column-gap, 0rem));
}
.columns.columns-masonry > :where(*) {
  page-break-inside: avoid;
  -moz-column-break-inside: avoid;
       break-inside: avoid;
}
.columns.columns-masonry > :where(*):nth-child(n+2) {
  -webkit-margin-before: var(--columns-gap-y, var(--column-gap, 0rem));
          margin-block-start: var(--columns-gap-y, var(--column-gap, 0rem));
}

/* Columns: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/columns.md
--------------------------------------------------------------- */
/* Column Customizations
Vars: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/columns.md#css-vars
--------------------------------------------------------------- */
.columns {
  --columns-gap: 0rem;
  /* distance between columns both horizontally and vertically. if different gaps are desired, set the variables below instead */
  --columns-gap-x: var(--columns-gap);
  /* distance between columns horizontally */
  --columns-gap-y: var(--columns-gap);
  /* distance between columns vertically */
  --columns-number: 1;
  /* Number of columns desired for the layout */
}

/* Group: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/section.md
Figma Autolayout grouping helper classes. Uses grid by default.
TODO. document whatever is going on here
--------------------------------------------------------------- */
/* Group: Skeletons/barebones. no need to edit
--------------------------------------------------------------- */
/* .group-frame and .group-module - Section blocks / grid scaffolding */
.group-frame {
  display: grid;
  grid-template-columns: 100%;
  grid-auto-flow: dense;
  inline-size: 100%;
  gap: 2rem;
}

/* .group-frame and .group-module - Section blocks / grid scaffolding */
.group-frame, .group-module {
  min-inline-size: 0;
  min-block-size: 0;
}

/* .group- universal helpers
--------------------------------------------------------------- */
/* .group-style-maxed - dont let stuff grow too wide or beyond available width */
.group-style-maxed:is(.group-frame) {
  /* if placed on group-frame, the frame will only grow based on max width of its contents available */
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  justify-self: center;
  margin-inline: auto;
}
.group-style-maxed:is(.group-module, :has(.group-frame > .group-module)) {
  /* if child of group-frame or placed on group-module, the frame will only grow based on the group-frame's available width */
  max-inline-size: 100%;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-style-maxed-sm:is(.group-frame) {
    max-inline-size: -webkit-max-content;
    max-inline-size: -moz-max-content;
    max-inline-size: max-content;
    justify-self: center;
  }
  .group-style-maxed-sm:is(.group-module, :has(.group-frame > .group-module)) {
    max-inline-size: 100%;
  }
}
@media only screen and (min-width: 75rem) {
  .group-style-maxed-nontouch:is(.group-frame) {
    max-inline-size: -webkit-max-content;
    max-inline-size: -moz-max-content;
    max-inline-size: max-content;
    justify-self: center;
  }
  .group-style-maxed-nontouch:is(.group-module, :has(.group-frame > .group-module)) {
    max-inline-size: 100%;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-style-maxed-touch:is(.group-frame) {
    max-inline-size: -webkit-max-content;
    max-inline-size: -moz-max-content;
    max-inline-size: max-content;
    justify-self: center;
  }
  .group-style-maxed-touch:is(.group-module, :has(.group-frame > .group-module)) {
    max-inline-size: 100%;
  }
}
/* .group-style-bypass - make an element within the group-frame be ignored as a group-frame child */
.group-frame .group-style-bypass {
  display: contents !important;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-frame .group-style-bypass-sm {
    display: contents !important;
  }
}
@media only screen and (min-width: 75rem) {
  .group-frame .group-style-bypass-nontouch {
    display: contents !important;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  .group-frame .group-style-bypass-md {
    display: contents !important;
  }
}
@media only screen and (min-width: 87.5rem) and (max-width: 119.9375rem) {
  .group-frame .group-style-bypass-lg {
    display: contents !important;
  }
}
@media only screen and (min-width: 120rem) and (max-width: 179.9375rem) {
  .group-frame .group-style-bypass-xl {
    display: contents !important;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-frame .group-style-bypass-touch {
    display: contents !important;
  }
}
/* .group-center-inline - center though the inline axis */
/* todo apply to layouts like banner.. ooo especially banner */
.group-align-center-inline {
  text-align: center;
}
.group-align-center-inline:is(.group-frame) {
  /* if placed on group-frame, all items inside will be justified center */
  justify-items: center;
  justify-content: center;
}
.group-align-center-inline:is(.group-module, :has(.group-frame > .group-module)) {
  /* if placed on group-module, only this item will be centered */
  justify-self: center;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-align-center-inline-sm {
    text-align: center;
  }
  .group-align-center-inline-sm:is(.group-frame) {
    justify-items: center;
    justify-content: center;
  }
  .group-align-center-inline-sm:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: center;
  }
}
@media only screen and (min-width: 75rem) {
  .group-align-center-inline-nontouch {
    text-align: center;
  }
  .group-align-center-inline-nontouch:is(.group-frame) {
    justify-items: center;
    justify-content: center;
  }
  .group-align-center-inline-nontouch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: center;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-align-center-inline-touch {
    text-align: center;
  }
  .group-align-center-inline-touch:is(.group-frame) {
    justify-items: center;
    justify-content: center;
  }
  .group-align-center-inline-touch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: center;
  }
}
/* .group-end-inline - align to end though the inline axis */
/* todo apply to layouts like banner.. ooo especially banner */
.group-align-end-inline:is(.group-frame) {
  /* if placed on group-frame, all items inside will be justified center */
  justify-items: end;
  justify-content: end;
}
.group-align-end-inline:is(.group-module, :has(.group-frame > .group-module)) {
  /* if placed on group-module, only this item will be ended */
  justify-self: self-end;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-align-end-inline-sm:is(.group-frame) {
    justify-items: end;
    justify-content: end;
  }
  .group-align-end-inline-sm:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-end;
  }
}
@media only screen and (min-width: 75rem) {
  .group-align-end-inline-nontouch:is(.group-frame) {
    justify-items: end;
    justify-content: end;
  }
  .group-align-end-inline-nontouch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-end;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-align-end-inline-touch:is(.group-frame) {
    justify-items: end;
    justify-content: end;
  }
  .group-align-end-inline-touch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-end;
  }
}
/* .group-start-inline - align to end though the inline axis */
/* todo apply to layouts like banner.. ooo especially banner */
.group-align-start-inline:is(.group-frame) {
  /* if placed on group-frame, all items inside will be justified center */
  justify-items: start;
  justify-content: start;
}
.group-align-start-inline:is(.group-module, :has(.group-frame > .group-module)) {
  /* if placed on group-module, only this item will be started */
  justify-self: self-start;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-align-start-inline-sm:is(.group-frame) {
    justify-items: start;
    justify-content: start;
  }
  .group-align-start-inline-sm:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-start;
  }
}
@media only screen and (min-width: 75rem) {
  .group-align-start-inline-nontouch:is(.group-frame) {
    justify-items: start;
    justify-content: start;
  }
  .group-align-start-inline-nontouch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-start;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-align-start-inline-touch:is(.group-frame) {
    justify-items: start;
    justify-content: start;
  }
  .group-align-start-inline-touch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: self-start;
  }
}
/* .group-stretch-inline - align to end though the inline axis */
/* todo apply to layouts like banner.. ooo especially banner */
.group-align-stretch-inline:is(.group-frame) {
  /* if placed on group-frame, all items inside will be justified center */
  justify-items: stretch;
  justify-content: stretch;
}
.group-align-stretch-inline:is(.group-module, :has(.group-frame > .group-module)) {
  /* if placed on group-module, only this item will be stretched */
  justify-self: stretch;
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-align-stretch-inline-sm:is(.group-frame) {
    justify-items: stretch;
    justify-content: stretch;
  }
  .group-align-stretch-inline-sm:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: stretch;
  }
}
@media only screen and (min-width: 75rem) {
  .group-align-stretch-inline-nontouch:is(.group-frame) {
    justify-items: stretch;
    justify-content: stretch;
  }
  .group-align-stretch-inline-nontouch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: stretch;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-align-stretch-inline-touch:is(.group-frame) {
    justify-items: stretch;
    justify-content: stretch;
  }
  .group-align-stretch-inline-touch:is(.group-module, :has(.group-frame > .group-module)) {
    justify-self: stretch;
  }
}
/* .group-module helpers
--------------------------------------------------------------- */
/* .group-module-style-stretch - stretch to full column. or if it's just the only child */
.group-module-style-stretch,
:where(.group-module:only-child) {
  grid-column: 1/-1;
}

@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .group-module-style-stretch-sm {
    grid-column: 1/-1;
  }
}
@media only screen and (min-width: 75rem) {
  .group-module-style-stretch-nontouch {
    grid-column: 1/-1;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .group-module-style-stretch-touch {
    grid-column: 1/-1;
  }
}
/* add more as needed */
/* .section-image-can-sticky - make an image that's typically 2 column set up w/ content to stick to the viewport. NOTE: This will work but it depends how the section is styled/built
--------------------------------------------------------------- */
/* Container: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/container.md#container
--------------------------------------------------------------- */
/* .container Skeletons. Do Not Edit */
.container {
  /* do not attempt to override or your container may misalign. containers are meant to always be centered after all */
  /* Tip: if something in the design is off center, consult with designer or use additional padding or margin as needed for the contents instead */
  padding-inline: min(var(--container-fallback, 1.25rem), var(--container-gutter, var(--container-fallback, 1.25rem))) !important;
  margin-inline: auto !important;
  /* widths*/
  max-inline-size: 100%;
  inline-size: calc(100% - max(var(--container-gutter, var(--container-fallback, 1.25rem)) - min(var(--container-fallback, 1.25rem), var(--container-gutter, var(--container-fallback, 1.25rem))), 0rem) * 2);
  min-inline-size: 0;
  /* flex stuff */
  flex: 0 0 auto;
  grid-column: 1/-1;
  /* container query support */
  container: container/inline-size;
}

/* Container: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/container.md
--------------------------------------------------------------- */
/* Fallback Scaffolding. Usually no need to edit: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/container.md#css-vars 
--------------------------------------------------------------- */
.container {
  --container-fallback: 1.25rem;
  /* customizeable distance. Set as the `--container-fallback` by default. Can be customized depending on the design of a given section though 20px - 30px should be enough */
  --container-size-reference: var(--comp);
  /* window width or section width. you wont usually need to manipulate this value  unless complex split layout designs */
  --container-gutter: var(--container-fallback);
  /* the value to constrain the container's horizontal space. you will mostly modify this variable. */
}
@media only screen and (min-width: 48rem) {
  .container {
    --container-fallback: 2.5rem;
  }
}
/* on some cases container query support is a conflict of interest and makes positioned/flex/grid children act weird. use this helper if you dont need container queries */
.container.container-style-normal {
  /* container query support */
  container-type: normal;
}

/* Custom Container Size Variations: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/container.md#container-size-name
--------------------------------------------------------------- */
/* repeating/ internal page container sizing. sometimes designers will use the same gutter width for internals and or gridded template. this can be used so you dont have to copy paste identical styles to different selectos like 10 times */
@media only screen and (min-width: 75rem) {
  .container.container-size-default {
    --container-gutter: 3.75rem;
  }
}
@media only screen and (min-width: 120rem) {
  .container.container-size-default {
    --container-gutter: 15rem;
  }
}

/* Reduces horizontal padding */
@media only screen and (min-width: 48rem) {
  .container.container-size-wide {
    --container-gutter: .9375rem;
  }
}
@media only screen and (min-width: 75rem) {
  .container.container-size-wide {
    --container-gutter: 1.875rem;
  }
}
/* Reduces horizontal padding for xs only */
@media only screen and (max-width: 47.9375rem) {
  .container.container-size-wide-xs {
    --container-gutter: .9375rem;
    --container-gutter: var(--container-fallback);
  }
}

/* Reduces horizontal padding for sm only */
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .container.container-size-wide-sm {
    --container-gutter: 1.875rem;
    --container-gutter: var(--container-fallback);
  }
}

/* Other Container Variations: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/container.md#container-style-name
--------------------------------------------------------------- */
/* sometimes when you dont need the fallback gutter for the container but also need to constrict the layout, here's ya boi. Note: Make sure you add appropriate padding for the innards of this container */
.container.container-style-no-padding {
  --container-fallback: 0rem;
}

/* constrict container to how wide it is in the deisgn comps. makes sure it never goes beyond the comp or set gutter or fallback global padding + adding important disables third party scripts from overriding our styles */
@media only screen and (min-width: 48rem) {
  .container.container-style-maxed {
    max-inline-size: calc(var(--container-size-reference) - max(var(--container-gutter) - min(var(--container-fallback), var(--container-gutter)), 0rem) * 2) !important;
  }
}

/* constrict container to how wide it is in the deisgn comps for mobile/xs and smaller only */
@media only screen and (max-width: 47.9375rem) {
  .container.container-style-maxed-xs {
    max-inline-size: calc(var(--container-size-reference) - max(var(--container-gutter) - min(var(--container-fallback), var(--container-gutter)), 0rem) * 2) !important;
  }
}

/* constrict container to how wide it is in the deisgn comps for hd/xl and beyond only */
@media only screen and (min-width: 120rem) {
  .container.container-style-maxed-xl {
    max-inline-size: calc(var(--container-size-reference) - max(var(--container-gutter) - min(var(--container-fallback), var(--container-gutter)), 0rem) * 2) !important;
  }
}

/* constrict container to how wide it is in the deisgn comps for touch devices/xs to sm-max only */
@media only screen and (max-width: 74.9375rem) {
  .container.container-style-maxed-touch {
    max-inline-size: calc(var(--container-size-reference) - max(var(--container-gutter) - min(var(--container-fallback), var(--container-gutter)), 0rem) * 2) !important;
  }
}

/* constrict container to how wide it is in the deisgn comps for touch devices/xs to sm-max only */
@media only screen and (min-width: 75rem) {
  .container.container-style-maxed-nontouch {
    max-inline-size: calc(var(--container-size-reference) - max(var(--container-gutter) - min(var(--container-fallback), var(--container-gutter)), 0rem) * 2) !important;
  }
}

/* Widgets https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/widget.md
--------------------------------------------------------------- */
/* Widgets Skeleton. Do not Edit 
--------------------------------------------------------------- */
.widget {
  padding-block: var(--widget-padding-top) var(--widget-padding-bottom);
  padding-inline: var(--widget-padding-x);
  position: relative;
  max-inline-size: none;
  inline-size: auto;
  overflow: hidden;
}
.widget,
.widget > :where(ul, .menu, div):not(.content),
.widget > :where(ul, .menu, div):not(.content) li {
  padding-inline: var(--widget-padding-x);
}
.widget > :where(ul, .menu, div),
.widget .widget-content {
  padding-block: var(--widget-content-padding-top) var(--widget-content-padding-bottom);
  -webkit-margin-after: var(--widget-content-margin-bottom);
          margin-block-end: var(--widget-content-margin-bottom);
}
.widget > :where(ul, .menu, div):nth-child(n+2),
.widget .widget-content:nth-child(n+2) {
  -webkit-margin-before: var(--widget-content-margin-top);
          margin-block-start: var(--widget-content-margin-top);
}
.widget > :where(ul, .menu, div):last-child, .widget > :where(ul, .menu, div):not(.content) > li, .widget > :where(ul, .menu, div):not(.content) :where(ul, .sub-menu),
.widget .widget-content:last-child,
.widget .widget-content:not(.content) > li,
.widget .widget-content:not(.content) :where(ul, .sub-menu) {
  max-inline-size: none;
  inline-size: auto;
}
.widget > :where(ul, .menu, div):last-child, .widget > :where(ul, .menu, div):not(.content) > li,
.widget .widget-content:last-child,
.widget .widget-content:not(.content) > li {
  margin-inline: calc(var(--widget-padding-x) * -1);
}
.widget > :where(ul, .menu, div):not(.content) :where(ul, .sub-menu),
.widget .widget-content:not(.content) :where(ul, .sub-menu) {
  margin-inline: var(--widget-dropdown-margin-x);
}
:is(.widget_title, .widget-title, .widgettitle) {
  padding-inline: var(--widget-title-padding-x);
  margin-block: 0;
}

.widget > :where(ul, .menu, div):not(.content) li > :is(a, :only-child) {
  padding-inline: var(--widget-item-padding-x);
}
.widget > :where(ul, .menu, div).content,
.widget .widget-content {
  padding-inline: calc(var(--widget-padding-x) + var(--widget-item-padding-x));
}
.widget > :where(ul, .menu, div):not(.content) ul li {
  padding-inline: calc(var(--widget-dropdown-padding-x) + var(--widget-dropdown-offset)) var(--widget-dropdown-padding-x);
}
.widget > :where(ul, .menu, div):not(.content) ul li > :is(a:only-child, a:has(+ :is(ul, .sub-menu))) {
  -webkit-padding-start: calc(var(--widget-dropdown-item-offset) + var(--widget-item-padding-x));
          padding-inline-start: calc(var(--widget-dropdown-item-offset) + var(--widget-item-padding-x));
}
.widget > :where(ul, .menu, div):not(.content) li {
  list-style: none;
  clear: both;
}
.widget > :where(ul, .menu, div):not(.content) li > :is(a:only-child, a:has(+ :is(ul, .sub-menu))) {
  line-height: var(--widget-item-line-height) !important;
  padding-block: calc(var(--widget-item-padding-y, calc((var(--widget-item-height, 3em) - var(--widget-item-border-width, 1px) * 2 - 1em * var(--widget-item-lines, 1) * var(--widget-item-line-height, 1.25)) * 0.5)) - var(--widget-item-border-width, 1px) * 0.5);
  color: inherit;
  text-decoration: none;
  display: flex;
}
.widget > :where(ul, .menu, div):not(.content) li ul {
  border-block: var(--widget-item-border-width) solid transparent;
  padding-block: var(--widget-dropdown-padding-top) var(--widget-dropdown-padding-bottom);
  margin-block: var(--widget-dropdown-margin-top) var(--widget-dropdown-margin-bottom);
  flex: 0 0 auto;
}
.widget > :where(ul, .menu, div):not(.content) li:last-child > ul {
  -webkit-border-after: 0;
          border-block-end: 0;
  -webkit-margin-after: calc(var(--widget-dropdown-padding-bottom) * -1);
          margin-block-end: calc(var(--widget-dropdown-padding-bottom) * -1);
}
.widget > :where(ul, .menu, div):not(.content) > li:last-child > ul {
  /* fix top level item dropdown bottom gaps */
  -webkit-margin-after: calc((var(--widget-padding-bottom) + var(--widget-content-padding-bottom)) * -1);
          margin-block-end: calc((var(--widget-padding-bottom) + var(--widget-content-padding-bottom)) * -1);
}
.widget:not(.widget-style-no-toggle):not(.open) > :is(.widget_title, .widget-title, .widgettitle) + *:where(ul, .menu, div), .widget:not(.widget-style-no-toggle):not(.open):has(:is(.widget_title, .widget-title, .widgettitle)) .widget-content,
.widget:not(.widget-style-no-toggle) li:not(.open) > ul:not(:only-child) {
  /* close it all, javascript will take care of opening what needs to be opened */
  display: none;
}
:is(.widget_title, .widget-title, .widgettitle) + *:not(:where(ul, .menu, div)), .widget:has(:is(.widget_title, .widget-title, .widgettitle)) .widget-content {
  margin-top: var(--widget-content-margin-top);
}

.widget :where(input:not([type=radio]):not([type=checkbox]):not([type=submit]):not([type=button]):not([type=image]):not([type=file]),
select,
textarea,
table) {
  inline-size: 100%;
}

/* Widget Customizations https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/widget.md#css-vars
--------------------------------------------------------------- */
.widgets-wrapper {
  display: flex;
  flex-direction: column;
  gap: min(var(--default-gap-y, 3.75rem), 3.75rem);
}

.widget {
  --widget-padding-x: 0rem;
  /* Horizontal padding between the widgets' edges and its contents
  NOTE: the .widget, title, li, and ul/content block use this variable to adjust paddings and negative margins to align to value
  NOTE: li is being padded with --widget-padding-x to align the padding perfectly with the title, li, and uls/content block */
  --widget-padding-top: 0rem;
  /* Yes */
  --widget-padding-bottom: var(--widget-padding-top);
  /* Yes */
  --widget-dropdown-padding-top: 1rem;
  /* Yes  */
  --widget-dropdown-padding-bottom: var(--widget-dropdown-padding-top);
  /* Yes
  * will also be used to calculate negative margins for dropdowns within the last child for consistent spacing  */
  --widget-dropdown-margin-top: 0.5rem;
  /* dropdown margin top. used to distance from previous sibling link */
  --widget-dropdown-margin-bottom: var(--widget-dropdown-margin-top);
  /* dropdown margin bottom. used to distance from parent li's next sibling */
  --widget-item-border-width: 1px;
  /* border width. This will be accounted for in calculating the widget list item height as well */
  --widget-item-padding-x: 0rem;
  /* Padding to distance between only the anchor tags' and parent widget li item.
  Not affected by `--widget-padding-x` */
  --widget-item-padding-y: .25em;
  /* Padding to distance between only the anchor tags' and parent widget li item.
  Not affected by `--widget-padding-x` */
  --widget-dropdown-margin-x: calc(var(--widget-padding-x) * -1);
  /* margin to offset dropdown. set to negative paddix x to flush, 0 to contain, whatever
  	not affected by --widget-padding-x */
  --widget-dropdown-padding-x: var(--widget-padding-x);
  /* padding for dropdow
  	not affected by --widget-padding-x */
  --widget-dropdown-offset: 0em;
  /* indent padding for dropdown. designers will prefer this if contrasting dropdown background is not set */
  /* Set to 0rem if not needed */
  --widget-dropdown-item-offset: 0em;
  /* indent padding for dropdown items. designers will prefer this if contrasting dropdown background is not set */
  /* Set to 0rem if not needed */
  --widget-title-padding-x: var(--widget-item-padding-x);
  /* horizontal padding for widget titles */
  /* Note: this value has to be unitless for calc values to work.
  * modify this value if the font seems a little too high or low in vertical alignment. 1 moves the text to the very top. 0 moves the text to the very bottom. 0.5 will center it based on the fonts' basline alignment */
  --widget-content-margin-top: 1rem;
  /* margin distance between the widget title and the widget contents */
  --widget-content-margin-bottom: 0rem;
  /* margin distance between the widget title and the widget contents */
  --widget-content-padding-top: 0rem;
  /* margin distance between the widget title and the widget contents
  	Note: if the widget accordion is closed, this hides along with the contents, meaning it wont affect the `--widget-padding-bottom` */
  --widget-content-padding-bottom: var(--widget-content-padding-top);
  /* margin distance between the widget title and the widget contents
  Tip: setting to `calc(var(--widget-padding-bottom) * -1)` can compensate the `--widget-padding-bottom` without affecting it when the widget is collapsed
  Note: if the widget accordion is closed, this hides along with the contents, meaning it wont affect the `--widget-padding-bottom` */
  --widget-item-line-height: 1.25;
  /* Note: this value has to be unitless for calc values to work. Usually there's no need to modify this unless a multiline widget list item is present in the design.
  	* Formula is line-height-px / font-size-px */
  border-radiusu: none;
  border-radius: none;
}
.widget > :where(ul, .widget-content):not(.content) {
  font-size: 1.125rem;
  color: var(--scheme-fg, var(--color-dark));
  font-weight: 500;
  text-align: left;
  text-decoration: none;
}
.widget > :where(ul, .widget-content):not(.content) li:is(.open, :hover, :focus-within) > a {
  color: var(--scheme-sp, var(--color-primary));
}
.widget > :where(ul, .widget-content):not(.content) li ul {
  border-color: var(--color-neutral-lighter);
  text-align: left;
}
.widget > :where(ul, .widget-content):not(.content) li ul ul {
  background-color: rgba(0, 0, 0, 0.01);
}
.widget > :where(ul, .widget-content):not(.content) li.open {
  -webkit-border-after: 0;
          border-block-end: 0;
}
.widget > :where(ul, .widget-content):not(.content) li.open > a {
  -webkit-border-after: 0;
          border-block-end: 0;
}
/* Widget Title
--------------------------------------------------------------- */
:is(.widget_title, .widget-title, .widgettitle) {
  font-size: 2.5rem;
  flex-wrap: wrap;
}
:is(.widget_title, .widget-title, .widgettitle):is(.fancy-border) {
  --fancy-border-width: 100%;
  --fancy-border-margin-y: var(--widget-content-margin-top);
  --fancy-border-margin-l: 0;
}
:is(.widget_title, .widget-title, .widgettitle):is(.fancy-border-before)::before, :is(.widget_title, .widget-title, .widgettitle):is(.fancy-border-after)::after {
  grid-column: 1/-1;
}
.widget:not(.widget-style-no-toggle):not(.open) > :is(.widget_title, .widget-title, .widgettitle) {
  -webkit-padding-after: 0;
          padding-block-end: 0;
  -webkit-border-after: 0;
          border-block-end: 0;
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.widget:not(.widget-style-no-toggle):not(.open) > :is(.widget_title, .widget-title, .widgettitle):is(.fancy-border) {
  --fancy-border-margin-y: 0rem;
  --fancy-border-height: 0rem;
}
/* Widget Toggle
--------------------------------------------------------------- */
.widget-toggle {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  -moz-column-gap: 0.5em;
       column-gap: 0.5em;
  cursor: pointer;
  justify-content: space-between;
}
.widget-toggle > * {
  min-inline-size: 0;
}
.widget-toggle::before {
  display: inline-block;
  order: 9;
  align-self: center;
  flex: 0 0 auto;
  content: "";
  font-size: 0.7rem;
  transform-origin: 67% 67%;
  width: 1em;
  -webkit-margin-end: 0.5em;
          margin-inline-end: 0.5em;
  height: 1em;
  border: 2px solid var(--color-primary);
  border-top: 0;
  border-left: 0;
  transform: rotate(45deg);
}
.open > .widget-toggle::before {
  transform: rotate(-135deg);
}
/* Widget Customization by type. Unless an extra extra custom site, there should be rarely a need to apply overrides at this point
--------------------------------------------------------------- */
.widget.sidebar-org-info-coupons {
  border-radius: var(--global-radius);
  --widget-padding-x: 2.5rem;
  --widget-padding-top: 4.1875rem;
  --widget-padding-bottom: 4rem;
  --fancy-background-elesi-t: -.1em;
  --fancy-background-elesi-l: auto;
  --fancy-background-elesi-r:-.27em
  // --widget-dropdown-padding-top: rem;
  border: 2px solid var(--color-accent-alt);
}
.widget.sidebar-org-info-testimonials {
  border-radius: var(--global-radius);
  --fancy-background-elesi-width: 34rem;
  --fancy-background-elesi-opacity: .2;
  --fancy-background-elesi-transform: scaleX(-1);
  --widget-padding-x: 1.75rem;
  --widget-padding-top: 4.25rem;
  --widget-padding-bottom: 2.875rem;
  border: 2px solid var(--color-accent-alt);
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .widget.sidebar-org-info-testimonials {
    --widget-padding-x: 3.4375rem;
  }
}
.widget.sidebar-org-info-testimonials .swiper-pagination {
  justify-content: flex-start;
}

/* Popup: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/popup.md#popup
--------------------------------------------------------------- */
/* .popup Skeletons. Do Not Edit */
.doc-popup-active {
  overflow-block: hidden;
}

.popup-content {
  display: none !important;
}

.popup {
  display: none;
  overflow-block: auto;
  position: fixed;
  isolation: isolate;
  z-index: 99999;
  inset: 0;
  margin: 0;
  min-block-size: 100vb;
  inline-size: 100%;
  min-inline-size: 20rem;
  display: flex;
  flex-direction: column;
  background: none !important;
}
.popup.active {
  display: block;
}
.popup-overlay {
  min-block-size: 100vb;
  position: fixed;
  inset: 0;
  margin: 0;
}
.popup-body {
  overflow-block: scroll;
  block-size: 100%;
  scrollbar-width: none;
}
.popup-body::-webkit-scrollbar {
  display: none;
}
.popup-frame {
  position: relative;
}
.popup:has(.popup-constrict) .popup-frame {
  block-size: 80vb;
  inline-size: 100%;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  max-block-size: -webkit-max-content;
  max-block-size: -moz-max-content;
  max-block-size: max-content;
  align-self: center;
  margin-inline: auto;
}
.popup:has(.popup-constrict) .popup-frame > *:not(.popup-destroy) {
  flex: 1 1;
  max-block-size: -webkit-max-content;
  max-block-size: -moz-max-content;
  max-block-size: max-content;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  inline-size: 100%;
  block-size: 100%;
}
.popup:has(.popup-constrict) .popup-frame > *:not(.popup-destroy) :nth-child(n+2) {
  display: none;
}
.popup:has(.popup-constrict) .popup-body {
  padding-block: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-content: center;
  align-items: center;
}

/* Popup https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/popup.md
--------------------------------------------------------------- */
/* Popup Customizations
--------------------------------------------------------------- */
.popup {
  -webkit-backdrop-filter: blur(3px);
          backdrop-filter: blur(3px);
}
.popup-overlay {
  background: var(--color-dark, black);
  opacity: 0.8;
}
.popup-body {
  padding-block: min(20vi, 16rem);
}
.popup-frame {
  background: var(--color-light, white);
  border-radius: var(--global-radius-large);
  padding-block: 5.625rem;
  padding-inline: 5.625rem;
}
.popup-frame :where(img) {
  border-radius: var(--global-radius);
}
.popup-close-button {
  position: absolute;
  inset-block-start: 0.625em;
  inset-inline-end: 0.625em;
  background: none;
  border: 0;
  font-size: 3.125rem;
  display: block;
  inline-size: 1em;
  block-size: 1em;
  line-height: 1;
  padding: 0;
  overflow-inline: clip;
  color: var(--color-accent);
}
.popup-close-button-text {
  font-size: 0.25em;
  text-transform: uppercase;
  text-wrap: pre-wrap;
  white-space: nowrap;
  -webkit-margin-before: 0.5em;
          margin-block-start: 0.5em;
  display: block;
  text-indent: -9999em;
}
.popup-close-button::before, .popup-close-button::after {
  content: "";
  display: block;
  block-size: 4px;
  inline-size: 1em;
  position: absolute;
  inset: 0;
  margin: auto;
  background: currentColor;
}
.popup-close-button::before {
  transform: rotate(45deg);
}
.popup-close-button::after {
  transform: rotate(-45deg);
}
.popup:has(.popup-constricted) .popup-frame {
  padding: 1.875rem;
  box-shadow: none;
}
.popup:has(.popup-constricted) .popup-frame :where(img) {
  border-radius: var(--global-radius);
}
.popup:has(.popup-constricted) .popup-close-button {
  inset-block-start: max(1.125rem, 9.375vi);
  inset-inline-end: min(25vi, 3.215rem, var(--container-gutter));
  -webkit-margin-before: 0;
          margin-block-start: 0;
  color: var(--color-light);
  position: fixed;
  z-index: 999;
}
@media only screen and (min-width: 75rem) {
  .popup:has(.popup-constricted) .popup-container {
    --container-gutter: 16rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .popup-container {
    --container-gutter: 12.5rem;
  }
  .popup:has(.popup-constricted) .popup-container {
    --container-gutter: 22rem;
  }
}
@media only screen and (min-width: 120rem) {
  .popup-container {
    --container-gutter: 17.1875rem;
  }
  .popup:has(.popup-constricted) .popup-container {
    --container-gutter: 37rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .popup-frame {
    padding-block: 4rem 2rem;
    padding-inline: 1.875rem;
  }
  .popup-close-button {
    font-size: 2rem;
    inset-block-start: 1.25rem;
    inset-block-end: 1.25rem;
  }
}

/* Graphic/ design related styles or decoration styles here. Essentially, the fancy stuff enhances the gucciness of the site
--------------------------------------------------------------- */
/* Fancy Borders + HR: /* https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/fancy.md#fancy-border-css-vars
--------------------------------------------------------------- */
:where(hr),
.fancy-border {
  clear: both;
  outline: none;
  border: none;
  -moz-column-break-inside: avoid;
       break-inside: avoid;
}

.fancy-border {
  --fancy-border-margin-y: 1.5rem;
  --fancy-border-margin-r: auto;
  --fancy-border-margin-l: auto;
  --fancy-border-height: 3px;
  --fancy-border-background: currentColor;
}
:where(hr),
hr:is(.fancy-border), .fancy-border.fancy-border-before::before, .fancy-border.fancy-border-after::after {
  block-size: var(--fancy-border-height, 1px);
  inline-size: var(--fancy-border-width, 100%);
  background: var(--fancy-border-background, var(--color-neutral));
  -webkit-margin-start: var(--fancy-border-margin-l, auto);
          margin-inline-start: var(--fancy-border-margin-l, auto);
  -webkit-margin-end: var(--fancy-border-margin-r, auto);
          margin-inline-end: var(--fancy-border-margin-r, auto);
  max-inline-size: 100%;
  grid-column: 1/-1;
  flex: 0 0 auto;
}

.fancy-border.fancy-border-before:not(hr)::before, .fancy-border.fancy-border-after:not(hr)::after {
  content: "";
}

:where(hr),
hr:is(.fancy-border),
.fancy-border-after::after,
.fancy-border-before::before {
  display: block;
  transition: all 0.375s ease-in-out;
}

.fancy-border.fancy-border-after::after {
  order: 99;
}
.fancy-border.fancy-border-before::before {
  order: -99;
}
hr.fancy-border-after, .fancy-border.fancy-border-after::after {
  -webkit-margin-before: var(--fancy-border-margin-y, 1.875rem);
          margin-block-start: var(--fancy-border-margin-y, 1.875rem);
}

hr.fancy-border-before, .fancy-border.fancy-border-before::before {
  -webkit-margin-after: var(--fancy-border-margin-y, 1.875rem);
          margin-block-end: var(--fancy-border-margin-y, 1.875rem);
}

.fancy-border-palette-primary {
  --fancy-border-background: var(--color-primary)
  	linear-gradient(
  		90deg,
  		var(--color-primary-gradient-start) 0%,
  		var(--color-primary-gradient-end) 100%
  	);
}
.fancy-border-palette-secondary {
  --fancy-border-background: var(--color-secondary)
  	linear-gradient(
  		90deg,
  		var(--color-secondary-gradient-start) 0%,
  		var(--color-secondary-gradient-end) 100%
  	);
}
.fancy-border-palette-accent {
  --fancy-border-background: var(--color-accent)
  	linear-gradient(
  		90deg,
  		var(--color-accent-gradient-start) 0%,
  		var(--color-accent-gradient-end) 100%
  	);
}
.fancy-border-palette-primary-alt {
  --fancy-border-background: var(--color-primary-alt)
  	linear-gradient(
  		90deg,
  		var(--color-primary-gradient-start) 0%,
  		var(--color-primary-gradient-end) 100%
  	);
}
.fancy-border-palette-secondary-alt {
  --fancy-border-background: var(--color-secondary-alt)
  	linear-gradient(
  		90deg,
  		var(--color-secondary-gradient-start) 0%,
  		var(--color-secondary-gradient-end) 100%
  	);
}
.fancy-border-palette-accent-alt {
  --fancy-border-background: var(--color-accent-alt)
  	linear-gradient(
  		90deg,
  		var(--color-accent-gradient-start) 0%,
  		var(--color-accent-gradient-end) 100%
  	);
}
.fancy-border-palette-neutral {
  --fancy-border-background: var(--color-neutral);
}
.fancy-border-style-grow {
  --fancy-border-margin-x: 1.25rem;
  --fancy-border-margin-y: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  -moz-column-gap: var(--fancy-border-margin-x);
       column-gap: var(--fancy-border-margin-x);
  row-gap: var(--fancy-border-margin-y);
}
hr.fancy-border-style-grow, .fancy-border-style-grow.fancy-border-before::before, .fancy-border-style-grow.fancy-border-after::after {
  margin: 0;
  flex: 1 1;
}

.fancy-border-style-round {
  border-radius: 999em;
}
.fancy-border-style-thin {
  --fancy-border-height: 1px;
}
.fancy-border-style-alignleft {
  --fancy-border-margin-r: auto;
  --fancy-border-margin-l: 0;
}
.fancy-border-style-alignright {
  --fancy-border-margin-r: 0;
  --fancy-border-margin-l: auto;
}
hr.fancy-border-style-flat, .fancy-border-style-flat.fancy-border-before::before, .fancy-border-style-flat.fancy-border-after::after {
  background-image: none !important;
}

.fancy-border-style-inline {
  --fancy-border-margin-l: 0.5em;
  display: flex;
  flex-wrap: nowrap;
  row-gap: var(--fancy-border-margin-y);
  -moz-column-gap: var(--fancy-border-margin-l);
       column-gap: var(--fancy-border-margin-l);
}
.fancy-border-style-inline.fancy-border-before::before, .fancy-border-style-inline.fancy-border-after::after {
  flex: 1 1;
  margin-block: 0 !important;
  align-self: center;
}
/* Animated Fancy Border: /* https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/fancy.md#fancy-border-animated
--------------------------------------------------------------- */
@media only screen and (min-width: 75rem) {
  hr.fancy-border-animated, .fancy-border-animated.fancy-border-before::before, .fancy-border-animated.fancy-border-after::after {
    transition: inline-size 1.5s ease-in-out;
  }
  .fancy-border-animated:not(.visible) {
    --fancy-border-width: 0% !important;
  }
}

/* Fancy Icons: /* https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/components/fancy.md#fancy-icon
--------------------------------------------------------------- */
.fancy-icon-menu {
  position: relative;
  --fancy-icon-menu-width: 2rem;
  --fancy-icon-menu-height: 1rem;
  --fancy-icon-menu-bar-height: 2px;
  --fancy-icon-menu-bar-top-width: 100%;
  --fancy-icon-menu-bar-top-margin-l: auto;
  --fancy-icon-menu-bar-top-margin-r: auto;
  --fancy-icon-menu-bar-center-width: 100%;
  --fancy-icon-menu-bar-center-margin-l: auto;
  --fancy-icon-menu-bar-center-margin-r: auto;
  --fancy-icon-menu-bar-bottom-width: 100%;
  --fancy-icon-menu-bar-bottom-margin-l: auto;
  --fancy-icon-menu-bar-bottom-margin-r: auto;
  inline-size: var(--fancy-icon-menu-width);
  block-size: var(--fancy-icon-menu-height);
}
.fancy-icon-menu span {
  position: absolute;
  transform-origin: center center;
  background: currentColor;
  inset: 0;
  block-size: var(--fancy-icon-menu-bar-height);
  inline-size: 100%;
  transition-duration: 0.375s;
  transition-timing-function: ease-in-out;
  transition-property: top, bottom, left, right, transform, inline-size;
}
.fancy-icon-menu span:where(:first-child) {
  inset-block-end: auto;
  inline-size: var(--fancy-icon-menu-bar-top-width);
  margin: auto var(--fancy-icon-menu-bar-top-margin-r) auto var(--fancy-icon-menu-bar-top-margin-l);
}
.fancy-icon-menu span:where(:last-child) {
  inset-block-start: auto;
  inline-size: var(--fancy-icon-menu-bar-bottom-width);
  margin: auto var(--fancy-icon-menu-bar-bottom-margin-r) auto var(--fancy-icon-menu-bar-bottom-margin-l);
}
.fancy-icon-menu span:where(:nth-child(2), :nth-child(3)) {
  inline-size: var(--fancy-icon-menu-bar-center-width);
  margin: auto var(--fancy-icon-menu-bar-center-margin-r) auto var(--fancy-icon-menu-bar-center-margin-l);
}
.open .fancy-icon-menu span {
  margin: auto;
}
.open .fancy-icon-menu span:nth-child(2) {
  transform: rotateZ(45deg);
}
.open .fancy-icon-menu span:nth-child(3) {
  transform: rotateZ(-45deg);
}
.open .fancy-icon-menu span:is(:nth-child(2), :nth-child(3)) {
  inline-size: 100%;
}
.open .fancy-icon-menu span:is(:first-child, :last-child) {
  inline-size: 0;
}
/* fancy boxes that is just boxed. rehash or rebuild as needed
--------------------------------------------------------------- */
/* @VersionA: version w/ backdrop. this version does not rely on variables to customize padding. simplest setup */
.fancy-box {
  --fancy-box-background: var(--scheme-bg,var(--color-light));
  --fancy-box-box-shadow: 0 5px 10px 0px rgba(0, 0, 0, 0.15);
  --fancy-box-pseudo-background: var(--color-light-alt);
  --fancy-box-pseudo-offset: 1.25rem;
  --fancy-box-pseudo-offset-x: var(--fancy-box-pseudo-offset);
  --fancy-box-pseudo-offset-bottom: var(--fancy-box-pseudo-offset);
  --fancy-box-pseudo-offset-top: var(--fancy-box-pseudo-offset-bottom);
  --fancy-box-border-radius: .25rem;
  background: var(--fancy-box-background);
  box-shadow: var(--fancy-box-box-shadow);
  position: relative;
  padding-inline: 1rem;
  padding-block: 2.5rem;
}
.fancy-box, .fancy-box::after {
  border-radius: var(--fancy-box-border-radius);
}
.fancy-box::after {
  content: "";
  z-index: -1;
  background: var(--fancy-box-pseudo-background);
  position: absolute;
  pointer-events: none;
}
.fancy-boxes-wrapper {
  position: relative;
  z-index: 1;
  -webkit-padding-before: var(--negative-pusher);
          padding-block-start: var(--negative-pusher);
}
.fancy-box-cut-left::after {
  inset-inline-start: var(--fancy-box-pseudo-offset-x);
}
.fancy-box-cut-right::after {
  inset-inline-end: var(--fancy-box-pseudo-offset-x);
}
.fancy-box-cut-top::after {
  inset-block-start: var(--fancy-box-pseudo-offset-top);
}
.fancy-box-cut-bottom::after {
  inset-block-end: var(--fancy-box-pseudo-offset-bottom);
}
:is(.fancy-box-extend-left, .fancy-box-extend-right) {
  max-inline-size: calc(100% - var(--fancy-box-pseudo-offset-x)) !important;
}

:is(.fancy-box-extend-left.fancy-box-extend-right) {
  max-inline-size: calc(100% - var(--fancy-box-pseudo-offset-x) * 2) !important;
}

.fancy-box-extend-left {
  -webkit-margin-start: var(--fancy-box-pseudo-offset-x);
          margin-inline-start: var(--fancy-box-pseudo-offset-x);
}
.fancy-box-extend-left::after {
  inset-inline-start: calc(var(--fancy-box-pseudo-offset-x) * -1);
}
.fancy-box-extend-right {
  -webkit-margin-end: var(--fancy-box-pseudo-offset-x);
          margin-inline-end: var(--fancy-box-pseudo-offset-x);
}
.fancy-box-extend-right::after {
  inset-inline-end: calc(var(--fancy-box-pseudo-offset-x) * -1);
}
.fancy-box-extend-top {
  -webkit-margin-before: var(--fancy-box-pseudo-offset-top);
          margin-block-start: var(--fancy-box-pseudo-offset-top);
}
.fancy-box-extend-top::after {
  inset-block-start: calc(var(--fancy-box-pseudo-offset-top) * -1);
}
.fancy-box-extend-bottom {
  -webkit-margin-after: var(--fancy-box-pseudo-offset-bottom);
          margin-block-end: var(--fancy-box-pseudo-offset-bottom);
}
.fancy-box-extend-bottom::after {
  inset-block-end: calc(var(--fancy-box-pseudo-offset-bottom) * -1);
}
@media only screen and (max-width: 47.9375rem) {
  .fancy-box-style-no-xs {
    margin-inline: 0;
    max-inline-size: 100%;
  }
  .fancy-box-style-no-xs::after {
    content: none;
  }
}

@media only screen and (min-width: 75rem) {
  .fancy-letters {
    /* Insert Mr Garrett's code here */
    --fancy-letters-factor: 0;
    --fancy-letters-line: 0;
    --fancy-letters-factor-word: 0;
    --fancy-letters-factor-char: 0;
    --fancy-letters-delay: .1s;
    --fancy-letters-duration: 1s;
  }
  .fancy-letters:where(:not([style]:has([class*=fancy-letters-]))) {
    --fancy-letters-delay: .5s;
    --fancy-letters-duration: 1s;
    transform: skewY(0deg) skewX(-2deg) rotate(-1deg) translateY(-4rem);
  }
  .fancy-letters:where([style]:has([class*=fancy-letters-])), .fancy-letters-line, .fancy-letters-word, .fancy-letters-char {
    -webkit-padding-after: 0.5em;
            padding-block-end: 0.5em;
    -webkit-margin-after: -0.5em;
            margin-block-end: -0.5em;
  }
  .fancy-letters-line, .fancy-letters-word, .fancy-letters-char, .fancy-letters {
    transition-timing-function: 0.5, 0, 0, 1;
    vertical-align: bottom;
    transition-property: opacity;
    transition-delay: 0s;
    transition-duration: 0.01s;
  }
  .fancy-letters-line, .fancy-letters-word, .fancy-letters-char, .fancy-letters:where(:not([style]:has([class*=fancy-letters-]))) {
    opacity: 0;
  }
  .fancy-letters-line, .fancy-letters-word, .fancy-letters:where([style]:has([class*=fancy-letters-])) {
    overflow: hidden;
  }
  .fancy-letters-word, .fancy-letters-char {
    display: inline-block;
    vertical-align: bottom;
  }
  .fancy-letters-line {
    transform: skewY(0deg) skewX(-4deg) rotate(-2deg) translateY(100%);
  }
  .fancy-letters-line, .fancy-letters:where([style]:has([class*=fancy-letters-])) {
    display: block;
  }
  .fancy-letters-word {
    white-space: nowrap;
    transform: skewY(-10deg) skewX(0deg) rotate(0deg) translateY(100%);
    min-inline-size: -webkit-max-content;
    min-inline-size: -moz-max-content;
    min-inline-size: max-content;
  }
  .fancy-letters-char {
    transform: skewY(10deg) skewX(0deg) rotate(10deg) translateY(100%);
  }
  .fancy-letters.visible,
  .fancy-letters.visible .fancy-letters-line,
  .fancy-letters.visible .fancy-letters-word,
  .fancy-letters.visible .fancy-letters-char, .visible .fancy-letters,
  .visible .fancy-letters .fancy-letters-line,
  .visible .fancy-letters .fancy-letters-word,
  .visible .fancy-letters .fancy-letters-char {
    transition-property: transform, opacity;
    transition-duration: var(--fancy-letters-duration);
    transform: skewY(0deg) skewX(0deg) rotate(0deg) translateY(0%);
    opacity: 1;
  }
  .fancy-letters.visible:where(:not([style]:has([class*=fancy-letters-]))),
  .fancy-letters.visible .fancy-letters-line, .visible .fancy-letters:where(:not([style]:has([class*=fancy-letters-]))),
  .visible .fancy-letters .fancy-letters-line {
    transform-origin: top left;
  }
  .fancy-letters.visible, .visible .fancy-letters {
    transition-delay: calc((var(--fancy-letters-delay)) * var(--fancy-letters-factor));
  }
  .fancy-letters.visible .fancy-letters-line, .visible .fancy-letters .fancy-letters-line {
    transition-delay: calc(var(--fancy-letters-delay) / max(1, var(--fancy-letters-factor) * 0.8) * (var(--fancy-letters-factor-line) + var(--fancy-letters-factor)));
  }
  .fancy-letters.visible .fancy-letters-word, .visible .fancy-letters .fancy-letters-word {
    transition-delay: calc(var(--fancy-letters-delay) / max(1, var(--fancy-letters-factor) * 0.5) * (var(--fancy-letters-factor-line) * 0.75 + var(--fancy-letters-factor-word)));
    transform-origin: bottom right;
  }
  .fancy-letters.visible .fancy-letters-char, .visible .fancy-letters .fancy-letters-char {
    transition-delay: calc(var(--fancy-letters-delay) / max(1, var(--fancy-letters-factor) * 0.2) * (var(--fancy-letters-factor-line) * 0.5 + var(--fancy-letters-factor-word) * 0.75 + var(--fancy-letters-factor-char)));
    transform-origin: center center;
  }
}

/* Other Custom Fancy Stuff
--------------------------------------------------------------- */
.fancy-background-elesi {
  background: var(--color-dark-alt);
  position: relative;
  z-index: 1;
  overflow: clip;
}
.fancy-background-elesi::after {
  content: "";
  display: block;
  z-index: -1;
  font-size: var(--fancy-background-elesi-width, 22.75rem);
  width: 1em;
  inset-block-start: var(--fancy-background-elesi-t, -0.1em);
  inset-block-end: var(--fancy-background-elesi-b, auto);
  inset-inline-start: var(--fancy-background-elesi-l, -0.27em);
  inset-inline-end: var(--fancy-background-elesi-r, auto);
  aspect-ratio: 1/1;
  pointer-events: none;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center center;
          mask-position: center center;
  transform: var(--fancy-background-elesi-transform, none);
  opacity: var(--fancy-background-elesi-opacity, 0.4);
  position: absolute;
  margin: auto;
}
.doc-images-loaded .fancy-background-elesi::after {
  -webkit-mask-image: var(--fancy-background-mask-image, var(--icon-elesi));
          mask-image: var(--fancy-background-mask-image, var(--icon-elesi));
  background-color: var(--fancy-background-elesi-color, rgba(0, 0, 0, 0.5));
}
/* Other Custom Fancy Stuff
--------------------------------------------------------------- */
/* Filter Dropdown https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/filter-dropdown.md
/*
drodpwon filter. for filterable blocks eg Case results. Uncomment in style.scss if needed
Markup should follow the folloowing


To enable, follow the steps:
- Uncomment the sass import declaration in the style.scss file
- Enqueue js/includes/filter-dropdown
- If being used for Case Results
	-Setup `Case Result Types` on
		- Admin > Theme Options > Other Components if there are no CPTs for case results being used
		- Admin > Case Results > Case Result Types if CPT Case results are enabled
		- Add classes/Attrs to the following
			- .filter-blocks => PARENT wrapper of case results row
			- .filter-block => set as the value for 'part_classes' of includes/repeater-results.
- If being used for other purposes
	- Use template part includes/helper-filter-dropdown
	- Add classes/Attrs to the following
		- .filter-blocks => PARENT wrapper of the items to be filtered
		- .filter-block => blocks to hide or show depending on active filter
		- [data-filter] => set attribute to  .filter-block as applicable filter slugs separated by commas


--------------------------------------------------------------- */
.filter {
  /* height of filter. designers will prefer to design filters based on their height. this is to better support the wonders they create while being able to use padding to support multi-line/ edge case filters */
  --filter-height: 3em;
  /* border width. This will be accounted for in calculating the filter height as well */
  --filter-border-width: 1px;
  /* duh */
  --filter-item-height: 2.8125rem;
  /* horizontal padding for the filter */
  --filter-padding-x: 1.5rem;
  /* Note: this value has to be unitless for calc values to work. Usually there's no need to modify this unless a multiline filter is present in the design.
  	* Formula is line-height-px / font-size-px */
  --filter-line-height: 1.125;
  /* padding for dropdown. Note: Applied as height to pseudo element to smooth out appearance of overflowing dropdown items */
  --filter-dropdown-padding-y: 1em;
  /* padding for dropdown */
  --filter-dropdown-padding-x: var(--filter-padding-x);
  position: relative;
  margin-inline: auto;
  inline-size: 36.25rem;
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
  z-index: 99;
  display: flex;
  flex-direction: column;
  gap: 1em;
}
.filter-title {
  align-self: center;
  margin: 0;
  flex: 0 0 auto;
}
.filter-select {
  flex: 1 1;
  position: relative;
  line-height: var(--filter-line-height);
}
.filter-select-label, .filter-select-dropdown {
  text-align: initial;
}
.filter-select-label {
  display: flex;
  justify-content: space-between;
  inline-size: 100%;
  background: var(--scheme-bg, var(--color-light));
  color: var(--scheme-fg, var(--color-dark));
  padding-inline: calc(var(--filter-padding-x) - var(--filter-border-width));
  padding-block: calc((var(--filter-height) - var(--filter-border-width) * 2 - 1em * var(--filter-line-height)) * 0.5) calc((var(--filter-height) - var(--filter-border-width) * 2 - 1em * var(--filter-line-height)) * 0.5);
  position: relative;
  z-index: 1;
  border: var(--filter-border-width) solid var(--scheme-bg-contrast, var(--color-light-alt));
}
.filter-select-label::before {
  order: 999;
  align-self: center;
  content: "\25BE\FE0E";
  display: inline-block;
}
.filter-select-dropdown {
  background: var(--scheme-bg, var(--color-dark-alt));
  color: var(--scheme-fg, var(--color-light));
  box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.2);
  position: absolute;
  inset-block-start: 100%;
  inset-inline-start: 0;
  inline-size: 100%;
  display: none;
  padding-block: 2rem;
  padding-inline: 1.5rem;
  line-height: var(--filter-line-height);
  max-block-size: calc(80vb - var(--layout-header-height));
  scrollbar-width: none;
  overflow-block: scroll;
  font-size: 1.25rem;
}
.filter-select-dropdown::-webkit-scrollbar {
  display: none;
}
.filter-select-dropdown:before, .filter-select-dropdown:after {
  content: "";
  position: -webkit-sticky;
  position: sticky;
  block-size: var(--filter-dropdown-padding-y);
  display: block;
  inset-inline-start: 0;
}
.filter-select-dropdown:before {
  inset-block-start: 0;
  background: linear-gradient(to top, transparent 0%, var(--scheme-bg, var(--color-dark-alt)) 90%);
}
.filter-select-dropdown:after {
  inset-block-end: 0;
  background: linear-gradient(to bottom, transparent 0%, var(--scheme-bg, var(--color-dark-alt)) 90%);
}
.filter-select-dropdown li {
  transition: all 0.5s ease-in-out;
  padding-inline: var(--filter-dropdown-padding-x);
}
.filter-select-dropdown li a {
  display: block;
  padding-block: calc((var(--filter-item-height) - 1.125em) * 0.5) calc((var(--filter-item-height) - 1.125em) * 0.5);
}
.filter-select-dropdown li:is(.active, :hover, :focus) {
  color: var(--scheme-sp, var(--color-primary));
}
@media only screen and (min-width: 48rem) {
  .filter-select {
    flex-direction: row;
  }
}
.filter-empty {
  margin: 90px auto;
  text-align: center;
  inline-size: 100%;
}
.filter-empty-text {
  /* Container for custom text. should not at all display. */
  display: none;
}

/* ================================================================================
* Includes 
================================================================================ */
/* Forms https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/form.md
For Gravity Forms specific styles go to scss/vendors/gforms
-------------------------------------------------------------------------------- */
.field-form {
  max-inline-size: 100%;
}
.field-form:where(.group-frame) {
  gap: 3rem;
}
.field-form:where(.group-frame) :where(.gform_wrapper,
.gform_body,
form) {
  display: contents;
}
.field-form :where(.gform_wrapper) :is(.gform_title,
.gform_description,
.gform_footer,
.gform_page_footer,
.gform_body) {
  margin: 0;
  padding: 0;
}
.field-form :where(.gform_wrapper) .gform_heading {
  /* gform heading: gforms generated or template custom ones */
}
.field-form :where(.gform_wrapper) .gform_heading:where(:not(.group-frame *)) {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
.field-form :where(.gform_wrapper) .gform_heading:where(.group-frame) {
  gap: 0.25rem;
}
.field-form :where(.gform_wrapper) :where(.gform_heading, .gform_title, .gform_description) {
  /* everything inside the heading: gforms generated or template custom ones */
  /* center the heading stuff. or adjust as needed if that's not the case */
  margin-inline: auto;
}
.field-form :is(.gform_wrapper) :is(.gform_title, .gform_description):last-child {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.field-form :is(.gform_wrapper) .gform_body {
  /* body: gforms generated or template custom ones */
}
.field-form :is(.gform_wrapper) :is(.gform_footer, .gform_page_footer) {
  /* footer: gforms generated or template custom ones */
}
.field-form :is(.gform_wrapper) :is(.gform_footer, .gform_page_footer) {
  /* reset margin and padding and add  one margin to keep spacing simple to setup. Gravity forms man. */
  padding: 0;
  margin: 0;
}
.field-form :is(.gform_wrapper) :is(.gform_footer, .gform_page_footer):where(:not(.group-frame *)) {
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
}
.field-form :is(.gform_wrapper) :is(.gform_footer, .gform_page_footer) :is(.gform_button, .button) {
  /* that goes for the button too */
  -webkit-margin-after: 0;
          margin-block-end: 0;
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
.field-form :is(.gform_wrapper) :is(.gform_footer, .gform_page_footer):not(:has(.gform_button)) {
  display: none;
}
.field-form-body :is(.gform_wrapper) .gform_heading {
  /* in case gravity forms decides to add more ugly things */
  display: none;
}

/*  Responsive Background skeletons: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/field/responsive-background
--------------------------------------------------------------- */
/* Responsive Background skeletons. Do not Edit.
--------------------------------------------------------------- */
.responsive-background {
  pointer-events: none;
  overflow: hidden;
  transform-style: preserve-3d;
  z-index: -1;
  background-color: var(--responsive-background-bg-color, var(--scheme-bg, var(--color-dark-alt)));
}
.responsive-background::after {
  content: "";
  display: block;
  inset: 0;
  position: absolute;
  pointer-events: none;
  mix-blend-mode: var(--responsive-background-overlay-mix-blend, normal);
  background: var(--responsive-background-overlay-background, none);
  opacity: var(--responsive-background-overlay-opacity, 0.75);
}
.responsive-background-wrapper {
  position: relative;
  z-index: 0;
}
.responsive-background, .responsive-background-bg {
  position: absolute !important;
  inset: 0;
}
.responsive-background-bg {
  /* Note: when styling instances of this block, make sure properties are NOT set as shorthand to avoid override issues */
  background-size: cover;
  background-position: var(--responsive-background-bg-position);
  /* Note: Best practice to add fallback background-colors to your background images */
  background-color: inherit;
  z-index: -2;
  background-image: var(--responsive-background-image, none) !important;
}
.responsive-background-bg:is(img) {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: var(--responsive-background-bg-position);
     object-position: var(--responsive-background-bg-position);
  inline-size: 100%;
  block-size: 100%;
}
@media only screen and (min-width: 75rem) {
  :is(.responsive-background-animated-on-loaded, .responsive-background-animated-on-visible.visible) .responsive-background-bg {
    /* make background block animate for document ready or when visible*/
    transition: opacity ease-in-out 1s, transform ease-in-out 1s;
    opacity: 1;
    transform: scale(1);
    transform-style: preserve-3d;
  }
  :is(html:not(.doc-images-loaded) .responsive-background-animated-on-loaded,
  .responsive-background-animated-on-visible:not(.visible)) .responsive-background-bg {
    /* hide if not ready to let the world to know got to let it show */
    opacity: 0;
    transform: scale(1.1);
  }
}

/* Responsive Background Customizations
--------------------------------------------------------------- */
:where(.responsive-background) {
  --responsive-background-overlay-mix-blend: normal;
  --responsive-background-overlay-background: none;
  --responsive-background-overlay-opacity: 0.75;
  --responsive-background-bg-position: center center;
}

/* Carousels https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/carousel.md
--------------------------------------------------------------- */
/* Carousel Item skeletons. Do not Edit.
--------------------------------------------------------------- */
.carousel-item {
  text-align: center;
}
.carousel-item-image {
  block-size: var(--carousel-height);
}
.carousel-item-image > :where(*) {
  pointer-events: none;
}
.carousel-item-image,
.carousel-item-image picture {
  display: flex;
  place-content: center;
  place-items: center;
  flex-direction: column;
}
.carousel-item-image :where(svg, object, img) {
  block-size: auto !important;
  margin: auto;
}
.carousel-item-image :where(img, svg, object, picture) {
  inline-size: auto !important;
  max-inline-size: 100% !important;
  max-block-size: 100% !important;
  align-self: center;
  flex: 0 0 auto;
}

/* Carousel Item Customizations
--------------------------------------------------------------- */
:where(.swiper, .slick) {
  /* height of award. best to set to the tallest award logo provided  */
  --carousel-height: 7.5rem;
}
/* Coupons
-------------------------------------------------------------------------------- */
/*
* Coupon Title
-------------------------------------------------------------------------------- */
.coupon-title {
  font-size: 1.875rem;
  line-height: 1.16;
}
.coupon-mini .coupon-title {
  font-size: 1.875rem;
  line-height: 1.16;
}
@media only screen and (min-width: 48rem) {
  .coupon-title {
    font-size: 2.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  .coupon-title {
    font-size: 2.5rem;
    line-height: 1;
  }
}
/*
* Coupon Type
-------------------------------------------------------------------------------- */
.coupon-type {
  font-size: 0.875rem;
}
/*
* Coupon Description
-------------------------------------------------------------------------------- */
.coupon-description {
  font-size: 1.25rem;
  line-height: 1.2;
  color: var(--color-neutral-light);
  font-weight: 500;
}
/*
* Coupon Content
-------------------------------------------------------------------------------- */
/*
* Coupon CTA
-------------------------------------------------------------------------------- */
.coupon-cta {
  margin-block: 0.875rem;
}
/*
* Coupon Disclaimer
-------------------------------------------------------------------------------- */
.coupon-disclaimer {
  font-size: 1rem;
  line-height: 1.25;
  color: var(--color-neutral-light);
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
}
.coupin-mini .coupon-disclaimer {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
/*
* includes/repeater-coupon
-------------------------------------------------------------------------------- */
.coupon {
  max-inline-size: 100%;
}
.coupon:is(.fancy-background-elesi) {
  --fancy-background-elesi-t: -5.1517rem;
  --fancy-background-elesi-l: -3.125rem;
  --fancy-background-elesi-opacity: .4;
  border-radius: var(--global-radius);
  --fancy-background-elesi-width: 28.125rem;
  padding-inline: 1.4375rem;
  padding-block: 4.375rem;
  border: 0.125rem solid var(--color-accent-alt, #08C4D0);
}
.coupon:is(.fancy-background-elesi) .coupon-container {
  gap: 1rem;
}
.coupon:is(.fancy-background-elesi) .coupon-disclaimer {
  matgin-block-start: 1.625rem;
}
.coupon, .coupon-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
.coupon-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 1.14rem;
}
@media only screen and (min-width: 48rem) {
  .coupon:is(.fancy-background-elesi) {
    padding-inline: 3.375rem;
    padding-block: 3.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  .coupon:is(.fancy-background-elesi) {
    padding-inline: 3.6875rem;
    padding-block: 4.125rem;
  }
  .coupon:is(.fancy-background-elesi) .coupon-container {
    gap: 1.25rem;
  }
}
/* Case Results https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/result.md
-------------------------------------------------------------------------------- */
/*
* Case Result Icon
-------------------------------------------------------------------------------- */
.result-icon {
  font-size: 3rem;
}
.result-details-popup .result-icon {
  font-size: 6.25rem;
}
/*
* Case Result Value
-------------------------------------------------------------------------------- */
.result-value {
  font-size: 4rem;
  text-transform: uppercase;
}
:where(.content-palette-dark) .result-value {
  color: var(--scheme-sp, inherit);
}
.result-value-confidential {
  font-size: 0.6em;
}
.result-value-number-long {
  font-size: 0.75em;
}
@media only screen and (min-width: 48rem) {
  .result-details-popup .result-value.h1 {
    font-size: 6.25rem;
  }
}
/*
* Case Result Type
-------------------------------------------------------------------------------- */
/*
* Other Case Result Type
-------------------------------------------------------------------------------- */
/*
* Case Result Title - Optional
-------------------------------------------------------------------------------- */
/*
* Case Result Description
-------------------------------------------------------------------------------- */
.result-details-default .result-description {
  flex: 1 1;
}
/*
* Case Result Content
-------------------------------------------------------------------------------- */
.result-details-default .result-content {
  max-inline-size: 50ch;
}
.result-details-popup .result-content {
  -webkit-margin-before: 3rem;
          margin-block-start: 3rem;
  text-align: initial;
}
/*
* Case Result Learn More - Optional
-------------------------------------------------------------------------------- */
.result-learn-more {
  -webkit-margin-before: 2em;
          margin-block-start: 2em;
  align-self: center;
}
@media only screen and (min-width: 120rem) {
  .result-details-default .result-learn-more:first-child {
    -webkit-margin-before: auto;
            margin-block-start: auto;
  }
}
/*
* includes/repeater-result
-------------------------------------------------------------------------------- */
.result {
  max-inline-size: 100%;
}
.result, .result-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
}
.result-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 0.75rem;
  align-items: center;
}
.result :where(.result-description, .result-content) {
  margin-inline: auto;
}
.result-pointer-reference:has(.result-details, [href]):is(:hover, :focus-within) .result-summary .result-value {
  color: inherit;
}
.result-summary {
  text-align: center;
  display: contents;
}
.result-summary:nth-last-child(n+2) {
  -webkit-margin-after: auto;
          margin-block-end: auto;
}
.result-details-default {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1 1;
  -webkit-margin-before: 1.5em;
          margin-block-start: 1.5em;
  -webkit-border-before: 1px solid var(--color-neutral);
          border-block-start: 1px solid var(--color-neutral);
  -webkit-padding-before: 1.5rem;
          padding-block-start: 1.5rem;
}
.result:has(.result-details-hover) {
  position: relative;
}

.result-pointer-reference:not(:is(:hover, :focus-within)) .result-details-hover {
  pointer-events: none;
  opacity: 0;
}
.result-details-hover {
  max-inline-size: none;
  position: absolute;
  background-color: var(--color-dark-alt);
  color: var(--color-light);
  inset: 0;
  margin: 0;
  scrollbar-width: none;
  overflow-block: scroll;
  transition: 0.25s all ease-in-out;
  padding: 2rem;
  opacity: 1;
}
.result-details-hover::-webkit-scrollbar {
  display: none;
}
.result-details-popup {
  text-align: center;
  flex-direction: column;
  display: flex;
  gap: 1rem;
}
/* Menu Directories https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/menudir.md
-------------------------------------------------------------------------------- */
/*
* Menu Directory Skeleton. Do not Edit
-------------------------------------------------------------------------------- */
.menudir-title {
  padding-inline: var(--pa-title-padding-x);
}
.menudir-title:is(.fancy-border) -after:after {
  --fancy-border-margin-l: calc(var(--pa-title-padding-x) * -1);
  --fancy-border-margin-r: calc(var(--pa-title-padding-x) * -1);
}
.menudir-menu li,
.menudir-menu li a {
  display: flex;
  flex-direction: column;
  line-height: var(--pa-item-line-height);
}
.menudir-menu li a {
  justify-content: center;
  flex: 1 1;
  padding-block: calc(var(--pa-item-padding-y, calc((var(--pa-item-height, 3em) - var(--pa-item-border-width, 1px) * 2 - 1em * var(--pa-item-lines, 2) * var(--pa-item-line-height, 1.25)) * 0.5)) - var(--pa-item-border-width, 1px) * 0.5);
  padding-inline: var(--pa-item-padding-x);
  min-block-size: var(--pa-item-height);
}
.menudir-menu li a:is([href="#"]) {
  pointer-events: none;
}
@media only screen and (max-width: 47.9375rem) {
  .menudir-menu li a {
    min-block-size: 0;
  }
}

/*
* Menu Directory Vars/ Scaffolding
-------------------------------------------------------------------------------- */
.menudir {
  --pa-item-padding-x: 0rem;
  /* height of practice area item. designers will prefer to design buttons based on their height. this is to better support the wonders they create while being able to use padding to support multi-line/ edge case buttons */
  --pa-item-height: 2em;
  /* ideal height of menu items */
  --pa-item-lines: 1;
  /* Note: this value has to be unitless for calc values to work.
  			* Number of lines to compensate for the item height */
  --pa-item-baseline-offset: 0.5;
  /* Note: this value has to be unitless for calc values to work.
  			* 1 moves the text to the very bottom. 0 moves the text to the very top */
  --pa-item-line-height: 1.5;
  /* Note: this value has to be unitless for calc values to work.
  			* Formula is line-height-px / font-size-px */
  --pa-title-padding-x: var(--pa-item-padding-x);
  /* horizontal padding for the practice area title */
}
@media only screen and (min-width: 48rem) {
  .menudir {
    min-inline-size: 100%;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .menudir {
    /* reset heights to normal flow */
  }
}

/*
* Menu Directory Category Title
-------------------------------------------------------------------------------- */
.menudir-title:not(.h5) {
  font-size: 2.1875rem;
  color: var(--color-accent);
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
/*
* Menu Directory Menu
-------------------------------------------------------------------------------- */
.menudir-menu {
  font-size: 1.25rem;
  font-weight: 500;
}
.menudir-menu li:is(:hover, :focus-within) a:not([href="#"]) {
  color: var(--color-primary);
}
/*
* includes/repeater-menudir
-------------------------------------------------------------------------------- */
.menudir {
  max-inline-size: 100%;
}
.menudir, .menudir-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
}
.menudir-container {
  inline-size: 100%;
  flex: 1 1;
}
/* Pagination https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/pagination.md
-------------------------------------------------------------------------------- */
/* Pagination Skeletons. do not edit 
--------------------------------------------------------------- */
.pagination {
  display: grid;
  grid-template-columns: 1fr -webkit-max-content 1fr;
  grid-template-columns: 1fr max-content 1fr;
  align-items: center;
  text-align: center;
  clear: both;
  margin-inline: auto;
  color: inherit;
}
.pagination-block {
  grid-row: 1;
}
.pagination-block-left {
  grid-column: 1;
  text-align: left;
}
.pagination-block-center {
  grid-column: 2;
}
.pagination-block-right {
  grid-column: 3;
  text-align: right;
}
.pagination-num-list.pagination-block-left span:first-child,
.pagination-num-list.pagination-block-left a:first-child {
  -webkit-margin-start: 0;
          margin-inline-start: 0;
}
.pagination-num-list.pagination-block-right span:last-child,
.pagination-num-list.pagination-block-right a:last-child {
  -webkit-margin-start: 0;
          margin-inline-start: 0;
}
@media only screen and (max-width: 74.9375rem) {
  .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-child(2), .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-last-child(2) {
    grid-column: 1/-1;
  }
  .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-child(2) span:nth-last-child(n+2),
  .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-child(2) a:nth-last-child(n+2), .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-last-child(2) span:nth-last-child(n+2),
  .pagination-nav-link:is(.pagination-block-left, .pagination-block-right):nth-last-child(2) a:nth-last-child(n+2) {
    -webkit-margin-end: 0.5em;
            margin-inline-end: 0.5em;
  }
}
/* Pagination Customizations. customize as needed 
--------------------------------------------------------------- */
.pagination {
  -webkit-border-before: 1px solid var(--color-neutral);
          border-block-start: 1px solid var(--color-neutral);
  -webkit-padding-before: 2rem;
          padding-block-start: 2rem;
  -webkit-margin-before: 3.75rem;
          margin-block-start: 3.75rem;
  -webkit-margin-after: 0;
          margin-block-end: 0;
  max-inline-size: 100%;
  grid-column: 1/-1;
  inline-size: calc(var(--comp) - var(--container-gutter, 30px));
}
.pagination .current,
.pagination a:is(:hover, :focus) {
  color: var(--color-primary);
}
.pagination-num-list a,
.pagination-num-list span {
  margin-inline: 0.5em;
}
.pagination-nav-link :is(.next, [rel=next]):after,
.pagination-nav-link :is(.prev, [rel=prev]):before {
  display: inline-block;
  color: var(--scheme-sp, var(--color-primary));
  align-self: center;
  flex: 0 0 auto;
  content: "";
  font-size: 0.5rem;
  transform-origin: 40% 40%;
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-top: 0;
  border-left: 0;
}
.pagination-nav-link :is(.next, [rel=next]):after {
  transform: rotate(-45deg);
  -webkit-margin-start: 1em;
          margin-inline-start: 1em;
}
.pagination-nav-link :is(.prev, [rel=prev]):before {
  transform: rotate(135deg);
  -webkit-margin-end: 1em;
          margin-inline-end: 1em;
}
@media only screen and (min-width: 75rem) {
  .pagination {
    order: 999;
  }
}
/* Profile https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/profile.md
-------------------------------------------------------------------------------- */
/* Profile Image Skeletons. No need to edit 
--------------------------------------------------------------- */
.profile-image {
  --cover-aspect-w: var(--profile-image-aspect-w);
  --cover-aspect-l: var(--profile-image-aspect-l);
  flex: 0 0 auto;
  position: relative;
  background-color: var(--color-light-alt);
  display: block;
  overflow: clip;
}
.profile-image::before {
  /* hover overlay */
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background: var(--profile-image-overlay-background);
  z-index: 2;
  opacity: 0;
  pointer-events: none;
}
.profile-image-placeholder {
  display: flex;
}
.profile-image-placeholder img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
:is(.profile-image-img, .profile-image-placeholder, .profile-image-placeholder-img) {
  position: absolute;
  inset: 0;
}

:is(.profile-image-img, .profile-image-placeholder-img) {
  max-inline-size: none;
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: var(--profile-image-position);
     object-position: var(--profile-image-position);
}

.profile-image:has(.profile-image-learn-more)::before,
.profile-image:has(.profile-image-learn-more) .profile-image-learn-more {
  pointer-events: none;
}
.profile-image:has(.profile-image-learn-more)::before {
  opacity: var(--profile-image-overlay-opacity);
  mix-blend-mode: var(--profile-image-overlay-mix-blend);
  -webkit-backdrop-filter: var(--profile-image-overlay-backdrop-filter);
          backdrop-filter: var(--profile-image-overlay-backdrop-filter);
  pointer-events: auto;
}
.profile-image:has(.profile-image-learn-more) .profile-image-learn-more {
  opacity: 0;
}
.profile-image:has(.profile-image-learn-more):is(:hover, :focus-within)::before,
.profile-image:has(.profile-image-learn-more):is(:hover, :focus-within) .profile-image-learn-more, .profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-image:has(.profile-image-learn-more)::before,
.profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-image:has(.profile-image-learn-more) .profile-image-learn-more {
  pointer-events: auto;
}
.profile-image:has(.profile-image-learn-more):is(:hover, :focus-within) .profile-image-learn-more, .profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-image:has(.profile-image-learn-more) .profile-image-learn-more {
  opacity: 1;
}
.profile-image:has(.profile-image-learn-more) .profile-image-learn-more {
  /*  */
  z-index: 2;
  position: absolute;
  inset: 0;
  margin: auto;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  max-block-size: -webkit-min-content;
  max-block-size: -moz-min-content;
  max-block-size: min-content;
}

/*
* Profile Image. Customizations https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/profile.md#css-vars
-------------------------------------------------------------------------------- */
.profile-image {
  --profile-image-aspect-w: 25;
  --profile-image-aspect-l: 32.1875;
  --profile-image-position: 50% 15%;
  --profile-image-overlay-background: var(--color-dark-alt)
  	linear-gradient(to bottom right, var(--color-dark), var(--color-dark-alt));
  --profile-image-overlay-opacity: 0;
  --profile-image-overlay-mix-blend: normal;
  --profile-image-overlay-backdrop-filter: blur(2px);
  border-radius: var(--global-radius);
}
/*
* Profile Placeholder. Customizations https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/profile.md#css-vars
-------------------------------------------------------------------------------- */
.profile-image-placeholder {
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 2rem;
  margin: 0;
  background: var(--profile-image-overlay-background, linear-gradient(to bottom right, var(--color-dark-alt), var(--color-dark-alt)));
  font-size: 1.875rem;
  line-height: 1.33;
  font-family: var(--font-accent);
  color: var(--color-light);
  font-weight: 700;
  text-align: center;
  --fancy-background-elesi-width: 30.75rem;
  --fancy-background-elesi-opacity: .2;
  --fancy-background-elesi-transform: scaleX(-1);
  --widget-padding-x: 1.75rem;
  --widget-padding-top: 4.25rem;
  --widget-padding-bottom: 2.875rem;
  border: 2px solid var(--color-accent-alt);
}
.profile-image-placeholder-icon {
  font-size: 6rem;
}
@media only screen and (min-width: 120rem) {
  .profile-image-placeholder-icon {
    font-size: 8rem;
  }
}
/*
* Profile Image Pseudos: wheh linking to a bio page only
-------------------------------------------------------------------------------- */
.profile-image:has(.profile-image-learn-more, [href])::before,
.profile-image:has(.profile-image-learn-more, [href]) .profile-image-learn-more, .profile-image:has(.profile-image-learn-more, [href]) [href] {
  transition: 0.5s ease-in-out all;
}
.profile-image:has(.profile-image-learn-more, [href]):is(:hover, :focus-within), .profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-image:has(.profile-image-learn-more, [href]) {
  --profile-image-overlay-opacity: 0.8;
}
.profile-image:has(.profile-image-learn-more, [href]):is(:hover, :focus-within):has(.profile-image-placeholder), .profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-image:has(.profile-image-learn-more, [href]):has(.profile-image-placeholder) {
  --profile-image-overlay-opacity: .8;
}

/*
* Profile View text
-------------------------------------------------------------------------------- */
/*
* Profile Thumbnail, contains profile image, special blurb, whatever can be included in a thumbnail
-------------------------------------------------------------------------------- */
.profile-thumbnail {
  flex: 0 0 auto;
  align-self: stretch;
  inline-size: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

/* Profile Additional Details. No need to edit 
--------------------------------------------------------------- */
.profile-details-hover {
  opacity: 0;
  display: flex;
  align-items: center;
  align-content: center;
  flex-direction: column;
  text-align: center;
  pointer-events: none;
  position: absolute;
  inset: 0;
  z-index: 10;
  overflow-block: scroll;
  scrollbar-width: none;
}
.profile-details-hover::-webkit-scrollbar {
  display: none;
}
.profile-details-hover::before {
  content: "";
  color: var(--color-light);
  opacity: 0.8;
  position: absolute;
  inset: 0;
  z-index: 0;
}
.profile-details-hover:is(:hover, :focus-within), .profile-pointer-reference:is(:hover, :focus, :focus-within) .profile-details-hover {
  opacity: 1;
  pointer-events: auto;
}
.profile-details-hover-body {
  flex: 1 1;
}

/*
* Profile Additional Details Customizations
-------------------------------------------------------------------------------- */
.profile-details {
  /* view profile hit space/ additional details container */
}
.profile-details-hover {
  padding-block: 3rem;
  padding-inline: 2rem;
  transition: 0.5s ease-in-out all;
  background: var(--color-dark-alt);
  color: var(--color-light);
}
.profile-details-body + .profile-details-footer {
  -webkit-padding-before: 2rem;
          padding-block-start: 2rem;
  align-self: stretch;
}
/*
* Profile Name
-------------------------------------------------------------------------------- */
.profile-name {
  font-size: 2.375rem;
  align-content: center;
}
.profile-details-popup .profile-name {
  font-size: 2.5rem;
}
/*
* Profile Name
-------------------------------------------------------------------------------- */
.profile-position {
  font-size: 1.125rem;
  -webkit-margin-before: auto;
          margin-block-start: auto;
}
/*
* includes/repeater-profile
-------------------------------------------------------------------------------- */
.profile {
  background: var(--color-light-alt);
  align-self: stretch;
  position: relative;
}
.profile .profile-image-learn-more {
  isolation: isolate;
}
.profile {
  /* styles when the profile has a link */
}
.profile:has(:has(.profile-image-learn-more, [href])):is(.profile-pointer-reference):is(:hover, :focus-within) {
  background: var(--color-neutral);
}
.profile {
  max-inline-size: 100%;
}
.profile, .profile-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
}
.profile-details, .profile-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 2.1875rem;
}
.profile:has(.profile-details-default) .profile-summary {
  text-align: initial;
  align-items: initial;
}
.profile-summary {
  flex: 1 1;
}
.profile-summary {
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.75rem;
}
.profile-image {
  inline-size: 100%;
}
.profile-details-popup .profile-image {
  align-self: self-start;
  inline-size: 22.5rem;
  max-inline-size: 100%;
}
.profile-details-popup {
  gap: 3.75rem;
}
.profile-details-popup .profile-details-body {
  display: flex;
  align-self: center;
  flex-direction: column;
  gap: 0.875rem;
}
@media only screen and (min-width: 75rem) {
  .profile-details-popup {
    grid-template-columns: auto 1fr;
    gap: 3.75rem 6.875rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .profile-details-popup .profile-image {
    justify-self: center;
    center-self: center;
    align-self: center;
  }
}
/* Testimonial https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/repeater/testimonial.md
-------------------------------------------------------------------------------- */
/*
* Testimonial Stars
-------------------------------------------------------------------------------- */
.testimonial-stars {
  font-size: 1.5625rem;
}
/*
* Testimonial Highlight / Main quote
-------------------------------------------------------------------------------- */
.testimonial-highlight {
  text-align: inherit;
  max-inline-size: none;
  margin-inline: 0;
}
/*
* Testimonial Quote Body / other parts of the quote
-------------------------------------------------------------------------------- */
.testimonial-quote {
  font-size: 1.375rem;
  line-height: 1.5;
  font-weight: 500;
}
/*
* Testimonial Divider - Optional
-------------------------------------------------------------------------------- */
.testimonial-divider {
  --fancy-border-margin-y: 0em;
}
/*
* Testimonial Source + Optional Icon
-------------------------------------------------------------------------------- */
.testimonial-source-default {
  font-size: 1.25rem;
  line-height: 1;
  font-weight: 700;
}
.testimonial-source {
  display: contents;
}
.testimonial-source.testimonial-source-has-first-letter::before {
  content: attr(data-first-letter);
  display: flex;
  align-content: center;
  align-items: center;
  justify-content: center;
  inline-size: 1.75em;
  block-size: 1.75em;
  border-radius: 999em;
  background: var(--scheme-sp, var(--color-primary));
  font-size: 1.125rem;
  font-family: var(--font-accent);
  color: var(--color-light);
  text-transform: uppercase;
}
:where(.content-palette-dark) .testimonial-source {
  color: var(--scheme-sp, inherit);
}
.testimonial-source-icon {
  font-size: 1.9375rem;
}
.testimonial-mini .testimonial-source-icon {
  font-size: 2rem;
}
/*
* includes/repeater-testimonial
-------------------------------------------------------------------------------- */
.testimonial {
  max-inline-size: 100%;
}
.testimonial, .testimonial-container {
  display: grid;
  grid-template-columns: 1fr auto;
  min-inline-size: 0;
  flex-direction: column;
  gap: 1.25rem;
}
.testimonial,
.testimonial > *, .testimonial-container,
.testimonial-container > * {
  min-inline-size: 0;
}
.testimonial-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 0.75rem;
  grid-auto-rows: -webkit-max-content;
  grid-auto-rows: max-content;
}
.testimonial .testimonial-highlight,
.testimonial .testimonial-source,
.testimonial .testimonial-quote {
  grid-column: 1/-1;
}
.testimonial .testimonial-stars {
  grid-column: -2;
  order: -1;
  align-self: center;
}
.testimonial .testimonial-source-icon {
  grid-column: 1;
  order: -2;
  justify-self: start;
  align-self: center;
}
.testimonial .testimonial-quote {
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
}
.testimonial .testimonial-source > span:first-child {
  align-self: self-end;
}
/* Video Button - Default (One that doesnt have custom markup in it, just the usual one with a play symbol)
https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/video-button.md
--------------------------------------------------------------- */
/* Video Button Skeletons. No need to edit 
--------------------------------------------------------------- */
@keyframes video-button-default-text-rotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
.video-button-html .wistia-embed {
  display: contents !important;
}

.video-button-default {
  display: inline-flex;
  block-size: var(--video-button-size);
  aspect-ratio: 1/1;
  position: relative;
  font-size: var(--video-button-size);
  z-index: 0;
  cursor: pointer;
  align-items: center;
  justify-content: center;
}
.video-button-default:is(.video-button-no-api) {
  pointer-events: none;
}
.video-thumbnail .video-button-default {
  /* customize instances of video button within thumbnail*/
  position: absolute;
  z-index: 1;
  inset: 0;
  margin: auto;
}
.video-button-default-image, .video-button-default-text, .video-button-default-text-svg, .video-button-default-text span, .video-button-default::before, .video-button-default::after {
  position: absolute;
  margin: auto;
  pointer-events: none;
}
.video-button-default-text, .video-button-default-image {
  inset: 0;
}
.video-button-default.video-button-default-no-icon::before, .video-button-default.video-button-default-no-icon::after {
  content: "";
  display: block;
}
.video-button-default > .wistia_click_to_play {
  position: static !important;
  inline-size: auto !important;
  block-size: auto !important;
}
.video-button-default-glyph {
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 100%;
  block-size: 100%;
}
.video-button-default-glyph::before {
  content: "";
  display: block;
  width: var(--video-button-glyph-width);
  height: var(--video-button-glyph-height);
  background: var(--video-button-glyph-color, currentColor);
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.video-button-default-glyph:not(.video-button-default-glyph-has-text) {
  padding-left: calc(var(--video-button-glyph-width) * 0.25);
}
.video-button-default-glyph-has-text::before {
  content: none;
}
.video-button-default-text {
  font-size: var(--video-button-glyph-height);
}
.video-button-default-text-svg {
  transform-style: preserve-3d;
  max-inline-size: none;
  inset: -100%;
  margin: auto;
  font-size: calc(1em * 1 / var(--video-button-text-svg-radius-ratio));
  inline-size: calc(200% * var(--video-button-text-svg-radius-ratio));
  block-size: calc(200% * var(--video-button-text-svg-radius-ratio));
}
.video-button-default-text-svg-path {
  transform-origin: center center;
}
.video-button-default-text-html span {
  inset-block-start: 0;
  inset-block-end: 0;
  inline-size: -webkit-max-content;
  inline-size: -moz-max-content;
  inline-size: max-content;
  block-size: -webkit-max-content;
  block-size: -moz-max-content;
  block-size: max-content;
}
.video-button-default-text-html span:not(.video-button-default-text-html-separator):first-child {
  inset-inline-end: 100%;
  -webkit-margin-end: 1em;
          margin-inline-end: 1em;
}
.video-button-default-text-html span:not(.video-button-default-text-html-separator):last-child {
  inset-inline-start: 100%;
  -webkit-margin-start: 1em;
          margin-inline-start: 1em;
}
.video-button-default-image-init:not(:only-child), .video-button-default:is(:hover, :focus) .video-button-default-image-hover, .video-pointer-reference:is(:hover, :focus, :focus-within) .video-button-default-image-hover {
  opacity: 1;
}

.video-button-default-image-hover, .video-button-default:is(:hover, :focus) .video-button-default-image-init:not(:only-child), .video-pointer-reference:is(:hover, :focus, :focus-within) .video-button-default-image-init:not(:only-child) {
  opacity: 0;
}

/* Video Button Customizations: https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/video-button.md#css-vars
--------------------------------------------------------------- */
.video-button-default {
  --video-button-size: 4rem;
  /* size of video button by height and or width */
  --video-button-text-svg-radius-ratio: 1.25;
  /*  ratio of svg path for rounded text. */
  --video-button-text-svg-start-offset: 50%;
  /*  offset of svg text */
  --video-button-glyph-height: 20%;
  /* height for video play triangle glyph*/
  /* Tip: set as ems so the play symbol scales along with the actual button */
  --video-button-glyph-width: 18%;
  /* width for video play triangle glyph*/
  /* Tip: set as ems so the play symbol scales along with the actual button */
  --video-button-glyph-color: currentColor;
  /* color of the video button glyph. Used as a background-color so it can take gradients too */
  color: var(--color-light);
}
.video-button-default, .video-button-default-image, .video-button-default-text, .video-button-default::before, .video-button-default::after, .video-button-default-thumbnail-markup::after {
  transition-duration: 0.25s;
  transition-timing-function: ease-in-out;
}
.video-button-default, .video-button-default-image, .video-button-default-text, .video-button-default-thumbnail-markup::after {
  transition-property: opacity, left, top, bottom, right, width, height;
}
.video-button-default::before, .video-button-default::after {
  transition-property: all;
}
.video-thumbnail .video-button-default {
  /* customize instances of video button within thumbnail*/
  --video-button-size: clamp(3rem,50%,10rem);
}
.video-thumbnail .video-button-default:is(:hover, :focus), .video-pointer-reference:is(:hover, :focus, :focus-within) .video-thumbnail .video-button-default {
  --video-thumbnail-overlay-opacity: 0.8;
}
@media only screen and (min-width: 87.5rem) {
  .video-button-default {
    --video-button-size: 6.25rem;
  }
}
.video-button-default-glyph::before {
  -webkit-clip-path: polygon(0 0, 100% 50%, 0 100%);
          clip-path: polygon(0 0, 100% 50%, 0 100%);
}
.video-button-default-text {
  font-size: 0.75rem;
  line-height: 1;
  color: var(--color-neutral);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-weight: 700;
}
.video-button-default-text-separator {
  color: inherit;
}
.video-button-default-text-svg {
  transform: rotate(32deg);
  color: inherit;
}
.video-button-default-text-html > span {
  inset-block-start: 0;
  inset-block-end: 0;
}
.video-button-default.video-button-default-no-icon {
  /* tru element/background */
  /* these are basic styles. overhaul as needed */
  background: rgba(255, 255, 255, 0.2);
  box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.2);
}
.video-button-default.video-button-default-no-icon, .video-button-default.video-button-default-no-icon::before, .video-button-default.video-button-default-no-icon::after {
  /* these are basic styles. overhaul as needed */
  border-radius: 999em;
  transform-origin: center center;
  transform-style: preserve-3d;
  transform: scale(1);
  margin: auto;
}
.video-button-default.video-button-default-no-icon::before {
  /* fake extra background */
  /* these are basic styles. overhaul as needed */
  background: linear-gradient(to bottom, var(--color-primary-gradient-start), var(--color-primary-gradient-end));
  z-index: -1;
  inset: 12.5%;
}
.video-button-default.video-button-default-no-icon::after {
  /* other element for fx */
  /* these are basic styles. overhaul as needed */
  border: 0.0125em solid var(--color-accent);
  inset: 18%;
}
.video-button-default.video-button-default-no-icon:is(:hover, :focus), .video-pointer-reference:is(:hover, :focus, :focus-within) .video-button-default.video-button-default-no-icon {
  /* on hover on itself/ containing repeater/ .video-pointer-reference */
  --video-button-glyph-color: linear-gradient(
  	to bottom,
  	var(--color-light-alt),
  	var(--color-light)
  );
  /* these are basic styles. overhaul as needed */
  box-shadow: 0 0 0 0.1em rgba(255, 255, 255, 0.2);
}
.video-button-default.video-button-default-no-icon:is(:hover, :focus)::before, .video-pointer-reference:is(:hover, :focus, :focus-within) .video-button-default.video-button-default-no-icon::before {
  /* these are basic styles. overhaul as needed */
  background: linear-gradient(to bottom, var(--color-primary-gradient-start), var(--color-primary-gradient-end));
  transform: scale(1.25);
}
.video-button-default.video-button-default-no-icon:is(:hover, :focus)::after, .video-pointer-reference:is(:hover, :focus, :focus-within) .video-button-default.video-button-default-no-icon::after {
  /* these are basic styles. overhaul as needed */
  transform: scale(0.98);
}
.video-thumbnail .video-button-default.video-button-default-no-icon:is(:hover, :focus), .video-pointer-reference:has(.video-thumbnail .video-button-default.video-button-default-no-icon):is(:hover, :focus-within) .video-button-default.video-button-default-no-icon {
  /* these are basic styles. overhaul as needed */
}
.video-thumbnail .video-button-default.video-button-default-no-icon:is(:hover, :focus)::before, .video-pointer-reference:has(.video-thumbnail .video-button-default.video-button-default-no-icon):is(:hover, :focus-within) .video-button-default.video-button-default-no-icon::before {
  /* these are basic styles. overhaul as needed */
}
.video-thumbnail .video-button-default.video-button-default-no-icon:is(:hover, :focus)::after, .video-pointer-reference:has(.video-thumbnail .video-button-default.video-button-default-no-icon):is(:hover, :focus-within) .video-button-default.video-button-default-no-icon::after {
  /* these are basic styles. overhaul as needed */
}

/* Video Pointer Reference
--------------------------------------------------------------- */
.video-pointer-reference:not(:has(.vode-thumbnail:not(:has(.video-button)))) {
  cursor: pointer;
}

/* Video Thumbnail https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/video-thumbnail.md
--------------------------------------------------------------- */
/* Video Thumbnail Skeletons. No need to edit 
--------------------------------------------------------------- */
.video-thumbnail {
  --cover-aspect-w: var(--video-thumbnail-aspect-w);
  --cover-aspect-l: var(--video-thumbnail-aspect-l);
  flex: 0 0 auto;
  position: relative;
  background-color: var(--color-light-alt);
}
.video-thumbnail-markup {
  border-radius: inherit;
  overflow: hidden;
}
.video-thumbnail-markup[href]::after, .video-thumbnail-markup.wistia_embed::after {
  /* overlay */
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: var(--video-thumbnail-overlay-background);
  opacity: var(--video-thumbnail-overlay-opacity);
  mix-blend-mode: var(--video-thumbnail-overlay-mix-blend);
  -webkit-backdrop-filter: var(--video-thumbnail-overlay-backdrop-filter);
          backdrop-filter: var(--video-thumbnail-overlay-backdrop-filter);
}
.video-thumbnail-markup-img img {
  max-inline-size: none;
}

/* force object fit cover where we need to, im looking at you wistia
--------------------------------------------------------------- */
:is(.video-thumbnail-markup > *, .video-thumbnail-markup img) {
  inline-size: 100% !important;
  block-size: 100% !important;
  max-inline-size: none !important;
  max-block-size: none !important;
  position: absolute !important;
  inset: 0 !important;
  -o-object-fit: cover !important;
     object-fit: cover !important;
  margin: 0 !important;
}

/* Video Thumbnail
https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/includes/helper/video-thumbnail.md#css-vars
--------------------------------------------------------------- */
.video-thumbnail {
  --video-thumbnail-aspect-w: 16;
  --video-thumbnail-aspect-l: 9;
  --video-thumbnail-overlay-background: var(--color-dark-alt)
  	linear-gradient(to bottom right, var(--color-dark), var(--color-dark-alt));
  --video-thumbnail-overlay-opacity: 0;
  --video-thumbnail-overlay-backdrop-filter: none;
  --video-thumbnail-overlay-mix-blend: multiply;
}
.video-thumbnail:is(:hover, :focus), .video-pointer-reference:is(:hover, :focus, :focus-within) .video-thumbnail {
  --video-thumbnail-overlay-opacity: 0.8;
}
.video-thumbnail-markup[href]::after, .video-thumbnail-markup.wistia_embed::after {
  /* overlay */
  transition: 0.25s ease-in-out all;
}

/* includes/repeater-video
--------------------------------------------------------------- */
.video {
  /* styles when the video has a link */
}
.video {
  max-inline-size: 100%;
}
.video, .video-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
}
.video-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 1rem;
}
.video-title {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  margin-block: 0;
  flex: 1 1;
}
/* ================================================================================
* Parts 
================================================================================ */
/* Review Us Page https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/parts/review-us.md
--------------------------------------------------------------- */
.review-us {
  text-align: center;
}
.review-us-columns {
  --columns-gap-x: 4em;
  --columns-gap-y: 2em;
  align-items: flex-end;
  justify-content: center;
}
.review-us-columns .button {
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
}
.review-us, .review-us-video {
  -webkit-margin-before: 3em;
          margin-block-start: 3em;
}
@media only screen and (min-width: 48rem) {
  .review-us-columns {
    --columns-number: 2;
  }
  .review-us-columns .button {
    inline-size: 100%;
  }
}
/* Awards https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/parts/awards.md
--------------------------------------------------------------- */
.awards {
  inline-size: 122rem;
  justify-self: center;
}
.awards:where(.section-blocks :has(.awards-container:is(.container))) {
  inline-size: 122rem;
  justify-self: center;
}
.awards :is(.swiper) {
  --carousel-height: 4.375rem;
  --swiper-custom-arrow-offset-x: 0rem;
}
/* ================================================================================
* Header
================================================================================ */
/* Layout Header https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/header.md
Note: The styles will be setup mobile first starting with the smallest device comp where the header menu toggle is no longer visible  (usually initially at md/laptop)
And then Desktop first starting with the largest device comp where the the header toggle is visible (Usually sm/tablet)
Tip: setting up mobile navigation desktop-first starting at sm-max for touch screen styles, and then mobile-first starting at md for desktop styles helps simplify the styles and lessen the need for overrides.
Also Tip: Default styles are set based on its sticky state, and then overriding these styles when no scroll has happened yet (.doc-header-not-sticky). This is to keep styles less repetitive and as simple as possible
--------------------------------------------------------------- */
/* Layout Header Variables
--------------------------------------------------------------- */
/* Tip: placing the css var on :root can allow elements outside of the layout header utilize the variable if needed ie sticky stuff, offsets, jump link scroll etc. */
:root {
  --layout-header-height: 8rem;
  /* initial height of the whole header */
  --layout-header-height-before-sticky: var(--layout-header-height);
  /* height of the whole header on overlap/ before sticky */
  --layout-header-offset: 0rem;
  /* How far off the header is from the top of the viewport. This is specially useful for .header-can-overlap styles before sticky-ing */
  --layout-header-logo-height: var(--layout-header-height);
  /* height of logo including its padding at a given state or layout. */
}
@media only screen and (min-width: 75rem) {
  :root {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (min-width: 87.5rem) {
  :root {
    --layout-header-height: 9rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :root {
    /* Touch Devices Header Styles Start */
    --layout-header-height: 9.5rem;
    /* offset: one top value might work for the design. NOTE: adjust ilawyer alertbar settings accordingly if enabled (dynamic margin, offset to bottom on touch devices, position, etc.) */
  }
}
@media only screen and (max-width: 47.9375rem) {
  :root {
    --layout-header-height: 8.125rem;
    --layout-header-logo-height: 5.8125rem;
    --layout-header-height-before-sticky: 10.75rem;
    /* offset: one top value might work for the design. NOTE: adjust ilawyer alertbar settings accordingly if enabled (dynamic margin, offset to bottom on touch devices, position, etc.) */
  }
}
.doc-header-not-sticky .header-can-overlap {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
  /* Top: Avoid changing the --layout-header-height in this state to prevent the document from shifting on scroll */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap {
    /* override logo height apart form the header height on this state only. Adjust as needed */
    /* set to before sticky height */
    --layout-header-logo-height: 8.5rem;
    /* set to a weirder height */
    --layout-header-offset: 3rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .doc-header-not-sticky .header-can-overlap {
    --layout-header-logo-height: 10.125rem;
    --layout-header-offset: 2.125rem;
  }
}
@media only screen and (min-width: 120rem) {
  .doc-header-not-sticky .header-can-overlap {
    --layout-header-logo-height: 11.5rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap {
    --layout-header-logo-height: 9rem;
    --layout-header-offset: 1.25rem;
    /* Touch Devices Header Styles Start */
    /* offset: one top value might work for the design. NOTE: adjust ilawyer alertbar settings accordingly if enabled (dynamic margin, offset to bottom on touch devices, position, etc.) */
  }
}
@media only screen and (max-width: 47.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap {
    --layout-header-logo-height: 7rem;
    --layout-header-offset: 0rem;
  }
}

.doc-header-menu-open {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
@media only screen and (max-width: 74.9375rem) {
  .doc-header-menu-open {
    /* DO NOT ENABLE. Safari has a bug that conflicts the window scrollbar as of 06/24 */
    /* overflow-block:hidden; */
  }
}
/* Offset the scroll by the header height so the element a jump link scrolls to us not underneath the header but instead compensates to the header height and scrolls just next to it
--------------------------------------------------------------- */
html,
body {
  scroll-padding-block-start: calc(var(--layout-header-height) + var(--layout-header-offset, 0px)) !important;
}

/* Layout Header Overlaps
	NOTE: Classes to use:
		.has-layout-header-offset => the element within the layout that will have the negative margins to overlap itself
--------------------------------------------------------------- */
.header-can-overlap .has-layout-header-offset:not(:has(.has-layout-header-offset)):first-child:is(:is(.template-wrapper > :first-child),
:is(.template-wrapper > :first-child) *)::before {
  content: "";
  flex: 0 0 auto;
  grid-column: 1/-1;
  block-size: var(--layout-header-height-before-sticky);
  display: block;
  inline-size: 100%;
}
.header-can-overlap:has(.has-layout-header-offset) .layout-header {
  position: fixed;
}
/* Layout Header Itself
--------------------------------------------------------------- */
.layout-header {
  /* Note: position must be set initially, NOT based on whether or not a scroll has occured (sticky vs not-sticky class). This is to prevent layout jumps on scroll */
  position: -webkit-sticky;
  position: sticky;
  isolation: isolate;
  inset-block-start: var(--layout-header-offset, 0px);
  inset-inline-start: 0;
  z-index: 999;
  inline-size: 100%;
  color: var(--scheme-fg, var(--color-dark));
  transition: 0.25s top ease-in-out;
}
.layout-header,
.layout-header .header-nav .menu::before {
  background-color: var(--color-light-alt);
  background-image: linear-gradient(0deg, var(--color-light-alt, #FFFDFA) 0%, var(--color-neutral-light, #DDEEF0) 100%);
  box-shadow: 0 0 10px -5px rgba(0, 0, 0, 0.8);
  border-radius: 0 0 var(--global-radius) var(--global-radius);
}
.layout-header .header-nav .menu::before {
  position: -webkit-sticky;
  position: sticky;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: 99;
}
.layout-header-container {
  --container-gutter: 2.4375rem;
}
@media only screen and (min-width: 75rem) {
  .layout-header {
    /* Non-touch Devices Header Styles Start */
  }
  .layout-header-container {
    --container-gutter: 1.125rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .layout-header-container {
    --container-gutter: 2rem;
  }
}
@media only screen and (min-width: 120rem) {
  .layout-header-container {
    --container-gutter: 2.375rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .layout-header {
    /* Touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 47.9375rem) {
  .layout-header-container {
    --container-gutter: 2rem;
  }
}
.doc-header-not-sticky .header-can-overlap .layout-header {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .layout-header {
    background: transparent;
    color: var(--color-light);
    box-shadow: none;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .layout-header {
    /* Touch Devices Header Styles Start */
    background: transparent;
    color: var(--color-light);
    box-shadow: none;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .layout-header-container {
    --container-gutter: 1.25rem;
  }
}

.doc-header-not-sticky .layout-header {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
@media only screen and (max-width: 47.9375rem) {
  .doc-header-not-sticky .layout-header {
    /* reset offset when no scrolling yet */
  }
}
.doc-header-menu-open .layout-header {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
.header-can-overlap .layout-header {
  /* Overlay header on header-can-overlap. best for setting position on large devices AND NOTHING ELSE */
}
/* Header Blocks - How elements will be layed out in the header
--------------------------------------------------------------- */
:where(.header-block, .header-blocks) {
  /* uncomment if flex/grid is causing any issues*/
  min-inline-size: 0;
}

.header-blocks {
  justify-content: center;
  align-items: center;
  -moz-column-gap: var(--container-gutter);
       column-gap: var(--container-gutter);
  row-gap: 0rem;
  inline-size: auto;
  block-size: var(--layout-header-height);
}
.header-block:is(.header-logo) {
  grid-area: logo;
  justify-self: self-start;
  block-size: var(--layout-header-logo-height);
}
.header-block:is(.header-nav) {
  grid-area: nav;
}
.header-block:is(.header-cta) {
  grid-area: cta;
}
.header-block:is(.header-toggle-menu) {
  grid-area: toggle-menu;
  align-self: center;
}
.header-block:is(.header-banner-buttons) {
  grid-area: banner-buttons;
  min-inline-size: -webkit-min-content;
  min-inline-size: -moz-min-content;
  min-inline-size: min-content;
}
@media only screen and (min-width: 75rem) {
  .header-block {
    /* Non-touch Devices Header Styles Start */
  }
  .header-blocks {
    grid-template-columns: auto 1fr;
    grid-template-rows: minmax(0, 1fr) auto;
    grid-template-areas: "logo cta" "logo nav";
    -moz-column-gap: 0rem;
         column-gap: 0rem;
    row-gap: 0.4rem;
  }
  .header-block:is(.header-logo) {
    align-self: start;
    inset-block: 0.25rem;
  }
  .header-block:is(.header-nav) {
    align-self: self-end;
    justify-self: self-end;
    -webkit-margin-after: 0.9375rem;
            margin-block-end: 0.9375rem;
  }
  .header-block:is(.header-cta) {
    justify-self: self-end;
    align-self: self-end;
  }
}
@media only screen and (min-width: 120rem) {
  .header-block:is(.header-nav) {
    -webkit-margin-after: 1rem;
            margin-block-end: 1rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-block {
    /* Touch Devices Header Styles Start */
  }
  .header-blocks {
    -moz-column-gap: 1.625rem;
         column-gap: 1.625rem;
    row-gap: 0.75rem;
    grid-template-columns: auto 1fr auto;
    grid-template-rows: auto minmax(0, 1fr);
    grid-template-areas: "logo banner-buttons toggle-menu" "logo cta toggle-menu";
  }
  .header-block:is(.header-cta) {
    justify-self: self-end;
    align-self: self-start;
  }
  .header-block:is(.header-toggle-menu) {
    align-self: center;
  }
  .header-block:is(.header-banner-buttons) {
    justify-self: self-end;
    align-self: self-end;
    -webkit-margin-before: 0.875rem;
            margin-block-start: 0.875rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-blocks {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto 1fr;
    grid-template-areas: "cta cta" "logo toggle-menu";
    row-gap: 0;
  }
  .header-block:is(.header-cta) {
    justify-self: stretch;
    align-self: stretch;
    margin-inline: calc(var(--container-gutter) * -1);
  }
}
.doc-header-not-sticky .header-can-overlap .header-block {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .header-blocks {
    row-gap: 1.25rem;
    block-size: var(--layout-header-height-before-sticky);
  }
  .doc-header-not-sticky .header-can-overlap .header-block:is(.header-logo) {
    inset-block-start: -7%;
  }
}
@media only screen and (min-width: 87.5rem) {
  .doc-header-not-sticky .header-can-overlap .header-block:is(.header-logo) {
    inset-block-start: -16%;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-block {
    /* Touch Devices Header Styles Start */
  }
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-blocks {
    min-block-size: var(--layout-header-height-before-sticky);
  }
}
.doc-header-not-sticky .header-block {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.header-block .doc-header-menu-open {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
/* Header Logo
--------------------------------------------------------------- */
.header-logo {
  padding-block: 0.96rem;
  flex: 0 0 auto;
  /* support logo offseting on overlay banner + not sticky state. comment if not needed */
  position: relative;
}
.header-logo .logo-wrapper-br, .header-logo .logo-wrapper-before-sticky {
  /* hide possible variations of logo */
  display: none;
}
@media only screen and (min-width: 75rem) {
  .header-logo {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-logo {
    /* Touch Devices Header Styles Start */
    padding-block: 1.3rem 1.5rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-logo {
    padding-block: 0.96rem;
  }
  .header-logo .logo-wrapper-br {
    /* show  */
    display: block;
  }
  .header-logo .logo-wrapper-br ~ .logo-wrapper-nonbr {
    display: none;
  }
}
.doc-header-not-sticky .header-can-overlap .header-logo {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .header-logo {
    background-color: transparent;
    padding-block: 0;
  }
  .doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-sticky, .doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-before-sticky ~ .logo-wrapper-br {
    /* hide default logo on before sticky */
    display: none;
  }
  .doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-before-sticky {
    /* show  */
    display: block;
  }
  .doc-header-not-sticky .header-can-overlap .header-logo {
    /* Any other styles for emphasis on logo on this state. Adjust as needed. Adjust as needed */
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-logo {
    padding-block: 0;
    /* Touch Devices Header Styles Start */
  }
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-sticky, :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-before-sticky ~ .logo-wrapper-br {
    /* hide default logo on before sticky */
    display: none;
  }
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-logo .logo-wrapper-before-sticky {
    /* show  */
    display: block;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-logo {
    padding-block: 0.875rem 0.55rem;
  }
}

.doc-header-not-sticky .header-logo {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-logo {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
/* Header Toggle/s - Scaffolding for usual box buttons
--------------------------------------------------------------- */
.header-toggle {
  inline-size: 4.375rem;
  block-size: 5.1875rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  flex: 0 0 auto;
  padding: 0;
  border-radius: var(--global-radius-small);
}
@media only screen and (min-width: 75rem) {
  .header-toggle {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-toggle {
    /* Touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-toggle {
    inline-size: 3.6875rem;
    block-size: 3.75rem;
  }
}
.doc-header-not-sticky .header-can-overlap .header-toggle {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-toggle {
    /* Touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 47.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-toggle {
    block-size: 4.125rem;
  }
}

.doc-header-not-sticky .header-toggle {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
@media only screen and (max-width: 74.9375rem) {
  .doc-header-not-sticky .header-toggle {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-menu-open .header-toggle {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
@media only screen and (max-width: 74.9375rem) {
  .doc-header-menu-open .header-toggle {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-menu-open.doc-header-not-sticky .header-toggle {
  /* Styles/Selectors for when header menu accordion for touch devices is open and header is not sticky yet */
}
@media only screen and (max-width: 74.9375rem) {
  .doc-header-menu-open.doc-header-not-sticky .header-toggle {
    /* Touch Devices Header Styles Start */
  }
}
/* Header Toggle - Menu
--------------------------------------------------------------- */
.header-toggle-menu {
  --layout-header-menu-toggle-open-offset: 0rem;
  /* How far off the toggle is from its original position. useful for mobile when the layout of the header shifts around and the toggle is positioned weird over the menu when it's open */
  background: var(--color-light-alt, #FFFDFA) linear-gradient(0deg, var(--color-light-alt, #FFFDFA) 0%, var(--color-neutral-light, #DDEEF0) 100%);
  box-shadow: 0 2px 10px 0 rgba(106, 114, 116, 0.5);
  color: var(--color-dark);
  position: relative;
  z-index: 99999;
  inset-block-start: 0;
  transition: 0.375s all ease-in-out;
  order: 99;
}
.header-toggle-menu.open {
  inset-block-start: var(--layout-header-menu-toggle-open-offset);
}
.header-toggle-menu-icon {
  --fancy-icon-menu-width: 3.125rem;
  --fancy-icon-menu-height: 1.8125rem;
  --fancy-icon-menu-bar-height: 5px;
}
.header-toggle-menu-icon > span {
  border-radius: 9999rem;
}
.header-toggle-menu.open .header-toggle-menu-icon {
  color: inherit;
}
.header-toggle-menu-label {
  font-size: 0.75rem;
  font-family: var(--font-accent);
  text-transform: uppercase;
  font-style: normal;
  font-weight: 700;
  text-align: center;
  -webkit-margin-before: 0.5em;
          margin-block-start: 0.5em;
  transition: 0.375s all ease-in-out;
}
.header-toggle-menu.open .header-toggle-menu-label {
  -webkit-margin-before: -1em;
          margin-block-start: -1em;
  opacity: 0;
}
.header-toggle-menu.open .header-toggle-menu-label:nth-last-child(2) {
  display: none;
}
.header-toggle-menu:not(.open) .header-toggle-menu-label:nth-child(3) {
  display: none;
}
@media only screen and (min-width: 75rem) {
  .header-toggle-menu {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-toggle-menu {
    /* Touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-toggle-menu-icon {
    --fancy-icon-menu-width: 2.5rem;
  }
}
.doc-header-not-sticky .header-can-overlap .header-toggle-menu {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-toggle-menu {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-toggle-menu {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-toggle-menu {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
.doc-header-menu-open.doc-header-not-sticky .header-toggle-menu {
  /* Styles/Selectors for when header menu accordion for touch devices is open and header is not sticky yet */
}
/* Header Toggle - Other Block toggles
--------------------------------------------------------------- */
@media only screen and (min-width: 75rem) {
  .header-toggle- {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-toggle- {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-can-overlap .header-toggle- {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-toggle- {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-toggle- {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-toggle- {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
.doc-header-menu-open.doc-header-not-sticky .header-toggle- {
  /* Styles/Selectors for when header menu accordion for touch devices is open and header is not sticky yet */
}
/* Header CTA
--------------------------------------------------------------- */
.header-cta {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: right;
  gap: 1rem;
}
@media only screen and (min-width: 75rem) {
  .header-cta {
    /* Non-touch Devices Header Styles Start */
    align-items: flex-end;
    gap: 1.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  .header-cta {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-cta {
    /* Touch Devices Header Styles Start */
    gap: 0.125rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-cta {
    text-align: center;
    align-items: center;
    flex: 1 1;
    padding-block: 0.875rem 0;
  }
}
.doc-header-not-sticky .header-can-overlap .header-cta {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-cta {
    /* Touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 47.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-cta {
    padding-block: 1.25rem;
    background: var(--color-light-alt, #FFFDFA) linear-gradient(0deg, var(--color-light-alt, #FFFDFA) 0%, var(--color-neutral-light, #DDEEF0) 100%);
    color: var(--color-dark);
  }
}

.doc-header-not-sticky .header-cta {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-cta {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
/* Header CTA - Text
--------------------------------------------------------------- */
.header-cta-text {
  line-height: 1.5;
  font-family: var(--font-accent);
  color: var(--color-accent);
  text-transform: uppercase;
}
.header-cta-text > span:nth-child(n+2)::before {
  content: "\25CF\FE0E";
  color: var(--color-primary);
  letter-spacing: 0em;
  margin: 0 0.5em;
}
@media only screen and (min-width: 48rem) {
  .header-cta-text {
    /* Non-touch Devices Header Styles Start */
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-cta-text {
    /* Touch Devices Header Styles Start */
    margin-block: 0 1.125rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-cta-text {
    align-self: center;
    margin-block: 0.75rem 2.75rem;
  }
}
.doc-header-not-sticky .header-can-overlap .header-cta-text {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .header-cta-text {
    color: inherit;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-cta-text {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-cta-text {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-cta-text {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
/* Header Number/s
--------------------------------------------------------------- */
.header-numbers {
  display: inline-flex;
  justify-content: inherit;
  justify-items: inherit;
  -moz-column-gap: 1rem;
       column-gap: 1rem;
}
.header-numbers .number {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.header-numbers .number-title {
  font-size: 0.875rem;
}
.header-numbers .number-link {
  font-size: 1.25rem;
}
.header-numbers .number-subtitle {
  font-size: 0.5rem;
  line-height: 1.62;
  font-family: var(--font-primary);
  display: block;
}
@media only screen and (min-width: 48rem) {
  .header-numbers .number-title {
    font-size: 1.125rem;
  }
  .header-numbers .number-link {
    font-size: 1.5625rem;
    line-height: 1;
  }
  .header-numbers .number-subtitle {
    font-size: 0.625rem;
    margin-block: 0.25rem 0;
  }
}
@media only screen and (min-width: 75rem) {
  .header-numbers {
    /* Non-touch Devices Header Styles Start */
  }
  .header-numbers .number {
    margin-block: 0.25rem 0;
    -moz-column-gap: 0.625rem;
         column-gap: 0.625rem;
  }
  .header-numbers .number-title {
    font-size: 1.25rem;
    align-self: flex-end;
    margin-block: 0 0.375rem;
  }
  .header-numbers .number-subtitle {
    font-size: 0.75rem;
  }
  .header-numbers .number-link {
    font-size: 2.0625rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .header-numbers .number {
    -moz-column-gap: 1.25rem;
         column-gap: 1.25rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-numbers {
    /* Touch Devices Header Styles Start */
  }
  .header-numbers .number {
    -moz-column-gap: 0.375rem;
         column-gap: 0.375rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-numbers .number {
    -moz-column-gap: 0.5rem;
         column-gap: 0.5rem;
  }
  .header-numbers .number-title {
    align-self: flex-end;
    margin-block: 0 0.25rem;
  }
}
.doc-header-not-sticky .header-can-overlap .header-numbers {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-numbers {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-numbers {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-numbers {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
.header-banner-buttons {
  min-inline-size: -webkit-min-content;
  min-inline-size: -moz-min-content;
  min-inline-size: min-content;
  flex: 0 0 auto;
}
.header-banner-buttons, .header-banner-buttons .button {
  align-self: stretch;
}

.header-banner-buttons .button {
  font-size: 1.0625rem;
}
@media only screen and (min-width: 87.5rem) {
  .header-banner-buttons .button {
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-banner-buttons {
    /* Touch Devices Header Styles Start */
  }
  .header-banner-buttons .button {
    --button-padding-y: .875em;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-banner-buttons {
    align-self: center;
  }
}

/* Header Navigation
--------------------------------------------------------------- */
.header-nav {
  --layout-header-menu-touch-offset: 0rem;
  /* top offset of nav overlay on touch devices to the viewport */
}
@media only screen and (min-width: 75rem) {
  .header-nav {
    /* Non-touch Devices Header Styles Start */
  }
  .header-nav {
    display: flex;
    flex: 1 1;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-nav {
    /* Touch Devices Header Styles Start */
    transition: top 0.25s ease-in-out, left 0.5s ease-in-out, opacity 0.5s ease-in-out;
    inline-size: 100%;
    overflow-inline: hidden;
    overflow-block: scroll;
    background: rgba(0, 0, 0, 0.8);
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    opacity: 0;
    z-index: -1;
    scrollbar-inline-size: none;
    position: fixed;
    inset-block-end: 0;
    inset-inline-start: 100%;
    inset-block-start: var(--layout-header-menu-touch-offset);
    box-shadow: inset 0 5px 10px -5px rgba(0, 0, 0, 0.8);
  }
  .header-nav::-webkit-scrollbar {
    display: none;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-nav {
    --layout-header-menu-touch-offset: 0;
  }
}
.doc-header-not-sticky .header-can-overlap .header-nav {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .header-nav {
    color: inherit;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-nav {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-nav {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-nav {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
@media only screen and (max-width: 74.9375rem) {
  .doc-header-menu-open .header-nav {
    inset-inline-start: 0%;
    opacity: 1;
  }
}
.doc-header-menu-open.doc-header-not-sticky .header-nav {
  /* Styles/Selectors for when header menu accordion for touch devices is open and header is not sticky yet */
}
/* Header Navigation Menu
--------------------------------------------------------------- */
.header-nav .menu {
  --layout-header-menu-touch-menu-padding-x: 6.125rem;
  /* horizontal padding for menu items and accordion/dropdowns */
  --layout-header-menu-nontouch-dropdown-padding-x: 1.875rem;
  /* horizontal padding for menu items and accordion/dropdowns
  NOTE: Keep horizontal padding on the li items instead of the containing ul/dropdown to maintain hover hitspace or so that the next level of dropdown does not disappear while you hover to it */
  --layout-header-menu-nontouch-current-height: 0px;
  /* current item border indicator height */
}
.header-nav .menu > .menu {
  display: contents;
}
.header-nav .menu > .menu::before {
  content: none;
}
.header-nav .menu {
  font-size: 1rem;
  line-height: 1.125;
  color: inherit;
  font-weight: 600;
}
.header-nav .menu:is(ul) li {
  display: flex;
  flex-wrap: wrap;
}
.header-nav .menu:is(ul) li,
.header-nav .menu:is(ul) li > a {
  position: relative;
}
.header-nav .menu:is(ul) li > a {
  padding-block: 0.96em;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  transition: 0.125s ease-in-out all;
  gap: 0.25em;
  flex: 1 0;
  justify-content: flex-start;
}
.header-nav .menu:is(ul) li:last-child, .header-nav .menu:is(ul) li:last-child > a {
  /* disable border for last items */
  border: none;
}
.header-nav .menu:is(ul) li:is(.menu-item-has-children) > a::after {
  display: inline-block;
  align-self: center;
  flex: 0 0 auto;
  content: "";
  font-size: 0.625rem;
  transform-origin: 67% 67%;
  margin-top: -0.25rem;
  width: 1em;
  height: 1em;
  border: 2px solid var(--color-primary);
  border-top: 0;
  border-left: 0;
  transform: rotate(45deg);
}
.header-nav .menu:is(ul) ul {
  background-color: var(--color-light-alt);
  color: var(--color-dark);
  padding-block: 1.75rem;
  border-radius: var(--global-radius);
  box-shadow: 0 10px 10px -5px rgba(0, 0, 0, 0.2);
}
.header-nav .menu:is(ul) ul:is(.menu-item-has-children) > a::after {
  color: inherit;
}
.header-nav .menu:is(ul) > li > ul {
  border-start-start-radius: 0;
  border-start-end-radius: 0;
}
@media only screen and (min-width: 75rem) {
  .header-nav .menu {
    font-size: 0.875rem;
    gap: 0.9375rem;
    flex: 1 1;
    display: flex;
    justify-content: space-between;
    position: relative;
    border-radius: 99999rem;
    -webkit-padding-start: 1rem;
            padding-inline-start: 1rem;
  }
  .header-nav .menu::before {
    content: none;
  }
  .header-nav .menu li:is(:not(.menu-item-special li):is(:hover, :focus, :focus-within),
  :is(.menu-item-special li):is(.open)) ~ li > ul,
  .header-nav .menu li:not(:not(.menu-item-special li):is(:hover, :focus, :focus-within),
  :is(.menu-item-special li):is(.open)) > ul {
    display: none !important;
  }
  .header-nav .menu:is(ul) li {
    position: relative;
  }
  .header-nav .menu:is(ul) li:nth-last-child(n+2) {
    -webkit-border-after: 1px solid var(--color-neutral);
            border-block-end: 1px solid var(--color-neutral);
  }
  .header-nav .menu:is(ul) li > a {
    flex: 1 1;
    /* flush dropdown indicator and text to the left */
    justify-content: flex-start;
  }
  .header-nav .menu:is(ul) li:is(:hover, :focus, :focus-within) > a {
    /* activated styles upon interaction for nontouch */
    color: var(--scheme-sp, var(--color-accent));
  }
  .header-nav .menu:is(ul) ul {
    inline-size: clamp(14.375rem, 18vi, 19rem);
    padding-inline: var(--layout-header-menu-nontouch-dropdown-padding-x);
    inset-block-start: 0;
    inset-inline-start: 100%;
    /* Take dropdowns out of doc flow + setup for hover/focus effects */
    position: absolute;
    z-index: 1;
    /* additional border styles + align to current item indicator. comment out if not needed */
    -webkit-border-before: var(--layout-header-menu-nontouch-current-height) solid var(--color-accent);
            border-block-start: var(--layout-header-menu-nontouch-current-height) solid var(--color-accent);
    -webkit-margin-before: calc(var(--layout-header-menu-nontouch-current-height) * -1);
            margin-block-start: calc(var(--layout-header-menu-nontouch-current-height) * -1);
  }
  .header-nav .menu:is(ul) ul li:is(.menu-item-has-children) > a::after {
    transform: rotate(-45deg);
    color: inherit;
  }
  .header-nav .menu:is(ul) > li {
    flex-direction: row;
    padding-inline: 0;
    -webkit-border-after: 0 !important;
            border-block-end: 0 !important;
  }
  .header-nav .menu:is(ul) > li > a {
    padding-block: 0.875rem;
    padding-inline: 0;
    border: none;
  }
  .header-nav .menu:is(ul) > li::before {
    /* current menu item indicator */
    content: "";
    position: absolute;
    inset-block-end: 0;
    inset-inline: 0;
    margin: 0 auto;
    transition: 0.125s ease-in-out inline-size;
    inline-size: 0;
    block-size: var(--layout-header-menu-nontouch-current-height);
    background: var(--color-accent);
  }
  .header-nav .menu:is(ul) > li:is(:hover, :focus, :focus-within), .header-nav .menu:is(ul) > li:is(:hover, :focus, :focus-within) > a {
    /* undo fanciness from non-media query scaffolding for top level menu item and its child a tag */
    border: none;
    background: none;
    color: inherit;
    margin: 0;
  }
  .header-nav .menu:is(ul) > li:is(:hover, :focus, :focus-within)::before {
    /* current menu item indicator if active */
  }
  .header-nav .menu:is(ul) > li:is(.current-menu-item, .current-menu-ancestor)::before {
    /* current menu item indicator if active */
  }
  .header-nav .menu:is(ul) > li:is(.current-menu-item,
  .current-menu-ancestor,
  :hover,
  :focus,
  :focus-within)::before {
    /* current menu item indicator if active */
    inline-size: 100%;
  }
  .header-nav .menu:is(ul) > li:is(.menu-item-has-children) > a::after {
    color: var(--color-primary);
  }
  .header-nav .menu:is(ul) > li.menu-item-special {
    --layout-header-nav-special-sub-width: 19em;
    --layout-header-nav-special-padding-y: .75rem;
    --layout-header-menu-nontouch-dropdown-padding-x: 2.875rem;
  }
  .header-nav .menu:is(ul) > li.menu-item-special li {
    position: static;
    flex-direction: column;
    padding-inline: 0;
  }
  .header-nav .menu:is(ul) > li.menu-item-special li.view-all {
    grid-column: 1/-1;
  }
  .header-nav .menu:is(ul) > li.menu-item-special ul {
    padding-inline: var(--layout-header-menu-nontouch-dropdown-padding-x);
  }
  .header-nav .menu:is(ul) > li.menu-item-special:nth-last-child(-n+2) > ul {
    left: auto;
    right: 0;
    transform: none;
  }
  .header-nav .menu:is(ul) > li.menu-item-special > ul {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-content: start;
    -moz-column-gap: var(--layout-header-menu-nontouch-dropdown-padding-x);
         column-gap: var(--layout-header-menu-nontouch-dropdown-padding-x);
    padding-inline: var(--layout-header-menu-nontouch-dropdown-padding-x);
    inline-size: min(80vi, 34.6875rem);
    max-inline-size: calc(100vi - var(--container-gutter) * 2);
    max-block-size: calc(90vb - var(--layout-header-height));
    min-block-size: min(16.25rem, 75vb - var(--layout-header-height));
    margin-inline: auto;
    background-image: linear-gradient(to left, var(--color-light-alt) 0, var(--color-light-alt) var(--layout-header-nav-special-sub-width), transparent var(--layout-header-nav-special-sub-width), transparent 100%);
    inset-inline-start: calc(var(--layout-header-menu-nontouch-dropdown-padding-x) * -1);
  }
  .header-nav .menu:is(ul) > li.menu-item-special > ul ul {
    color: inherit;
  }
  .header-nav .menu:is(ul) > li.menu-item-special > ul > li > ul {
    position: absolute;
    inset-block-start: 0;
    inset-inline-start: 100%;
    block-size: auto;
    max-block-size: calc(100vi - var(--layout-header-height));
    width: var(--layout-header-nav-special-sub-width);
    background: var(--color-neutral-light, #DDEEF0);
    border-start-start-radius: 0;
    border-start-end-radius: 0;
    border-end-start-radius: 0;
    scrollbar-width: none;
    overflow-y: scroll;
  }
  .header-nav .menu:is(ul) > li.menu-item-special > ul > li > ul::-webkit-scrollbar {
    display: none;
  }
  .header-nav .menu:is(ul) > li.menu-item-special > ul > li > ul ul {
    background: rgba(0, 0, 0, 0.08);
    border-radius: 0;
    width: auto;
    position: static;
    box-shadow: none !important;
    margin-inline: calc(var(--layout-header-menu-nontouch-dropdown-padding-x) * -1);
  }
  .header-nav .menu:is(ul) > li > ul {
    inset-block-start: 100%;
    inset-inline-start: 0;
  }
  .header-nav .menu:is(ul) > li > ul ul {
    background-color: var(--color-dark-alt);
    color: var(--color-light);
  }
  body:not(.doc-header-not-sticky .header-can-overlap) .header-nav .menu:is(ul) > li > ul ul {
    inset-block-start: 1rem;
  }
  .header-nav .menu {
    /* extra extra deep deep deep inner level dropdown edge case dropdown fix */
  }
  .header-nav .menu ul ul ul {
    inset-inline-start: calc(var(--layout-header-menu-nontouch-dropdown-padding-x) * 2);
    inset-block-start: 100%;
    transform: none;
  }
}
@media only screen and (min-width: 87.5rem) {
  .header-nav .menu {
    font-size: 1rem;
    -webkit-padding-start: 1.875rem;
            padding-inline-start: 1.875rem;
  }
}
@media only screen and (min-width: 120rem) {
  .header-nav .menu {
    font-size: 1.125rem;
    gap: 2.2875rem;
    -webkit-padding-start: 2.5rem;
            padding-inline-start: 2.5rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .header-nav .menu {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    align-content: stretch;
    background: var(--color-neutral-light);
    color: var(--color-dark);
    font-size: 1.25rem;
    inline-size: 100%;
    padding-inline: var(--layout-header-menu-touch-menu-padding-x);
  }
  .header-nav .menu::before {
    -webkit-margin-after: 4.875rem;
            margin-block-end: 4.875rem;
    margin-inline: calc(var(--layout-header-menu-touch-menu-padding-x) * -1);
  }
  .header-nav .menu {
    box-shadow: inherit;
    /* shift menu to the right edge and limit inline-size. comment if not needed*/
  }
  .header-nav .menu::before {
    content: "";
    display: block;
    block-size: var(--layout-header-height);
  }
  .header-nav .menu li:not(.open) > ul {
    display: none;
  }
  .header-nav .menu:is(ul) li > a {
    flex: 1 0 100%;
    padding-block: 0.625em;
  }
  .header-nav .menu:is(ul) li:is(:hover, :focus, :focus-within, .open) > a {
    /* activated styles upon interaction for touch */
    color: var(--scheme-sp, var(--color-primary));
  }
  .header-nav .menu:is(ul) li:is(.open) {
    -webkit-border-after: 0;
            border-block-end: 0;
  }
  .header-nav .menu:is(ul) li:is(.open) > a {
    -webkit-border-after: 0;
            border-block-end: 0;
  }
  .header-nav .menu:is(ul) ul {
    background-color: #C2E1E3;
    color: inherit;
    align-self: stretch;
    order: 99;
    flex: 1 0 100%;
    margin-block: 0.875rem 1.5rem;
    padding-inline: var(--layout-header-menu-touch-menu-padding-x);
    margin-inline: calc(var(--layout-header-menu-touch-menu-padding-x) * -1);
  }
  .header-nav .menu:is(ul) ul:has(> li:last-child.open), .header-nav .menu:is(ul) ul:is(li:last-child.open > ul) {
    -webkit-margin-after: 0 !important;
            margin-block-end: 0 !important;
  }
  .header-nav .menu:is(ul) ul:has(> li:last-child.open) {
    -webkit-padding-after: 0 !important;
            padding-block-end: 0 !important;
  }
  .header-nav .menu:is(ul) > li {
    padding-inline: 0;
  }
  .header-nav .menu:is(ul) > li > a {
    padding-block: 0.96em;
  }
  .header-nav .menu:is(ul) > li > ul ul {
    background-color: rgba(0, 0, 0, 0.05);
  }
}
@media only screen and (max-width: 47.9375rem) {
  .header-nav .menu {
    --layout-header-menu-touch-menu-padding-x: 2.5rem;
    max-inline-size: 100%;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    align-content: stretch;
  }
  .header-nav .menu::before {
    -webkit-margin-after: 2.125rem;
            margin-block-end: 2.125rem;
  }
  .header-nav .menu:is(ul) li:is(.menu-item-has-children) > a::after {
    margin-right: -1.7ch;
  }
  .header-nav .menu:is(ul) > li {
    align-self: stretch;
  }
}
.doc-header-not-sticky .header-can-overlap .header-nav .menu {
  /* Styles/Selectors for when header overlays the banner or adjacent element before scroll on non-touch devices. NOTE: You can modify where overlay styles can appear by modifying the functions body header classes  */
}
@media only screen and (min-width: 75rem) {
  .doc-header-not-sticky .header-can-overlap .header-nav .menu {
    background: var(--color-light);
    color: var(--color-dark);
    box-shadow: 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  }
  .doc-header-not-sticky .header-can-overlap .header-nav .menu:is(ul) ul {
    box-shadow: 0 10px 10px -5px rgba(0, 0, 0, 0.2), inset 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  }
  .doc-header-not-sticky .header-can-overlap .header-nav .menu:is(ul) > li.menu-item-special > ul,
  .doc-header-not-sticky .header-can-overlap .header-nav .menu:is(ul) > li.menu-item-special > ul ul {
    box-shadow: inset 0 10px 10px -5px rgba(0, 0, 0, 0.2);
  }
}
@media only screen and (max-width: 74.9375rem) {
  :not(.doc-header-menu-open).doc-header-not-sticky .header-can-overlap .header-nav .menu {
    /* Touch Devices Header Styles Start */
  }
}
.doc-header-not-sticky .header-nav .menu {
  /* Styles/Selectors for when header is not sticky yet. best for smaller devices styles and minor/global changes for larger devices */
}
.doc-header-menu-open .header-nav .menu {
  /* Styles/Selectors for when header menu accordion for touch devices is open */
}
.doc-header-menu-open.doc-header-not-sticky .header-nav .menu {
  /* Styles/Selectors for when header menu accordion for touch devices is open and header is not sticky yet */
}
/* Header Form
--------------------------------------------------------------- */
#header-form {
  grid-area: form;
}
#header-form .field-form {
  gap: 2rem;
}
#header-form .gform_description {
  max-inline-size: 80ch;
}
#header-form .gform_body {
  margin-inline: auto;
}
#header-form .gform_footer {
  justify-content: center;
  text-align: center;
}
#header-form .gfield.gfield--type-submit {
  /* dont stretch flex button */
  align-self: flex-start;
}
@media only screen and (max-width: 74.9375rem) {
  #header-form .gform_fields .gfield:not(.gfield-inline-size-full) {
    /* fix gravity forms from deciding to undo the grid columns on mobile instead of tablet now */
    grid-column: 1/-1;
  }
}
/* ================================================================================
* Banner
================================================================================ */
/* Layout Banner https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/banner.md
--------------------------------------------------------------- */
/* Layout Banner Variables
--------------------------------------------------------------- */
/* In case banner is also as crazy as the header */
/* Tip: placing the css var on :root can allow elements outside of the layout header utilize the variable if needed ie sticky stuff, offsets, jump link scroll etc. */
:root {
  --layout-banner-offset: var(--global-radius-large);
}
.banner-has-background-image {
  /* Styles specific for when banner supports background image */
}
.banner-no-background-image {
  /* Styles specific for when banner doesnt support background image */
}
/* Layout Banner Overlaps
	NOTE: Classes to use:
		.layout-banner-offset-element => the element within the layout that will have the negative margins to overlap itself
		.has-layout-banner-offset => the adjacent layouts/ child of adjacent layouts that will have the pseudo element to adjust itself if the `layout-banner-offset-element` is next to it
--------------------------------------------------------------- */
.banner-can-overlap:has(.has-layout-banner-offset) .layout-banner:has(.layout-banner-offset-element) {
  isolation: isolate;
  z-index: 10;
  position: relative;
}
.banner-can-overlap .has-layout-banner-offset:not(:has(.has-layout-banner-offset)):is(:is(.layout-banner + *),
:is(.main, main, .aside, aside):first-child,
.layout-banner + :is(.main, main) > :is(section, .section):first-child,
.layout-banner + :is(.main, main) > :is(section, .section):first-child *:not(.group-module))::before {
  content: "";
  flex: 0 0 auto;
  grid-column: 1/-1;
  block-size: var(--layout-banner-offset, 0px);
  display: block;
  inline-size: 100%;
}
@media only screen and (min-width: 75rem) {
  .banner-can-overlap .has-layout-banner-offset:not(:has(.has-layout-banner-offset)):is(:is(.main, main):first-child + :is(.aside, aside),
  :is(.main, main):first-child + :is(.aside, aside) *)::after {
    content: "";
    flex: 0 0 auto;
    grid-column: 1/-1;
    block-size: var(--layout-banner-offset, 0px);
    display: block;
    inline-size: 100%;
  }
}
.banner-can-overlap:has(.has-layout-banner-offset) .layout-banner-offset-element:is(.layout-banner > :last-child,
.layout-banner > :last-child *) {
  -webkit-margin-after: calc((var(--layout-banner-offset, 0px) + var(--overlap-buffer)) * -1) !important;
          margin-block-end: calc((var(--layout-banner-offset, 0px) + var(--overlap-buffer)) * -1) !important;
}
.banner-can-overlap:has(.has-layout-banner-offset) .layout-banner:has(.layout-banner-offset-element) {
  -webkit-padding-after: var(--overlap-buffer) !important;
          padding-block-end: var(--overlap-buffer) !important;
}

/* Layout Banner Itself
--------------------------------------------------------------- */
@media only screen and (max-width: 47.9375rem) {
  .layout-banner {
    /* allow more space for mobile only because the design said so */
  }
  .layout-banner-container {
    --container-gutter: .75rem;
  }
}
.banner-has-background-image .layout-banner {
  /* Styles specific for when banner has background image */
}
.banner-no-background-image .layout-banner {
  /* Styles specific for when banner doesnt support background image */
}
/* Banner Background
--------------------------------------------------------------- */
.banner-background {
  --responsive-background-overlay-mix-blend: multiply;
  --responsive-background-overlay-background:
  	linear-gradient(180deg, rgba(49, 48, 24, 0.60) 0.37%, rgba(255, 255, 255, 0.00) 28.57%),
  	linear-gradient(179deg, rgba(240, 240, 240, 0.30) 25.42%, rgba(13, 21, 10, 0.70) 45.08%, rgba(5, 9, 6, 0.95) 89.33%) ;
  --responsive-background-overlay-opacity: 1;
  --responsive-background-bg-position: center top;
}
@media only screen and (min-width: 48rem) {
  .banner-background {
    --responsive-background-overlay-background:
    	linear-gradient(180deg, rgba(23, 23, 11, 0.60) 4%, rgba(115, 115, 104, 0.33) 24.98%, rgba(255, 255, 255, 0.00) 38.33%),
    	linear-gradient(180deg, rgba(240, 240, 240, 0.30) 33.91%, rgba(13, 21, 10, 0.30) 47.18%, rgba(5, 9, 6, 0.90) 69.22%) ;
  }
}
@media only screen and (min-width: 75rem) {
  .banner-background {
    --responsive-background-overlay-background:
    	linear-gradient(
    		to bottom,
    		rgba(5, 9, 6, 0.60) 0,
    		rgba(240, 240, 240, 0.30) calc(var(--layout-header-height, 0) * 1.5)
    	),
    	linear-gradient(
    		94deg,
    		rgba(5, 9, 6, 0.70) calc(50vi - min(480px, 25%)),
    		rgba(240, 240, 240, 0.30) calc(50vi + min(480px, 25%))
    	) ;
  }
}
/* Banner Main
--------------------------------------------------------------- */
.banner-main {
  padding-block: 3.3125rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
.banner-main-blocks {
  justify-items: center;
  justify-content: center;
  align-items: center;
  gap: 3rem;
}
@media only screen and (min-width: 48rem) {
  .banner-main {
    padding-block: 5rem;
  }
}
@media only screen and (min-width: 75rem) {
  .banner-main {
    padding-block: 7.5rem;
  }
}
@media only screen and (min-width: 120rem) {
  .banner-main-blocks {
    -moz-column-gap: 8rem;
         column-gap: 8rem;
  }
}
.banner-has-background-image .banner-main {
  /* Styles specific for when banner has background image */
}
.banner-has-background-image .banner-main {
  padding-block: 2.5rem;
  min-block-size: 36.625rem;
  justify-content: flex-end;
  overflow: clip;
  border-end-start-radius: var(--layout-banner-offset);
  border-end-end-radius: var(--layout-banner-offset);
}
@media only screen and (min-width: 48rem) {
  .banner-has-background-image .banner-main {
    padding-block: 4.5rem;
    min-block-size: 34.6875rem;
  }
}
@media only screen and (min-width: 75rem) {
  .banner-has-background-image .banner-main {
    padding-block: 5.4375rem;
    min-block-size: 37.1875rem;
  }
  .banner-has-background-image .banner-main-blocks {
    grid-template-columns: 1fr 1fr;
  }
}
@media only screen and (min-width: 87.5rem) {
  .banner-has-background-image .banner-main {
    padding-block: 5.625rem;
    min-block-size: 40.9375rem;
  }
}
.banner-has-background-image.header-can-overlap .banner-main {
  /* Styles specific for when banner has the header overlay before scroll + Styles specific for when banner has background image */
}
.banner-no-background-image .banner-main {
  /* Styles specific for when banner doesnt support background image OR global fallback heading*/
}
/* Banner Body
--------------------------------------------------------------- */
.banner-body {
  grid-column: auto;
}
.banner-body, .banner-body-blocks {
  align-items: inherit;
  justify-content: inherit;
  justify-items: inherit;
}
.banner-body-block, .banner-body-blocks {
  min-inline-size: 0;
  max-inline-size: 100%;
}
.banner-body-blocks {
  gap: 1.5625rem;
}
@media only screen and (min-width: 48rem) {
  .banner-body-blocks {
    gap: 2.1875rem;
  }
}
.banner-has-background-image .banner-body {
  /* Styles specific for when banner has background image customized */
}
.banner-has-background-image .banner-body-blocks {
  gap: 1.875rem;
}
@media only screen and (min-width: 48rem) {
  .banner-has-background-image .banner-body-blocks {
    gap: 1.875rem;
  }
}
@media only screen and (min-width: 75rem) {
  .banner-has-background-image .banner-body {
    text-align: left;
    justify-items: flex-start;
    justify-content: flex-start;
    max-inline-size: -webkit-max-content;
    max-inline-size: -moz-max-content;
    max-inline-size: max-content;
    justify-self: self-start;
  }
  .banner-has-background-image .banner-body-blocks {
    gap: 2.5rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .banner-has-background-image .banner-body-blocks {
    gap: 2.3125rem;
  }
}
.banner-no-background-image .banner-body {
  /* Styles specific for when banner doesnt support background image */
}
/* Global Banner Text
--------------------------------------------------------------- */
.banner-has-background-image .banner-text {
  /* Styles specific for when banner has background image */
}
.banner-no-background-image .banner-text {
  /* Styles specific for when banner doesnt support background image */
}
/* Global Secondary Heading
--------------------------------------------------------------- */
.secondary-heading {
  font-size: 0.875rem;
  line-height: 1;
  font-weight: 700;
}
.secondary-heading {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem 0.9375rem;
  justify-content: inherit;
  align-items: center;
}
.secondary-heading > span {
  color: var(--color-light);
  background: var(--color-accent);
  border-radius: var(--global-radius-micro);
  padding-inline: 1.11em;
  padding-block: 0.75em;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}
:where(.content-palette-dark) .secondary-heading > span {
  background: var(--color-dark-alt);
}
.secondary-heading em {
  /* emphasized words */
  color: var(--scheme-sp, var(--color-accent));
  letter-spacing: 0em;
  font-style: normal;
}
.secondary-heading::before,
.secondary-heading > span::before {
  color: var(--scheme-sb, var(--color-primary));
  font-style: normal;
}
@media only screen and (min-width: 48rem) {
  .secondary-heading {
    font-size: 1rem;
  }
}
@media only screen and (min-width: 75rem) {
  .secondary-heading {
    font-size: 1.125rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .secondary-heading {
    flex-direction: column;
  }
  .secondary-heading > span {
    display: inline-block;
  }
}
.banner-has-background-image .secondary-heading {
  /* Styles specific for when banner has background image */
}
.banner-no-background-image .secondary-heading {
  /* Styles specific for when banner doesnt support background image */
}
.secondary-heading.secondary-heading-default {
  /* Styles specific for default template primary heading (Single Post, Single Page, Possibly Blog/ Archive etc.) */
}
.secondary-heading.secondary-heading-blog {
  /* Styles specific for blog post/ blog archive custom primary heading (Blog/ Archive) and blog post titles*/
}
.secondary-heading.secondary-heading-blog-posts {
  /* Styles specific for blog post/ blog archive custom primary heading (Blog/ Archive) */
}
.secondary-heading.secondary-heading-blog-post {
  /* Styles specific for the blog post title*/
}
/* Global Primary Heading
--------------------------------------------------------------- */
/* Note: default styles are set to custom internal templates w/ no banner background images  (Case Results, Testimonials, etc.) to reduce repetitive styles and or lengthy selectors */
.primary-heading {
  /* Global Styles / custom page template heading styles (Testimonials Grid, Attorney Grid, etc.) */
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.primary-heading :is(em, strong) {
  font-weight: normal;
  font-style: normal;
  text-shadow: 0.025em 0.025em 0 var(--color-light);
}
.primary-heading :is(em) {
  color: var(--color-accent-alt);
}
.primary-heading :is(strong) {
  color: var(--color-primary);
}
.primary-heading :is(em strong, strong em) {
  color: var(--color-secondary);
}
@media only screen and (min-width: 48rem) {
  .primary-heading {
    font-size: 4.0625rem;
  }
}
.primary-heading.primary-heading-default {
  /* Styles specific for default template primary heading (Single Post, Single Page, Possibly Blog/ Archive etc.) */
  font-size: 2rem;
  line-height: calc(1em - 5px);
}
@media only screen and (min-width: 75rem) {
  .primary-heading.primary-heading-default {
    font-size: 4.375rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .primary-heading.primary-heading-default {
    font-size: 5rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .primary-heading.primary-heading-default {
    font-size: 3.75rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .primary-heading.primary-heading-default {
    font-size: 3.4375rem;
  }
}
.primary-heading.primary-heading-default-h1 {
  /* Styles specific for default template primary heading set as an h1 (Single Post, Single Page) */
}
.primary-heading.primary-heading-blog {
  /* Styles specific for blog post/ blog archive custom primary heading (Blog/ Archive) and blog post titles*/
}
.primary-heading.primary-heading-blog-posts {
  /* Styles specific for blog post/ blog archive custom primary heading (Blog/ Archive) */
}
.primary-heading.primary-heading-blog-post {
  /* Styles specific for the blog post title*/
}
.layout-banner .primary-heading {
  /* Styles specific for when it's inside a banner */
}
.primary-heading.h1-fallback-heading {
  /* Styles specific for when banner does not exist/ rendered as a helper class for the fallback h1 */
}
.primary-heading.h1-fallback-heading:where(.section-heading) {
  text-align: center;
}
.banner-has-background-image .layout-banner .primary-heading {
  color: inherit;
}
.banner-has-background-image .primary-heading {
  /* Styles specific for when banner has background image */
  color: inherit;
}
.banner-no-background-image .primary-heading {
  /* Styles specific for when banner doesnt support background image */
}
/* Banner Awards (Optional depending on comps)
--------------------------------------------------------------- */
.banner-awards {
  grid-column: 1/-1;
  flex: 0 0 auto;
  order: 99;
}
.banner-has-background-image .banner-awards {
  /* Styles specific for when banner has background image */
}
.banner-no-background-image .banner-awards {
  /* Styles specific for when banner doesnt support background image */
}
/* Banner video (Optional depending on comps)
--------------------------------------------------------------- */
.banner-video .video-thumbnail {
  inline-size: 18.75rem;
}
.banner-video-cta.video-button:not(.video-button-default-has-text) {
  display: block;
}
@media only screen and (min-width: 75rem) {
  .banner-video {
    order: 99;
  }
}
.banner-has-background-image .banner-video {
  /* Styles specific for when banner has background image */
}
.banner-no-background-image .banner-video {
  /* Styles specific for when banner doesnt support background image */
}
/* Banner Content (Optional depending on comps)
--------------------------------------------------------------- */
.banner-content {
  max-inline-size: 85ch;
}
.banner-has-background-image .banner-content {
  /* Styles specific for when banner has background image */
  font-size: 1.25rem;
  line-height: 1.25;
  font-family: var(--font-accent);
  font-weight: 700;
  text-wrap: balance;
  max-inline-size: 90ch;
}
@media only screen and (min-width: 48rem) {
  .banner-has-background-image .banner-content {
    font-size: 1.5rem;
  }
}
.banner-no-background-image .banner-content {
  /* Styles specific for when banner doesnt support background image */
}
/* Banner Buttons
--------------------------------------------------------------- */
.banner-buttons {
  display: inline-flex;
  gap: 1rem;
  align-items: center;
  text-align: inherit;
  justify-content: inherit;
}
.banner-buttons-touch {
  -webkit-margin-before: 3.25rem;
          margin-block-start: 3.25rem;
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}
.banner-buttons-touch:first-child {
  -webkit-margin-before: -1rem;
          margin-block-start: -1rem;
}
@media only screen and (min-width: 48rem) {
  .banner-button-shift .banner-buttons-touch, .banner-has-h1.banner-button-shift .banner-buttons-touch + hr {
    /* hide buttons outside of banner */
    display: none;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .banner-buttons, .banner-buttons-touch {
    flex-direction: column;
  }
  .banner-buttons-touch {
    inline-size: 100%;
    align-items: stretch;
  }
  .h1-fallback-heading:has(+ .banner-buttons-touch) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
  .banner-button-shift :is(.layout-banner .banner-buttons, .banner-buttons-nontouch) {
    /* hide buttons inside of banner */
    display: none;
  }
}

/* Banner Form
--------------------------------------------------------------- */
#banner-form {
  padding-block: 0rem 2.625rem;
  background: var(--color-neutral-light);
  border-radius: 1.25rem;
  inline-size: 41.5rem;
}
#banner-form .field-form {
  gap: 2.1875rem;
}
#banner-form .gform_title {
  font-size: 3.4375rem;
  white-space: nowrap;
  justify-self: center;
  -webkit-text-stroke-width: 0.25em;
  -webkit-text-stroke-color: var(--color-neutral-light, #DDEEF0);
  position: relative;
  -webkit-margin-before: -0.625em;
          margin-block-start: -0.625em;
}
#banner-form .gform_title::before {
  content: attr(data-content);
  -webkit-text-stroke-width: 0;
  -webkit-text-stroke-color: transparent;
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
}
#banner-form .gform_description {
  max-inline-size: 80ch;
}
#banner-form .gform_body {
  margin-inline: auto;
}
#banner-form .gform_footer {
  justify-content: center;
  text-align: center;
}
#banner-form .gfield.gfield--type-submit {
  /* dont stretch flex button */
  align-self: flex-start;
  justify-self: center;
}
@media only screen and (min-width: 48rem) {
  #banner-form {
    padding-block: 0rem 2.3125rem;
  }
  #banner-form .field-form {
    gap: 1.75rem;
  }
  #banner-form .gform_title {
    font-size: 5rem;
  }
  #banner-form .gfield.gfield--type-submit {
    /* dont stretch flex button */
    align-self: flex-start;
    justify-self: end;
  }
}
@media only screen and (min-width: 75rem) {
  #banner-form {
    justify-self: self-end;
  }
}
@media only screen and (max-width: 47.9375rem) {
  #banner-form {
    margin-inline: calc(var(--container-gutter) * -1);
    max-inline-size: none;
    inline-size: auto;
  }
  #banner-form .field-form-body {
    position: relative;
  }
  #banner-form .gfield.required-message {
    position: absolute;
    inset-inline: 0;
    text-align: center;
    top: 100%;
  }
}

/* Banner Organization info
--------------------------------------------------------------- */
.banner-org-info {
  padding-block: 2rem;
  background: var(--color-light-alt);
}
.banner-org-info-header {
  text-align: center;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
/* ================================================================================
* Sidebar
================================================================================ */
/* Layout Sidebar https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/sidebar.md
--------------------------------------------------------------- */
/* Layout Sidebar Variables
--------------------------------------------------------------- */
/* In case banner is also as crazy as the header */
/* Tip: placing the css var on :root can allow elements outside of the layout header utilize the variable if needed ie sticky stuff, offsets, jump link scroll etc. */
@media only screen and (min-width: 75rem) {
  :root {
    --layout-sidebar-offset: 3.125rem;
  }
}
/* Layout sidebar Overlaps
	NOTE: Classes to use:
		.layout-sidebar-offset-element => the element within the layout that will have the negative margins to overlap itself
		.has-layout-sidebar-offset => the adjacent layouts/ child of adjacent layouts that will have the pseudo element to adjust itself if the `layout-sidebar-offset-element` is next to it
--------------------------------------------------------------- */
@media only screen and (min-width: 75rem) {
  .sidebar-can-overlap .has-layout-sidebar-offset:not(:has(.has-layout-sidebar-offset)):last-child:is(.template-wrapper > *:has(+ * .layout-sidebar-offset-element),
  .template-wrapper > *:has(+ * .layout-sidebar-offset-element) *)::after {
    content: "";
    flex: 0 0 auto;
    block-size: var(--layout-sidebar-offset, 0px);
    display: block;
    inline-size: 100%;
  }
  .sidebar-can-overlap:has(.has-layout-sidebar-offset) .layout-sidebar-offset-element {
    -webkit-margin-before: calc((var(--layout-sidebar-offset, 0px) + var(--overlap-buffer)) * -1) !important;
            margin-block-start: calc((var(--layout-sidebar-offset, 0px) + var(--overlap-buffer)) * -1) !important;
  }
  .sidebar-can-overlap:has(.has-layout-sidebar-offset) :is(.aside, aside):has(.layout-sidebar-offset-element) {
    -webkit-padding-before: var(--overlap-buffer) !important;
            padding-block-start: var(--overlap-buffer) !important;
  }
}
/* Layout Sidebar
--------------------------------------------------------------- */
/* Sidebar Form
--------------------------------------------------------------- */
#sidebar-form {
  --widget-padding-x: 1.25rem;
  --widget-padding-top: 3.125rem;
  --widget-content-margin-top: 0rem;
  --widget-content-margin-bottom: 0rem;
  border-radius: var(--global-radius-large) var(--global-radius-large) 0 0;
  background: radial-gradient(circle 17rem at -1.5rem -5.5rem, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%), radial-gradient(circle 17rem at 75% 90%, rgba(8, 196, 208, 0.3) 0, rgba(8, 196, 208, 0.15) 35%, transparent 100%), var(--color-neutral-light, #DDEEF0);
}
#sidebar-form .field-form {
  gap: 1.25rem;
}
#sidebar-form .field-form-header {
  gap: 1.25rem;
}
#sidebar-form .field-form-body {
  gap: 1.25rem;
}
#sidebar-form .gform_title {
  font-size: 2.8125rem;
}
#sidebar-form .gform_description {
  max-inline-size: 80ch;
}
#sidebar-form .gform_body {
  margin-inline: auto;
}
#sidebar-form .gform_footer {
  justify-content: center;
  text-align: center;
}
#sidebar-form .gfield.gfield--type-submit {
  /* dont stretch flex button */
  align-self: flex-start;
}
/* Sidebar Organization info
--------------------------------------------------------------- */
.sidebar-org-info-container {
  display: contents;
}
.sidebar-org-info :is(.swiper) {
  --swiper-custom-arrow-offset-x: 0px;
  --swiper-custom-arrow-offset-x: calc(
  	var(--widget-padding-x) + var(--widget-item-padding-x)
  );
  --swiper-custom-arrow-offset-x-negate: var(--widget-padding-x);
}
.sidebar-org-info :is(.swiper) .swiper-custom-buttons {
  margin-inline: calc(var(--widget-padding-x) * -1);
}
.sidebar-org-info :is(.testimonial) :is(.testimonial-highlight, .testimonial-quote) * {
  display: contents;
}
.sidebar-contact .sidebar-embed-map {
  --cover-aspect-w: 1;
  --cover-aspect-l: 1;
  border-radius: calc(var(--global-radius) - 0.625rem);
}
.sidebar-contact .layout-contact {
  text-align: center;
  margin-top: 2.375rem;
}
.sidebar-contact .contact-blocks {
  grid-template-columns: 100%;
}
.sidebar-contact .contact-block-title {
  font-size: 1.125rem;
}
.sidebar-contact .contact-block {
  grid-column: auto;
  grid-row: auto;
}

/* ================================================================================
Contact Info
================================================================================ */
/* Layout Contact https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/contact.md
-------------------------------------------------------------------------------- */
/* Layout contact Variables
--------------------------------------------------------------- */
/* In case contact is also as crazy as the header */
/* Tip: placing the css var on :root can allow elements outside of the layout header utilize the variable if needed ie sticky stuff, offsets, jump link scroll etc. */
:root {
  --layout-contact-offset: 6.25rem;
}
/* Layout contact Overlaps
	NOTE: Classes to use:
		.layout-contact-offset-element => the element within the layout that will have the negative margins to overlap itself
		.has-layout-contact-offset => the adjacent layouts/ child of adjacent layouts that will have the pseudo element to adjust itself if the `layout-contact-offset-element` is next to it
--------------------------------------------------------------- */
.contact-can-overlap:has(.has-layout-contact-offset) .layout-contact:has(.layout-contact-offset-element) {
  isolation: isolate;
}
.contact-can-overlap .has-layout-contact-offset:not(:has(.has-layout-contact-offset)):is(.footer-top:has(+ .footer-bottom .footer-contact:first-child),
.footer-top:has(+ .footer-bottom .footer-contact:first-child) + *,
.template-wrapper:has(:is(.main, main) .layout-contact:nth-child(n+2)))::after {
  content: "";
  flex: 0 0 auto;
  grid-column: 1/-1;
  block-size: var(--layout-contact-offset, 0px);
  display: block;
  inline-size: 100%;
}
.contact-can-overlap:has(.has-layout-contact-offset) .layout-contact-offset-element:is(.layout-contact > :last-child,
.layout-contact > :last-child *) {
  -webkit-margin-before: max(0, (var(--layout-contact-offset, 0px) + var(--overlap-buffer)) * -1) !important;
          margin-block-start: max(0, (var(--layout-contact-offset, 0px) + var(--overlap-buffer)) * -1) !important;
}
.contact-can-overlap:has(.has-layout-contact-offset) .layout-contact:has(.layout-contact-offset-element),
.contact-can-overlap:has(.has-layout-contact-offset) :is(main, .main):has(.layout-contact) {
  -webkit-padding-before: var(--overlap-buffer) !important;
          padding-block-start: var(--overlap-buffer) !important;
}

/* Contact Main
-------------------------------------------------------------------------------- */
.footer-no-contact .contact-main {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .contact-main {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Contact  Related Classes

Note: 
This file is for styles applied globally for the contact information globally

For styles applied globally for the contact information, apply styles to layouts/layout-contact.scss
For Contact Page only overrides for the contact informatio, apply styles to templates/template-contact.scss -> #contact-page
For Footer section only overrides for the contact informatio, apply styles to layout/layout-footer.scss -> .footer-contact styles section
-------------------------------------------------------------------------------- */
/* Global Stylees - Numbers (eg. header phone number, footer phone number, etc.)
-------------------------------------------------------------------------------- */
.number-title {
  font-size: 1rem;
  line-height: 1;
  font-family: var(--font-accent);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.number-title .button-glyph {
  font-size: 1.25rem;
}
.number-link {
  font-size: 1.5625rem;
  line-height: 1;
  font-family: var(--font-accent);
  color: inherit;
  font-weight: 800;
  text-decoration: none;
  display: inline-block;
}
/* Global Stylees - Locations
-------------------------------------------------------------------------------- */
.location-content {
  display: contents;
}
.location-numbers {
  display: contents;
  align-items: inherit;
  justify-content: inherit;
}
.location-number {
  flex-wrap: wrap;
}
.location-number-label {
  -webkit-margin-end: 0.25em;
          margin-inline-end: 0.25em;
}
/* Global Stylees - Social Links (ie. Organization social media, blog share icons, etc)
-------------------------------------------------------------------------------- */
.social {
  font-size: 1.5rem;
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1em;
  list-style: none;
  padding: 0;
  margin: 0;
}
.social li a {
  color: inherit;
}
.social li a svg * {
  fill: currentColor;
}
.social li:is(:hover, :focus) {
  color: var(--scheme-sp, var(--color-primary));
}
.social:is(.social-style-circle) {
  gap: 0.25em;
}
.social:is(.social-style-circle) li a {
  display: flex;
  align-items: center;
  justify-content: center;
  list-style: none;
  border-radius: 999em;
  height: 1.75em;
  aspect-ratio: 1/1;
  padding-bottom: 0.15em;
  background: var(--color-light);
  color: var(--color-dark);
}
.social:is(.social-style-circle) li:is(:hover, :focus, :focus-within) > a {
  background: var(--color-primary);
  color: var(--color-light);
}
/* Confact Info Block - Titles
-------------------------------------------------------------------------------- */
.contact-block-title:not(.contact-block-title-custom) {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
/* Confact Info Block - Basic Text Content
-------------------------------------------------------------------------------- */
.contact-block-content {
  flex: 1 1;
}
:where(.contact-block-content :where(a)) {
  color: inherit;
  text-decoration: none;
}
:where(.contact-block-content :where(a)):where(:hover, :focus) {
  text-decoration: underline;
}

.contact-block-content:not(.contact-block-content-custom) {
  font-size: 1.25rem;
  line-height: 1.13;
  display: contents;
}
/* Confact Info Block - Grid setup
-------------------------------------------------------------------------------- */
.contact-blocks {
  justify-items: center;
  justify-content: center;
  -moz-column-gap: 2.8125rem;
       column-gap: 2.8125rem;
  row-gap: 2.5rem;
  align-items: stretch;
}
.contact-block, .contact-blocks {
  min-inline-size: 0;
}
.contact-block {
  inline-size: 100%;
  gap: 1em;
}
.contact-block:is(:only-child) {
  grid-column: 1/-1;
}
.contact-block:not(.contact-block-custom) {
  display: flex;
  flex-direction: column;
}
.contact-block:is(.contact-image) {
  justify-self: self-start;
  align-self: self-start;
  inline-size: 21.25rem;
  margin-inline: -6rem 0;
  margin-block: -6.6875rem 0;
  max-inline-size: none;
}
.contact-block:is(.contact-special) {
  justify-self: center;
}
.contact-block:is(.contact-number, .contact-numbers) {
  justify-self: self-start;
  inline-size: -webkit-max-content;
  inline-size: -moz-max-content;
  inline-size: max-content;
}
@media only screen and (min-width: 48rem) {
  .contact-block:is(.contact-image) {
    inline-size: 30.7rem;
    margin-inline: -12rem 0;
    margin-block: -10rem 1rem;
    grid-row: span 2;
  }
  .contact-block:is(.contact-number, .contact-numbers) {
    align-self: self-start;
  }
}
@media only screen and (min-width: 75rem) {
  .contact-blocks {
    -moz-column-gap: 5.3125rem;
         column-gap: 5.3125rem;
  }
  .contact-block:is(.contact-image) {
    grid-row: span 3;
    margin-inline: -8.75rem 0;
    margin-block: -10.5rem -0.75rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .contact-block:is(.contact-image) {
    margin-inline: -1.25rem -0.5rem;
    margin-block: -7.875rem -0.75rem;
  }
}
@media only screen and (min-width: 120rem) {
  .contact-block:is(.contact-image) {
    margin-inline: -1.25rem -0.5rem;
    margin-block: -7.875rem -1.92rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .contact-blocks {
    inline-size: -webkit-max-content;
    inline-size: -moz-max-content;
    inline-size: max-content;
    max-inline-size: 100%;
    margin-inline: auto;
  }
  .contact-block:is(.contact-special) {
    justify-self: center;
    order: 9999;
    grid-column: 1/-1;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .contact-block:is(.contact-menudirs) .menudir {
    order: 99;
  }
}
.contact-block :where(.contact-locations .location, .contact-lists .list) {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.contact-block :where(.contact-locations .location, .contact-lists .list) :where(.contact-block-content, .location-content) {
  display: contents;
}
.contact-block.contact-special {
  text-align: center;
  max-inline-size: 100%;
  place-items: center;
  place-content: center;
}
.contact-block.contact-special .contact-logo {
  align-self: center;
}
.contact-block:is(.contact-number, .contact-numbers) {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
}
.contact-block:is(.contact-number, .contact-numbers) .number-title {
  -webkit-margin-after: 0;
          margin-block-end: 0;
  pointer-events: none;
}
.contact-block:is(.contact-number, .contact-numbers) .number-title:is(.button) {
  --button-padding-y: .8125em;
}
.contact-block:is(.contact-number, .contact-numbers) .number-link .number-subtitle {
  display: none;
}
@media only screen and (min-width: 75rem) {
  .contact-block:is(.contact-number, .contact-numbers) .number-title {
    font-size: 1.25rem;
  }
  .contact-block:is(.contact-number, .contact-numbers) .number-title:is(.button) {
    --button-padding-y: .625em;
  }
  .contact-block:is(.contact-number, .contact-numbers) .number-link {
    font-size: 2.1875rem;
  }
}
.contact-block.contact-number {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
  flex-direction: column-reverse;
}
.contact-block.contact-numbers {
  /*
  @Variation B: One block
  Requires PHP: templates/template-contact.php - @Variation B: One block
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numbersColumn / @Variation B: One block
  */
}
.contact-block.contact-numbers .contact-numbers-content {
  flex: 0 0;
  row-gap: 1rem;
}
.contact-block.contact-location {
  /* Location - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: layouts/layout-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layouts/_contact.scss - @Variation A: Separate blocks
  */
}
.contact-block.contact-locations {
  /* Locations - Contact Block Grid */
  /*
  @Variation B: One block
  Requires PHP: layouts/layout-contact.php - @Variation B: One block
  Requires SCSS: scss/layouts/_contact.scss - @Variation B: One block
  */
}
.contact-block.contact-locations .contact-locations-content {
  row-gap: 4rem;
  display: grid;
}
.contact-block:is(.contact-list, .contact-lists) .list-block-items {
  display: flex;
  flex-direction: column;
}
.contact-list-email {
  /* This is an example and can be omitted if not needed. each column added here will be separated by a class named after the block's title, unless the corresponding layout-contact.php markup has been modified.  */
  font-size: 1.5em;
  font-family: var(--font-secondary);
}

.contact-block.contact-lists .contact-lists-content {
  row-gap: 4rem;
  display: grid;
}
.contact-block.contact-image {
  --cover-aspect-w: 982;
  --cover-aspect-l: 1034;
}
.contact-block.contact-image:has(img[src*="/wp-content/uploads/2026/05/7-emergency.webp"]) {
  background: none;
}
.contact-block.contact-image:not(:has(img[src*="/wp-content/uploads/2026/05/7-emergency.webp"])) {
  -webkit-mask-image: var(--icon-elesi);
          mask-image: var(--icon-elesi);
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
}
.contact-block.contact-menudirs .menudir {
  --pa-item-padding-x: 0rem;
  --pa-item-height: 2rem;
}
.contact-block.contact-menudirs .menudir-container {
  display: contents;
}
.contact-block.contact-menudirs .menudir-menu {
  font-size: 1em;
}
@media only screen and (min-width: 48rem) {
  .contact-block.contact-menudirs {
    display: grid;
    grid-template-columns: repeat(2, auto);
    gap: 4.125rem;
  }
}
@media only screen and (min-width: 75rem) {
  .contact-block.contact-menudirs {
    gap: 3rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .contact-block.contact-menudirs {
    display: contents;
  }
}

/* Contact Form
--------------------------------------------------------------- */
#contact-form .field-form {
  gap: 2rem;
}
#contact-form .gform_description {
  max-inline-size: 80ch;
}
#contact-form .gform_body {
  margin-inline: auto;
}
#contact-form .gform_footer {
  justify-content: center;
  text-align: center;
}
#contact-form .gfield.gfield--type-submit {
  /* dont stretch flex button */
  align-self: flex-start;
}
@media only screen and (max-width: 74.9375rem) {
  #contact-form .gform_fields .gfield:not(.gfield-width-full) {
    /* fix gravity forms from deciding to undo the grid columns on mobile instead of tablet now */
    grid-column: 1/-1;
  }
}
/* ================================================================================
* Footer
================================================================================ */
/* Layout Footer https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/footer.md
--------------------------------------------------------------- */
/* Layout Footer Variables
--------------------------------------------------------------- */
/* In case footer is also as crazy as the header */
/* Tip: placing the css var on :root can allow elements outside of the layout header utilize the variable if needed ie sticky stuff, offsets, jump link scroll etc. */
:root {
  --layout-footer-offset: var(--global-radius-large);
}
/* Layout Footer Overlaps
	NOTE: Classes to use:
		.layout-footer-offset-element => the element within the layout that will have the negative margins to overlap itself
		.has-layout-footer-offset => the adjacent layouts/ child of adjacent layouts that will have the pseudo element to adjust itself if the `layout-footer-offset-element` is next to it
--------------------------------------------------------------- */
.footer-can-overlap:has(.has-layout-footer-offset) .layout-footer:has(.layout-footer-offset-element) {
  isolation: isolate;
  z-index: 10;
  position: relative;
}
.footer-can-overlap .has-layout-footer-offset:not(:has(.has-layout-footer-offset)):is(:has(+ .layout-footer),
.template-wrapper:has(+ .layout-footer) :is(.template-wrapper:has(+ .layout-footer) > :last-child,
:is(.main, main, .aside, aside):last-child,
:is(.main, main):last-child > :is(section, .section):last-child,
:is(.main, main):last-child > :is(section, .section):last-child *))::after {
  content: "";
  flex: 0 0 auto;
  grid-column: 1/-1;
  block-size: var(--layout-footer-offset, 0px);
  display: block;
  inline-size: 100%;
}
@media only screen and (min-width: 75rem) {
  .footer-can-overlap .has-layout-footer-offset:not(:has(.has-layout-footer-offset)):is(:is(.main, main):has(+ :is(.aside, aside):last-child),
  :is(.main, main):has(+ :is(.aside, aside):last-child) *)::after {
    content: "";
    flex: 0 0 auto;
    grid-column: 1/-1;
    block-size: var(--layout-footer-offset, 0px);
    display: block;
    inline-size: 100%;
  }
}
.footer-can-overlap:has(.has-layout-footer-offset) .layout-footer-offset-element:is(.layout-footer > :first-child,
.layout-footer > :first-child *) {
  -webkit-margin-before: calc((var(--layout-footer-offset, 0px) + var(--overlap-buffer)) * -1) !important;
          margin-block-start: calc((var(--layout-footer-offset, 0px) + var(--overlap-buffer)) * -1) !important;
}
.footer-can-overlap:has(.has-layout-footer-offset) .footer-top:has(.layout-footer-offset-element) {
  -webkit-padding-before: var(--overlap-buffer) !important;
          padding-block-start: var(--overlap-buffer) !important;
}

/* Branding logo sizes
--------------------------------------------------------------- */
:is(.ilawyer-legacy, .ilawyer, .onep21, .ihealth) {
  color: inherit;
}

.ilawyer-legacy,
.ilawyer {
  font-size: 1.125rem;
}

.onep21 {
  font-size: 3.125rem;
}

.ihealth {
  font-size: 2.125rem;
}

/* Layout Footer
--------------------------------------------------------------- */
.footer-no-contact .layout-footer {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .layout-footer {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Footer Organization info
--------------------------------------------------------------- */
.footer-org-info {
  padding-block: 2rem;
  background: var(--color-dark);
}
.footer-org-info-header {
  text-align: center;
}
/* Footer Split - Top
--------------------------------------------------------------- */
.footer-top {
  background-color: var(--color-neutral-light, #DDEEF0);
  border-start-start-radius: var(--layout-footer-offset);
  border-start-end-radius: var(--layout-footer-offset);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 42.5rem at 20% 5rem, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%), radial-gradient(circle 42.5rem at 75% 80%, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%), radial-gradient(circle 42.5rem at 10% 70%, rgba(8, 196, 208, 0.3) 0, rgba(8, 196, 208, 0.15) 35%, transparent 100%), radial-gradient(circle 42.5rem at 90% 20%, rgba(8, 196, 208, 0.3) 0, rgba(8, 196, 208, 0.15) 35%, transparent 100%);
  color: var(--color-dark);
  padding-block: 3.125rem;
}
@media only screen and (min-width: 48rem) {
  .footer-top {
    padding-block: 6.1875rem 6.26rem;
  }
}
@media only screen and (min-width: 75rem) {
  .footer-top {
    padding-block: 8.125rem 8.1875rem;
  }
  .footer-top-container {
    --container-gutter: 15.1875rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .footer-top-container {
    --container-gutter: 21.4375rem;
  }
}
@media only screen and (min-width: 120rem) {
  .footer-top-container {
    --container-gutter: 37.72rem;
  }
}
.footer-no-contact .footer-top {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .footer-top {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
/* Footer Form
--------------------------------------------------------------- */
#footer-form {
  max-inline-size: 100%;
  margin-inline: auto;
}
#footer-form .field-form {
  gap: 1.25rem;
}
#footer-form .field-form-header {
  gap: 1.25rem;
  justify-self: center;
}
#footer-form .field-form-body {
  gap: 1.25rem;
}
#footer-form .gform_title {
  font-size: 2.8125rem;
}
#footer-form .gform_description {
  text-wrap: balance;
  max-inline-size: 80ch;
}
#footer-form .gform_body {
  margin-inline: auto;
  display: contents;
}
#footer-form .gform_footer {
  justify-content: center;
  text-align: center;
}
#footer-form .gfield.gfield--type-consent {
  /* dont stretch flex button */
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
}
#footer-form .gfield.gfield--type-submit {
  /* dont stretch flex button */
  justify-self: center;
  -webkit-margin-before: 0.6875rem;
          margin-block-start: 0.6875rem;
}
@media only screen and (min-width: 48rem) {
  #footer-form .field-form {
    gap: 3.5rem;
  }
  #footer-form .field-form-header {
    gap: 1.75rem;
  }
  #footer-form .gform_title {
    font-size: 5rem;
  }
  #footer-form .gform_fields {
    gap: 1.25rem;
  }
  #footer-form .gfield.gfield--type-submit {
    /* dont stretch flex button */
    justify-self: self-end;
    align-self: self-start;
  }
}
@media only screen and (min-width: 75rem) {
  #footer-form .field-form {
    gap: 3.4375rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  #footer-form .field-form-body {
    position: relative;
    -webkit-padding-after: 2rem;
            padding-block-end: 2rem;
  }
  #footer-form .gfield.required-message {
    position: absolute;
    inset-inline: 0;
    text-align: center;
    inset-block-start: 100%;
  }
}
.footer-no-contact #footer-form {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact #footer-form {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Footer Contact

Note: 
This file is for Footer only overrides for the contact information
For Footer section only overrides for the contact informatio, apply styles to layout/layout-footer.scss -> .footer-contact styles section
For styles applied globally for the contact information, apply styles to layouts/layout-contact.scss
For Contact Page only overrides for the contact informatio, apply styles to templates/template-contact.scss -> #contact-page
--------------------------------------------------------------- */
.footer-contact {
  padding-block: 3.1875rem;
}
@media only screen and (min-width: 48rem) {
  .footer-contact {
    padding-block: 6.5rem;
  }
}
@media only screen and (min-width: 75rem) {
  .footer-contact {
    padding-block: 8.4375rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .footer-contact {
    padding-block: 6.9375rem;
  }
}
@media only screen and (min-width: 120rem) {
  .footer-contact {
    padding-block: 6.1875rem;
  }
}
.footer-contact .contact-block:is(.contact-special) {
  justify-self: center;
}
@media only screen and (min-width: 48rem) {
  .footer-contact .contact-blocks {
    grid-template-columns: repeat(2, auto);
    grid-template-rows: auto 1fr;
    -moz-column-gap: 2.5rem;
         column-gap: 2.5rem;
    row-gap: 2.8125rem;
  }
  .footer-contact .contact-block:is(.contact-social) {
    grid-column: 1;
  }
  .footer-contact .contact-block:is(.contact-menudirs) {
    grid-column: -2;
    grid-row: span 2;
  }
}
@media only screen and (min-width: 75rem) {
  .footer-contact .contact-blocks {
    grid-template-columns: repeat(2, auto) 1fr;
    grid-template-rows: 1fr auto;
    grid-auto-rows: -webkit-max-content;
    grid-auto-rows: max-content;
    -moz-column-gap: 2.5rem;
         column-gap: 2.5rem;
  }
  .footer-contact .contact-block:is(.contact-number, .contact-numbers) {
    grid-column: -2;
    grid-row: auto;
  }
  .footer-contact .contact-block:is(.contact-social) {
    grid-column: 2;
  }
  .footer-contact .contact-block:is(.contact-list, .contact-lists) {
    grid-row: auto;
  }
  .footer-contact .contact-block:is(.contact-menudirs) {
    grid-column: -2;
    grid-row: 1/span 2;
  }
}
@media only screen and (min-width: 87.5rem) {
  .footer-contact .contact-blocks {
    -moz-column-gap: 5.25rem;
         column-gap: 5.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  .footer-contact .contact-blocks {
    -moz-column-gap: 11.25rem;
         column-gap: 11.25rem;
  }
}
.footer-contact .contact-block:is(.contact-number, .contact-numbers) {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
}
.footer-contact .contact-block.contact-numbers {
  /* Phone number - Contact Block Grid */
  /*
  @Variation B One Block
  Requires PHP: templates/template-contact.php - @Variation B One Block
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation B One Block
  */
}
.footer-contact .contact-block.contact-number {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
}
.footer-contact .contact-block.contact-location {
  /* Location - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: layouts/layout-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layouts/_contact.scss - @Variation A: Separate blocks
  */
}
.footer-contact .contact-block.contact-locations {
  /* Locations - Contact Block Grid */
  /*
  @Variation B: One block
  Requires PHP: layouts/layout-contact.php - @Variation B: One block
  Requires SCSS: scss/layouts/_contact.scss - @Variation B: One block
  */
}
/* Footer Split - Bottom
--------------------------------------------------------------- */
.footer-bottom {
  background: var(--scheme-bg-contrast, var(--color-dark)) linear-gradient(213deg, var(--color-dark, #003543) 6.59%, var(--color-dark-alt, #00485A) 33.02%, var(--color-dark-alt-alt, #003543) 78.24%);
  overflow: clip;
}
.footer-no-contact .footer-bottom {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .footer-bottom {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Footer Sitemap
--------------------------------------------------------------- */
.footer-no-contact .footer-sitemap {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .footer-sitemap {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Footer utility
--------------------------------------------------------------- */
.footer-utility {
  padding-block: 1.75rem 4.75rem;
  background: var(--color-dark);
  font-size: 1;
  line-height: 1.25;
  font-weight: 500;
  text-align: center;
  text-wrap: balance;
}
.footer-utility-blocks {
  row-gap: 0.625rem;
  -moz-column-gap: 2rem;
       column-gap: 2rem;
  align-items: center;
}
.footer-utility-content :is(li) {
  display: inline;
  margin: 0;
}
.footer-utility-content :is(li):nth-child(n+2)::before {
  content: ". ";
  display: inline-block;
  margin-inline: -0.25em 0.25em;
}
.footer-utility-content :is(li):is(li:has(a[href="#"])) {
  pointer-events: none;
}
.footer-utility-content :is(li):is(li:has(a[href="#"])) a {
  text-decoration: none;
}
.footer-utility a {
  text-decoration: underline;
}
.footer-utility a:is(:hover, :focus) {
  text-decoration: none;
}
@media only screen and (min-width: 48rem) {
  .footer-utility-content :is(p:not(.footer-disclaimer),
  ul) {
    display: inline;
    margin: 0;
  }
  .footer-utility-content :is(p:not(.footer-disclaimer),
  ul):nth-child(n+2)::before {
    content: ". ";
    display: inline-block;
    margin-inline: -0.25em 0.25em;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  .footer-utility-content :is(li:last-child) {
    display: block;
  }
  .footer-utility-content :is(li:last-child)::before {
    content: none;
  }
}
@media only screen and (min-width: 75rem) {
  .footer-utility {
    padding-block: 1.75rem;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  .footer-utility-container {
    --container-gutter: 1.24rem;
  }
}
@media only screen and (min-width: 75rem) {
  .footer-utility-blocks {
    grid-template-columns: auto 1fr auto;
  }
  .footer-utility-content:first-child:nth-last-child(2) {
    grid-column: span 2;
  }
  .footer-utility .social {
    text-align: center;
  }
  .footer-utility .social::before {
    content: none;
  }
  .footer-utility :is(.footer-brand) {
    order: 99;
    justify-self: self-end;
    align-self: center;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .footer-utility-blocks {
    text-align: center;
    justify-content: center;
    justify-items: center;
  }
}
@media only screen and (max-width: 47.9375rem) {
  .footer-utility .footer-brand-text {
    order: -1;
  }
}
.footer-no-contact .footer-utility {
  /* Styles/Selectors for when nested layout-contact is hidden*/
}
.footer-has-contact .footer-utility {
  /* Styles/Selectors for when nested layout-contact is enabled */
}

/* Footer logo
--------------------------------------------------------------- */
/* Footer disclaimer
--------------------------------------------------------------- */
.footer-disclaimer {
  -webkit-margin-before: 1em;
          margin-block-start: 1em;
}
/* ================================================================================
* Internals/ Default
================================================================================ */
/*!
* Default Sections: Main + Aside: Can also be reused on other templates with similar wireframes (eg. Profile Page, etc.)
-------------------------------------------------------------------------------- */
/* Default Sections: Main + Aside: Skeletons - no need to edit
--------------------------------------------------------------- */
.default-sections {
  gap: var(--default-gap-y, 0) var(--default-gap-x, 0);
}
.default-sections, .default-section, .default-section-main, .default-section-sidebar {
  min-inline-size: 0; /* grid/flex fixes*/
  max-inline-size: 100%;
}
.default-section-main {
  inline-size: 100%;
}
.default-section-sidebar {
  inline-size: var(--default-sidebar-width);
  justify-self: center;
}
.default-sections.default-sections-float {
  display: block;
}
.default-sections.default-sections-float :where(.default-section, .default-section-main, .default-section-sidebar) {
  margin-inline: auto;
}
.default-sections.default-sections-float :where(.default-section, .default-section-main, .default-section-sidebar):where(:nth-last-child(n+2)) {
  -webkit-margin-after: var(--default-gap-y);
          margin-block-end: var(--default-gap-y);
}
.default-sections:is(.default-sections-split, .default-sections-full) {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.default-sections.default-sections-grid {
  display: grid;
  grid-template-columns: 100%;
  justify-content: center;
}
@media only screen and (min-width: 75rem) {
  .default-section-main {
    max-inline-size: calc(var(--comp) - var(--default-sidebar-width) - var(--container-gutter, 0px) * 2 - var(--default-gap-x));
  }
  .default-section-sidebar {
    order: 9;
  }
  .default-sections:is(.default-sections-split, .default-sections-full) {
    flex-direction: row;
    align-items: normal;
    justify-content: center;
  }
  .default-sections.default-sections-reverse .default-section-sidebar {
    order: -1;
  }
  .default-sections.default-sections-reverse .default-section-main {
    order: 9;
  }
  .default-sections.default-sections-float::after {
    content: "";
    font-size: 0;
    visibility: hidden;
    block-size: 0;
    clear: both;
    display: table;
    inline-size: 100%;
    flex: 0 0 auto;
  }
  .default-sections.default-sections-float .default-section-sidebar {
    float: inline-end;
    clear: inline-end;
  }
  .default-sections.default-sections-float .default-section-main {
    float: inline-start;
    clear: inline-start;
    inline-size: calc(100% - (var(--default-sidebar-width)) - var(--default-gap-x));
  }
  .default-sections.default-sections-float .default-section-main:only-child {
    /* no sidebar adjust */
    float: none;
  }
  .default-sections.default-sections-float.default-sections-reverse .default-section-sidebar {
    float: inline-start;
    clear: inline-start;
  }
  .default-sections.default-sections-float.default-sections-reverse .default-section-main {
    float: inline-end;
    clear: inline-end;
  }
  .default-sections:is(.default-sections-split, .default-sections-full) .default-section-sidebar {
    flex: 0 0 auto;
  }
  .default-sections:is(.default-sections-split, .default-sections-full) .default-section-main {
    flex: 1 1;
  }
  .default-sections.default-sections-full {
    --default-gap-x: 0rem;
  }
  .default-sections.default-sections-full .default-section-main {
    margin-inline: auto;
  }
  .default-sections.default-sections-grid {
    grid-template-columns: 1fr var(--default-sidebar-width);
    grid-column-gap: var(--default-gap-x);
  }
  .default-sections.default-sections-grid .default-section-main {
    justify-self: center;
    grid-column: 1;
  }
  .default-sections.default-sections-grid:not(.default-sections-no-autocenter) .default-section-main:not(.default-sections:has(.default-section-sidebar) .default-section) {
    /* no sidebar adjust */
    grid-column: 1/-1 !important;
  }
  .default-sections.default-sections-grid .default-section-sidebar {
    grid-column: 2;
  }
  .default-sections.default-sections-grid .default-section-main, .default-sections.default-sections-grid .default-section-sidebar {
    inline-size: 100%;
    min-inline-size: 0;
    min-block-size: 0;
  }
  .default-sections.default-sections-grid.default-sections-reverse {
    grid-template-columns: var(--default-sidebar-width) 1fr;
  }
  .default-sections.default-sections-grid.default-sections-reverse .default-section-main {
    grid-column: 2;
  }
  .default-sections.default-sections-grid.default-sections-reverse .default-section-sidebar {
    grid-column: 1;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .default-sections:is(.default-sections-split, s.default-sections-grid) :is(.default-section-main, .default-section-sidebar) {
    display: contents;
  }
  .default-sections.default-sections-full .default-section-sidebar {
    align-self: stretch;
    inline-size: 100%;
  }
  .default-sections:not(.default-sections-full) > .default-section:is(aside, .aside):not(:only-child) {
    -webkit-padding-before: 0;
            padding-block-start: 0;
  }
  .default-sections:not(.default-sections-full) > .default-section:is(main, .main):not(:only-child) {
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
}

/* Default Sections Customizations
--------------------------------------------------------------- */
.default-sections {
  --default-sidebar-width: 100%;
  --default-gap-x: 5rem;
  --default-gap-y: 1.875rem;
}
@media only screen and (min-width: 48rem) {
  .default-sections {
    --default-sidebar-width: 28.5rem;
  }
}
@media only screen and (min-width: 75rem) {
  .default-sections {
    --default-sidebar-width: 22.5rem;
    --default-gap-y: 3.125rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  .default-sections {
    --default-gap-x: 9.3125rem;
  }
}
@media only screen and (min-width: 120rem) {
  .default-sections {
    --default-gap-x: 15.3125rem;
  }
}
@media only screen and (min-width: 75rem) {
  .default-sections.default-sections-split .default-section-sidebar-container {
    --container-gutter: 1rem;
  }
}
.default-sections.default-sections-full .default-section-sidebar {
  background: var(--scheme-bg, var(--color-light-alt));
}
@media only screen and (min-width: 75rem) {
  .default-sections.default-sections-full .default-section-main-container {
    --container-gutter: 7.5rem;
  }
}
@media only screen and (min-width: 120rem) {
  .default-sections.default-sections-full .default-section-main-container {
    --container-gutter: 15.625rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .default-sections.default-sections-full {
    row-gap: 0rem;
  }
}
/* Entry Skeletons. No need to edit 
--------------------------------------------------------------- */
.entry-thumbnail {
  --cover-aspect-w: var(--entry-thumbnail-aspect-w);
  --cover-aspect-l: var(--entry-thumbnail-aspect-l);
  flex: 0 0 auto;
  background-color: var(--color-light-alt);
}

/* Default Entries
-------------------------------------------------------------------------------- */
.entry-thumbnail {
  --entry-thumbnail-aspect-w: 15.625;
  --entry-thumbnail-aspect-l: 10.75;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  background: var(--color-neutral-light);
  border-radius: var(--global-radius);
}
.entry-thumbnail:nth-child(n+2) {
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
}
.entry-thumbnail:is(a) {
  color: inherit;
}
.entry-thumbnail:empty::after {
  content: "No Image Available";
  opacity: 0.4;
  font-size: 1.5rem;
  line-height: 1.125;
  font-family: var(--font-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: absolute;
  inset: 0;
  margin: auto;
  padding: 2em;
}
.entry-thumbnail img {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  max-inline-size: none;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: 50% 30%;
     object-position: 50% 30%;
  z-index: 1;
}
.entry-meta a:not(:hover, :focus) {
  text-decoration: underline;
}
.entry-meta-category a:not(:hover, :focus) {
  color: var(--color-primary);
}
.entry-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}
.entries .entry {
  display: grid;
  justify-content: space-between;
  -moz-column-gap: 2.1875rem;
       column-gap: 2.1875rem;
  row-gap: 2.1875rem;
}
.entries .entry:nth-child(n+2) {
  -webkit-padding-before: 3.75rem;
          padding-block-start: 3.75rem;
  -webkit-margin-before: 3.75rem;
          margin-block-start: 3.75rem;
  -webkit-border-before: 1px solid var(--color-neutral);
          border-block-start: 1px solid var(--color-neutral);
}
.entries .entry-thumbnail {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.entries .entry-thumbnail, .entries .entry-body {
  /* grid fix */
  min-inline-size: 0;
}
@media only screen and (min-width: 87.5rem) {
  .entries .entry {
    grid-template-columns: 250px 1fr;
  }
  .entries .entry-body {
    align-self: center;
  }
  .entries .entry-body:only-child {
    grid-column: 1/-1;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .entry-thumbnail {
    --entry-thumbnail-aspect-w: 648;
    --entry-thumbnail-aspect-l: 260;
  }
}
/*!
* Default Header
-------------------------------------------------------------------------------- */
.default-header {
  -webkit-margin-after: 1.5rem;
          margin-block-end: 1.5rem;
}
@media only screen and (min-width: 48rem) {
  .banner-has-h1.banner-button-shift .default-header {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
}
/*
* Default Layout/Template https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/layout/default.md
-------------------------------------------------------------------------------- */
@media only screen and (max-width: 74.9375rem) {
  .layout-default-sections-simple .layout-default-aside {
    max-inline-size: var(--default-sidebar-width);
  }
}
/*!
* Default Heading
-------------------------------------------------------------------------------- */
@media only screen and (min-width: 48rem) {
  .default-heading {
    text-wrap: auto;
  }
}
/*!
* Default Divider - Optional
-------------------------------------------------------------------------------- */
.default-divider {
  --fancy-border-margin-y: 3rem;
}
/*!
* Search Form
* Although optional, some builds may include this OR request this in the long run. Since it's built in to wordpress, we might as well at least give it some basic styles. Overhaul as needed
-------------------------------------------------------------------------------- */
.searchform {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: stretch;
}
.searchform:nth-last-child(n+2) {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
.searchform-field {
  border-start-end-radius: 0;
  border-end-end-radius: 0;
}
.searchform-button {
  order: 99;
  border-start-start-radius: 0;
  border-end-start-radius: 0;
}

.financing {
  margin-block: 3.875rem;
}
.financing .h1 {
  font-size: 2.8125rem;
}
.financing img {
  width: auto !important;
  height: auto !important;
}
.financing-columns {
  --columns-gap-x: 1.5rem;
  --columns-gap-y: 3.125rem;
  margin-top: 3.125rem;
}
.financing .image:nth-last-child(n+2) {
  -webkit-padding-after: var(--columns-gap-y);
          padding-block-end: var(--columns-gap-y);
  -webkit-border-after: 1px solid var(--color-neutral);
          border-block-end: 1px solid var(--color-neutral);
}
.financing .image {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 5rem;
  padding-inline: 1.875rem;
}
.financing .image picture {
  display: block;
  flex: 0 0 auto;
  inline-size: 9rem;
  text-align: center;
}
.financing .image picture img {
  margin-inline: auto;
}
.financing .image-title {
  margin-top: 0;
}
.financing .image-body {
  flex: 1 1;
}
@media only screen and (max-width: 47.9375rem) {
  .financing .image {
    flex-direction: column;
  }
}

.maintenance .h1 {
  font-size: 2.5rem;
}
.maintenance table :is(th, td):nth-child(n+2) {
  text-align: center;
}
.maintenance-columns {
  --columns-gap-x: 1.5rem;
  --columns-gap-y: 3.625rem;
}

/* ================================================================================
* Home Template
================================================================================ */
/* Template Home https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/home.md
-------------------------------------------------------------------------------- */
/*
* Home Related Classes
-------------------------------------------------------------------------------- */
:where(.home-section) :is(img):not(.content-icon *) {
  display: block;
  inline-size: 100%;
}
/* Add helper classes specific to this template as needed */
/*
* Home Template
-------------------------------------------------------------------------------- */
@media only screen and (max-width: 47.9375rem) {
  body.onep21-template-home {
    --layout-banner-offset: 0rem;
  }
}

#home-banner .banner-main {
  min-block-size: 31.25rem;
  justify-content: flex-end;
  -webkit-padding-before: 10.125rem;
          padding-block-start: 10.125rem;
}
#home-banner .banner-main-blocks {
  gap: 4.4375rem;
}
#home-banner .banner-body-blocks {
  gap: 1.375rem;
}
#home-banner .banner-buttons {
  display: none;
}
#home-banner .banner-background {
  --responsive-background-overlay-background:
  	linear-gradient(
  		to bottom,
  		rgba(49, 48, 24, 0.60) 0%,
  		rgba(255, 255, 255, 0.00) 14%
  	),
  	linear-gradient(
  		to bottom, rgba(240, 240, 240, 0.30) 13%,
  		rgba(13, 21, 10, 0.50) 34.5%,
  		rgba(5, 9, 6, 0.80) 50%,
  		rgba(5, 9, 6, 1) 53%
  	) ;
}
@media only screen and (min-width: 48rem) {
  #home-banner .banner-main {
    min-block-size: 85.6875rem;
  }
  #home-banner .primary-heading {
    font-size: 4.6875rem;
  }
  #home-banner .banner-background {
    --responsive-background-overlay-background:
    	linear-gradient(
    		to bottom, rgba(240, 240, 240, 0.30) 38%,
    		rgba(13, 21, 10, 0.50) 60%,
    		rgba(5, 9, 6, 0.95) 100%
    	) ;
  }
}
@media only screen and (min-width: 75rem) {
  #home-banner .banner-main {
    min-block-size: 66.4375rem;
    padding-block: 7rem;
    justify-content: flex-end;
    text-align: initial;
  }
  #home-banner .banner-main-container {
    --container-gutter: 2.625rem;
  }
  #home-banner .banner-main-blocks {
    justify-items: space-between;
    justify-content: space-between;
    align-items: end;
    gap: 1.625rem;
  }
  #home-banner .banner-background {
    --responsive-background-overlay-opacity: 1;
  }
}
@media only screen and (min-width: 87.5rem) {
  #home-banner .banner-main {
    min-block-size: 66.25rem;
    padding-block: 7.125rem;
  }
  #home-banner .banner-main-container {
    --container-gutter: 3.25rem;
  }
  #home-banner .banner-body-blocks {
    gap: 0.625rem;
  }
  #home-banner .primary-heading {
    font-size: 5.625rem;
  }
}
@media only screen and (min-width: 120rem) {
  #home-banner .banner-main {
    min-block-size: 66.25rem;
    padding-block: 6.8125rem;
  }
  #home-banner .banner-main-container {
    --container-gutter: 9.125rem;
  }
  #home-banner .banner-body-blocks {
    gap: 2.125rem;
  }
  #home-banner .primary-heading {
    font-size: 6.875rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  #home-banner .primary-heading {
    text-wrap: balance;
  }
}
@media only screen and (max-width: 47.9375rem) {
  #home-banner .banner-main {
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
  #home-banner #banner-form {
    border-end-start-radius: var(--layout-banner-offset);
    border-end-end-radius: var(--layout-banner-offset);
    -webkit-padding-after: 2.625rem;
            padding-block-end: 2.625rem;
  }
}

/*
* Home Section 1
-------------------------------------------------------------------------------- */
:is(.home-section-1, #home-section-1):is(.section-style-padded) {
  padding-block: 3.75rem 6.75rem;
}
:is(.home-section-1, #home-section-1) :is(.swiper) {
  --swiper-custom-arrow-offset-x: 4.8125rem;
}
:is(.home-section-1, #home-section-1) .section-item {
  background: var(--color-neutral-light);
  padding-inline: 1.25rem;
  -webkit-padding-before: 3rem;
          padding-block-start: 3rem;
  overflow: clip;
  border-radius: var(--global-radius);
}
:is(.home-section-1, #home-section-1) .section-item:is(.content-palette-dark) {
  background: var(--color-dark-alt);
}
:is(.home-section-1, #home-section-1) .section-item, :is(.home-section-1, #home-section-1) .section-item-container {
  display: flex;
  min-inline-size: 0;
  flex-direction: column;
}
:is(.home-section-1, #home-section-1) .section-item-container {
  inline-size: 100%;
  flex: 1 1;
  gap: 0.875rem;
}
:is(.home-section-1, #home-section-1) .section-item .number {
  flex-direction: column;
  align-items: center;
  -webkit-margin-before: auto;
          margin-block-start: auto;
  align-self: center;
}
:is(.home-section-1, #home-section-1) .section-item .number .number-link {
  font-size: 1.9375rem;
}
:is(.home-section-1, #home-section-1) .section-item .testimonials {
  inline-size: 100%;
}
:is(.home-section-1, #home-section-1) .section-item-heading {
  font-size: 1.125rem;
}
:is(.home-section-1, #home-section-1) .section-item-image {
  align-self: self-end;
  margin-block: auto 0;
  overflow: clip;
  border-start-start-radius: var(--global-radius);
  border-start-end-radius: var(--global-radius);
}
:is(.home-section-1, #home-section-1) .section-item-button {
  margin-block: 0.625rem 2.725rem;
}
:is(.home-section-1, #home-section-1) .section-item-center {
  padding-block: 0 4rem;
}
:is(.home-section-1, #home-section-1) .section-item-center-image {
  align-self: self-start;
  justify-self: self-start;
  inline-size: 22rem;
  -webkit-margin-before: -3.25rem;
          margin-block-start: -3.25rem;
  -webkit-margin-start: -2.5625rem;
          margin-inline-start: -2.5625rem;
}
:is(.home-section-1, #home-section-1) .section-item-right-image {
  position: relative;
}
:is(.home-section-1, #home-section-1) .section-item-right-button {
  inset: auto 1.75rem 1.875rem auto;
  position: absolute;
  margin: auto;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-1, #home-section-1):is(.section-style-padded) {
    padding-block: 5rem 9.4375rem;
  }
  :is(.home-section-1, #home-section-1) .section-container {
    --container-gutter: 9.625rem;
  }
  :is(.home-section-1, #home-section-1) .section-item {
    padding-inline: 1.875rem;
    -webkit-padding-before: 3.4375rem;
            padding-block-start: 3.4375rem;
  }
  :is(.home-section-1, #home-section-1) .section-item-center {
    padding-block: 0 3rem;
  }
  :is(.home-section-1, #home-section-1) .section-item-center-image {
    inline-size: 30.75rem;
    -webkit-margin-before: -5.6245rem;
            margin-block-start: -5.6245rem;
    -webkit-margin-start: -3.4065rem;
            margin-inline-start: -3.4065rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-1, #home-section-1):is(.section-style-padded) {
    padding-block: 7.5rem 9.94375rem;
  }
  :is(.home-section-1, #home-section-1) .section-container {
    --container-gutter: 8rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-1, #home-section-1):is(.section-style-padded) {
    padding-block: 7.5rem 10.125rem;
  }
  :is(.home-section-1, #home-section-1) .section-container {
    --container-gutter: 13.9375rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-1, #home-section-1):is(.section-style-padded) {
    padding-block: 8.75rem 14.75rem;
  }
  :is(.home-section-1, #home-section-1) .section-container {
    --container-gutter: 15.3125rem;
  }
  :is(.home-section-1, #home-section-1) .section-item-right {
    padding-inline: 3.3rem;
  }
  :is(.home-section-1, #home-section-1) .section-item-right-image {
    margin-inline: -1.42rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.home-section-1, #home-section-1) .section-item-heading > span {
    padding-inline: 0.875em;
  }
}

/*
* Home Section 2
-------------------------------------------------------------------------------- */
/*
* Section Offset Demo: For overlapping the section or parts of it to adjacent sections/layouts.
Sections php template parts should have classes ready for use in case overlaps are needed. DO NOT REMOVE THEM.
AVOID hard coding overlap css margins and use these variables with calc() or other similar css methods to offset instead, in case the site choses to omit overlapping or asjacent to overlapping sections due to missing content. (example: PQL44. on the case that the client chooses to omit the pa menu box, the layout breaks)

Feel free to copy/paste/comment out as needed. Find and replace `home-section-2` to rename variables and sections appropriately
Example of usage: PQL36, PQL40, PQL39
-------------------------------------------------------------------------------- */
:root {
  --home-section-2-offset: var(--global-radius-large);
}
/*
* Section Offset Demo: Overlap this section and adjust it siblings and or the siblings' contents to it
	NOTE: To reuse on other elements, copy this css and replace:
		* `home-section-2` with `[TEMPLATE]-section-[DESIRED_NUMBER]`
		* `home-section` with `[TEMPLATE]-section`
	NOTE: Classes to use:
		.home-section-2-offset-element => the element within the section that will have the negative margins to overlap itself
		.has-home-section-2-offset => the adjacent sections/ child of adjacent sections that will have the pseudo element to adjust itself if the `home-section-2-offset-element` is next to it
		// todo replicate profile offset behavior
-------------------------------------------------------------------------------- */
.home-section-2:has(.home-section-2-offset-element):nth-child(n+2) {
  position: relative;
  z-index: 2;
}

.template-wrapper:has(:is(main, .main) > .home-section-2) .has-home-section-2-offset.home-section:not(.home-section-2):has(+ .home-section-2 .home-section-2-offset-element)::after, .home-section:not(.home-section-2):has(+ .home-section-2 .home-section-2-offset-element) .template-wrapper:has(:is(main, .main) > .home-section-2) .has-home-section-2-offset::after {
  content: "";
  block-size: var(--home-section-2-offset);
  -webkit-margin-after: min(var(--home-section-2-offset) - var(--overlap-buffer), 0px);
          margin-block-end: min(var(--home-section-2-offset) - var(--overlap-buffer), 0px);
  display: block;
  flex: 0 0 auto;
  inline-size: 100%;
}
.template-wrapper:has(:is(main, .main) > .home-section-2) .home-section-2:has(.home-section-2-offset-element):nth-child(n+2) {
  -webkit-margin-before: calc((var(--home-section-2-offset) + var(--overlap-buffer)) * -1) !important;
          margin-block-start: calc((var(--home-section-2-offset) + var(--overlap-buffer)) * -1) !important;
  -webkit-padding-before: var(--overlap-buffer);
          padding-block-start: var(--overlap-buffer);
  border-start-start-radius: var(--home-section-2-offset);
  border-start-end-radius: var(--home-section-2-offset);
}
:is(.home-section-2):is(.section-style-padded) {
  padding-block: 0rem 3.75rem;
  background-color: var(--color-neutral-light, #DDEEF0);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 42.5rem at 40% 50%, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%), radial-gradient(circle 42.5rem at 10% 70%, rgba(8, 196, 208, 0.3) 0, rgba(8, 196, 208, 0.15) 35%, transparent 100%);
}
:is(.home-section-2) .section-feature {
  overflow: clip;
  border-radius: var(--global-radius);
  color: var(--color-light);
  background: var(--color-dark-alt);
  justify-self: center;
}
:is(.home-section-2) .section-feature-image {
  block-size: 12.5rem;
}
:is(.home-section-2) .section-feature-icon {
  font-size: 5rem;
  justify-self: self-end;
  -webkit-margin-end: 3rem;
          margin-inline-end: 3rem;
  -webkit-margin-before: -2.125rem;
          margin-block-start: -2.125rem;
  isolation: isolate;
}
:is(.home-section-2) .section-feature-body {
  padding-inline: 1.2875rem;
  -webkit-padding-after: 5.875rem;
          padding-block-end: 5.875rem;
}
:is(.home-section-2) .section-feature-body h2 {
  font-size: 1.875rem;
  color: inherit;
  margin-bottom: 0.9375rem;
}
:is(.home-section-2) .section-blocks-outer {
  gap: 4.375rem;
}
:is(.home-section-2) .section-blocks-header {
  gap: 1.75rem;
}
:is(.home-section-2) .section-blocks-feature {
  gap: 0;
}
:is(.home-section-2) .section-blocks-content {
  gap: 2.5rem;
}
:is(.home-section-2) .section-divider {
  --fancy-border-width: 4.4rem;
  --fancy-border-margin-y: 0;
  grid-column: 1/-1;
}
:is(.home-section-2) .section-heading {
  font-size: 2.8125rem;
  text-align: center;
  grid-column: 1/-1;
  inline-size: 12ch;
  justify-self: center;
  -webkit-text-stroke-width: 0.25em;
  -webkit-text-stroke-color: var(--color-neutral-light, #DDEEF0);
  position: relative;
  -webkit-margin-before: -0.625em;
          margin-block-start: -0.625em;
}
:is(.home-section-2) .section-heading::before {
  content: attr(data-content);
  -webkit-text-stroke-width: 0;
  -webkit-text-stroke-color: transparent;
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-2):is(.section-style-padded) {
    padding-block: 6.625rem;
  }
  :is(.home-section-2) .section-feature {
    inline-size: 34.25rem;
  }
  :is(.home-section-2) .section-feature-body {
    -webkit-padding-after: 3rem;
            padding-block-end: 3rem;
    padding-inline: 3.4375rem;
  }
  :is(.home-section-2) .section-divider {
    --fancy-border-width: 9.375rem;
  }
  :is(.home-section-2) .section-blocks-outer {
    gap: 5rem;
  }
  :is(.home-section-2) .section-blocks-header {
    gap: 4rem;
  }
  :is(.home-section-2) .section-heading {
    font-size: 3.75rem;
    inline-size: 16ch;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-2) .section-container {
    --container-gutter: 8.8125rem;
  }
  :is(.home-section-2) .section-feature {
    inline-size: 32.25rem;
  }
  :is(.home-section-2) .section-heading {
    font-size: 5rem;
    inline-size: 26ch;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-2):is(.section-style-padded) {
    padding-block: 8.75rem;
  }
  :is(.home-section-2) .section-container {
    --container-gutter: 3.8125rem;
  }
  :is(.home-section-2) .section-feature {
    inline-size: 34.25rem;
  }
  :is(.home-section-2) .section-blocks-outer {
    gap: 5.625rem 4.375rem;
    grid-template-columns: 1fr auto;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-2):is(.section-style-padded) {
    padding-block: 12.625rem;
  }
  :is(.home-section-2) .section-container {
    --container-gutter: 16.625rem;
  }
  :is(.home-section-2) .section-blocks-outer {
    gap: 5.375rem 11.25rem;
  }
}
/*
* Home Section 3
-------------------------------------------------------------------------------- */
:is(.home-section-3, #home-section-3) :is(.swiper) {
  --swiper-custom-arrow-offset-x: 0rem;
}
:is(.home-section-3, #home-section-3) img {
  border-radius: var(--global-radius);
}
:is(.home-section-3, #home-section-3) .section-top {
  background: var(--color-neutral-dark);
  padding-block: 2.125rem;
}
:is(.home-section-3, #home-section-3) .section-top::after {
  content: "";
  display: block;
  block-size: var(--global-radius-large);
  display: block;
}
:is(.home-section-3, #home-section-3) .section-top .section-button {
  display: flex;
  align-items: center;
  gap: 1.25rem;
  font-size: 1.25rem;
  font-weight: 500;
}
:is(.home-section-3, #home-section-3) .section-bottom {
  margin-top: calc(var(--global-radius-large) * -1);
  border-start-start-radius: var(--global-radius-large);
  border-start-end-radius: var(--global-radius-large);
  padding-block: 4.375rem 5rem;
  background: var(--scheme-bg-contrast, var(--color-dark)) linear-gradient(213deg, var(--color-dark, #003543) 6.59%, var(--color-dark-alt, #00485A) 33.02%, var(--color-dark-alt-alt, #003543) 78.24%);
  overflow: clip;
}
:is(.home-section-3, #home-section-3) .section-top-heading {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-size: 2.0625rem;
}
:is(.home-section-3, #home-section-3) .section-top-icon {
  flex: 0 0 auto;
  font-size: 3rem;
}
:is(.home-section-3, #home-section-3) .section-blocks-bottom {
  gap: 4.437rem;
}
:is(.home-section-3, #home-section-3) .section-blocks-top {
  place-items: center;
  gap: 0.9375rem;
}
:is(.home-section-3, #home-section-3) .section-blocks-header {
  gap: 1.125rem;
}
:is(.home-section-3, #home-section-3) .section-items {
  inline-size: 19.89881rem;
  grid-column: 1/-1;
}
:is(.home-section-3, #home-section-3) .section-item {
  --responsive-background-bg-color: var(--color-neutral-light, #08C4D0);
  border-radius: var(--global-radius);
  overflow: clip;
  padding: 2.5rem;
  text-align: initial;
  color: var(--color-dark-alt);
  min-block-size: 28.1875rem;
}
:is(.home-section-3, #home-section-3) .section-item:is(:hover, :focus) {
  --responsive-background-bg-color: var(--color-accent-alt);
  color: var(--color-light);
}
:is(.home-section-3, #home-section-3) .section-item .image-container {
  min-height: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  align-content: end;
  align-items: center;
  justify-items: space-between;
  justify-content: space-between;
}
:is(.home-section-3, #home-section-3) .section-item .image-container span:last-child {
  flex: 0 0 auto;
}
:is(.home-section-3, #home-section-3) .section-item-title {
  font-size: 2.5rem;
}
:is(.home-section-3, #home-section-3) .section-item-title:has(br) {
  font-size: 2.25rem;
}
:is(.home-section-3, #home-section-3) .section-feature-body-text {
  font-size: 1.4375rem;
}
:is(.home-section-3, #home-section-3) .section-header {
  text-align: center;
  grid-column: 1/-1;
}
:is(.home-section-3, #home-section-3) .section-heading {
  font-size: 2.8125rem;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-3, #home-section-3) .section-top {
    padding-block: 2.125rem 1rem;
  }
  :is(.home-section-3, #home-section-3) .section-bottom {
    padding-block: 6.1875rem 8.25rem;
  }
  :is(.home-section-3, #home-section-3) .section-items {
    inline-size: 44.4375rem;
  }
  :is(.home-section-3, #home-section-3) .section-heading {
    font-size: 4.0625rem;
  }
  :is(.home-section-3, #home-section-3) .section-top-heading {
    font-size: 3.125rem;
  }
  :is(.home-section-3, #home-section-3) .section-feature {
    inline-size: 25rem;
    justify-self: center;
  }
  :is(.home-section-3, #home-section-3) .section-feature-body-text {
    font-size: 1.4375rem;
    line-height: 1.52;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-3, #home-section-3) .slider-custom-buttons {
    justify-content: flex-end;
  }
  :is(.home-section-3, #home-section-3) .section-container-bottom {
    --container-gutter: 3.81rem;
  }
  :is(.home-section-3, #home-section-3) .section-bottom {
    padding-block: 7.41rem 13.75rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-top {
    gap: 6.25rem;
    grid-template-columns: auto auto;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-bottom {
    grid-template-columns: auto 1fr;
    -moz-column-gap: 5rem;
         column-gap: 5rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-header {
    grid-template-columns: 1fr auto;
    text-align: initial;
    justify-content: space-between;
    -moz-column-gap: 3.3875rem;
         column-gap: 3.3875rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-header > :not(.section-button) {
    grid-column: 1;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-header .section-button {
    grid-row: span 2;
    grid-column: -2;
    align-self: self-end;
  }
  :is(.home-section-3, #home-section-3) .section-header {
    -webkit-margin-after: -2rem;
            margin-block-end: -2rem;
  }
  :is(.home-section-3, #home-section-3) .section-heading {
    font-size: 4.0625rem;
  }
  :is(.home-section-3, #home-section-3) .section-top {
    padding-block: 2.125rem 2rem;
  }
  :is(.home-section-3, #home-section-3) .section-top-heading {
    font-size: 4.0625rem;
  }
  :is(.home-section-3, #home-section-3) .section-items {
    inline-size: 67.9375rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-3, #home-section-3) .section-container-bottom {
    --container-gutter: 6.75rem;
  }
  :is(.home-section-3, #home-section-3) .section-bottom {
    padding-block: 8.72rem 12.5rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-bottom {
    -moz-column-gap: 11.25rem;
         column-gap: 11.25rem;
  }
}
@media only screen and (min-width: 87.5rem) and (max-width: 119.9375rem) {
  :is(.home-section-3, #home-section-3) .section-header {
    inline-size: 67.6875rem;
    justify-self: center;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-3, #home-section-3) .section-container-bottom {
    --container-gutter: 14.625rem;
  }
  :is(.home-section-3, #home-section-3) .section-bottom {
    padding-block: 10rem 12.75rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-bottom {
    grid-template-columns: 1fr 1.375fr;
    -moz-column-gap: 12rem;
         column-gap: 12rem;
    row-gap: 8.8125rem;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-header {
    -moz-column-gap: 15.3875rem;
         column-gap: 15.3875rem;
  }
  :is(.home-section-3, #home-section-3) .section-feature {
    justify-self: self-end;
  }
  :is(.home-section-3, #home-section-3) .section-items {
    inline-size: 91rem;
  }
  :is(.home-section-3, #home-section-3) .section-header {
    -webkit-margin-after: -6.25rem;
            margin-block-end: -6.25rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :is(.home-section-3, #home-section-3) .section-content {
    inline-size: 38rem;
    justify-self: center;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.home-section-3, #home-section-3) .section-item {
    padding-inline: 2.25rem;
  }
  :is(.home-section-3, #home-section-3) .section-content {
    inline-size: 100%;
    justify-self: center;
  }
  :is(.home-section-3, #home-section-3) .section-blocks-header {
    justify-items: center;
    justify-content: center;
  }
}

/*
* Home Section 4
-------------------------------------------------------------------------------- */
/*
* Section Offset Demo: For overlapping the section or parts of it to adjacent sections/layouts.
Sections php template parts should have classes ready for use in case overlaps are needed. DO NOT REMOVE THEM.
AVOID hard coding overlap css margins and use these variables with calc() or other similar css methods to offset instead, in case the site choses to omit overlapping or asjacent to overlapping sections due to missing content. (example: PQL44. on the case that the client chooses to omit the pa menu box, the layout breaks)

Feel free to copy/paste/comment out as needed. Find and replace `home-section-4` to rename variables and sections appropriately
Example of usage: PQL36, PQL40, PQL39
-------------------------------------------------------------------------------- */
:root {
  --home-section-4-offset: var(--global-radius-large);
}
@media only screen and (min-width: 48rem) {
  :root {
    --home-section-4-offset: calc(var(--global-radius-large) + 11.14rem);
  }
}
@media only screen and (min-width: 75rem) {
  :root {
    --home-section-4-offset: calc(var(--global-radius-large) + 11.875rem);
  }
}
@media only screen and (min-width: 87.5rem) {
  :root {
    --home-section-4-offset: calc(var(--global-radius-large) + 22.27rem);
  }
}
@media only screen and (min-width: 120rem) {
  :root {
    --home-section-4-offset: calc(var(--global-radius-large) + 21.75rem);
  }
}

/*
* Section Offset Demo: Overlap this section and adjust it siblings and or the siblings' contents to it
	NOTE: To reuse on other elements, copy this css and replace:
		* `home-section-4` with `[TEMPLATE]-section-[DESIRED_NUMBER]`
		* `home-section` with `[TEMPLATE]-section`
	NOTE: Classes to use:
		.home-section-4-offset-element => the element within the section that will have the negative margins to overlap itself
		.has-home-section-4-offset => the adjacent sections/ child of adjacent sections that will have the pseudo element to adjust itself if the `home-section-4-offset-element` is next to it
		// todo replicate profile offset behavior
-------------------------------------------------------------------------------- */
.home-section-4:has(.home-section-4-offset-element):nth-child(n+2) {
  position: relative;
  z-index: 2;
}

.template-wrapper:has(:is(main, .main) > .home-section-4) .has-home-section-4-offset.home-section:not(.home-section-4):has(+ .home-section-4 .home-section-4-offset-element):not(:has(.section-bottom))::after, .template-wrapper:has(:is(main, .main) > .home-section-4) .has-home-section-4-offset.home-section:not(.home-section-4):has(+ .home-section-4 .home-section-4-offset-element):has(.section-bottom) .section-bottom::after, .home-section:not(.home-section-4):has(+ .home-section-4 .home-section-4-offset-element) .template-wrapper:has(:is(main, .main) > .home-section-4) .has-home-section-4-offset:not(:has(.section-bottom))::after, .home-section:not(.home-section-4):has(+ .home-section-4 .home-section-4-offset-element) .template-wrapper:has(:is(main, .main) > .home-section-4) .has-home-section-4-offset:has(.section-bottom) .section-bottom::after {
  content: "";
  block-size: var(--home-section-4-offset);
  -webkit-margin-after: min(var(--home-section-4-offset) - var(--overlap-buffer), 0px);
          margin-block-end: min(var(--home-section-4-offset) - var(--overlap-buffer), 0px);
  display: block;
  flex: 0 0 auto;
  inline-size: 100%;
}
.template-wrapper:has(:is(main, .main) > .home-section-4) .home-section-4:has(.home-section-4-offset-element):nth-child(n+2) {
  -webkit-padding-before: var(--overlap-buffer) !important;
          padding-block-start: var(--overlap-buffer) !important;
  -webkit-margin-before: calc((var(--global-radius-large)) * -1) !important;
          margin-block-start: calc((var(--global-radius-large)) * -1) !important;
  border-start-start-radius: var(--global-radius-large);
  border-start-end-radius: var(--global-radius-large);
}
.template-wrapper:has(:is(main, .main) > .home-section-4) .home-section-4:has(.home-section-4-offset-element):nth-child(n+2) .home-section-4-offset-element {
  -webkit-margin-before: calc((var(--home-section-4-offset) - var(--global-radius-large) + var(--overlap-buffer)) * -1);
          margin-block-start: calc((var(--home-section-4-offset) - var(--global-radius-large) + var(--overlap-buffer)) * -1);
}

:is(.home-section-4, #home-section-4) {
  background-color: var(--color-neutral-light, #DDEEF0);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 42.5rem at 40% 50%, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%);
}
:is(.home-section-4, #home-section-4) img {
  border-radius: var(--global-radius);
}
:is(.home-section-4, #home-section-4):is(.section-style-padded) {
  padding-block: 4.4375rem;
}
:is(.home-section-4, #home-section-4) .section-blocks-outer {
  gap: 4.4375rem;
}
:is(.home-section-4, #home-section-4) .section-blocks-header {
  gap: 1.75rem;
}
:is(.home-section-4, #home-section-4) .section-header {
  margin-bottom: -1.0625rem;
}
:is(.home-section-4, #home-section-4) .section-image {
  grid-column: 1/-1;
  justify-self: center;
  margin-inline: -30vi;
}
:is(.home-section-4, #home-section-4) .section-heading {
  font-size: 2.8125rem;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-4, #home-section-4):is(.section-style-padded) {
    padding-block: 5rem 6.625rem;
  }
  :is(.home-section-4, #home-section-4) .section-container {
    --container-gutter: 4.875rem;
  }
  :is(.home-section-4, #home-section-4) .section-blocks-outer {
    gap: 5rem;
  }
  :is(.home-section-4, #home-section-4) .section-header {
    -webkit-margin-after: -2.125rem;
            margin-block-end: -2.125rem;
  }
  :is(.home-section-4, #home-section-4) .section-image {
    inline-size: 43.04744rem;
  }
  :is(.home-section-4, #home-section-4) .section-heading {
    font-size: 4.0625rem;
  }
  :is(.home-section-4, #home-section-4) .section-content {
    inline-size: 38.3125rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-4, #home-section-4):is(.section-style-padded) {
    padding-block: 5rem 7.11rem;
  }
  :is(.home-section-4, #home-section-4) .section-container {
    --container-gutter: 8.5rem;
  }
  :is(.home-section-4, #home-section-4) .section-blocks-outer {
    gap: 5rem 6.25rem;
    grid-template-columns: auto auto;
    justify-content: center;
    justify-items: center;
  }
  :is(.home-section-4, #home-section-4) .section-image {
    inline-size: 68.75rem;
  }
  :is(.home-section-4, #home-section-4) .section-content {
    inline-size: 29.125rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-4, #home-section-4):is(.section-style-padded) {
    padding-block: 6.875rem 7.375rem;
  }
  :is(.home-section-4, #home-section-4) .section-container {
    --container-gutter: 5.75rem;
  }
  :is(.home-section-4, #home-section-4) .section-blocks-outer {
    gap: 6.875rem 6.25rem;
  }
  :is(.home-section-4, #home-section-4) .section-image {
    inline-size: 81.25rem;
  }
  :is(.home-section-4, #home-section-4) .section-content {
    inline-size: 33.44rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-4, #home-section-4):is(.section-style-padded) {
    padding-block: 8.5rem;
  }
  :is(.home-section-4, #home-section-4) .section-container {
    --container-gutter: 20.875rem;
  }
  :is(.home-section-4, #home-section-4) .section-blocks-outer {
    gap: 8.5rem 10.25rem;
  }
  :is(.home-section-4, #home-section-4) .section-image {
    inline-size: 97.125rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.home-section-4, #home-section-4) .section-image {
    inline-size: 100vi;
    margin-inline: calc(var(--container-gutter) * -1);
  }
  :is(.home-section-4, #home-section-4) .section-image img {
    border-radius: 0;
  }
}

/*
* Home Section 5
-------------------------------------------------------------------------------- */
:is(.home-section-5) {
  background-color: var(--scheme-bg, var(--color-light-alt));
}
:is(.home-section-5):is(.section-style-padded) {
  padding-block: 5rem;
}
:is(.home-section-5) .swiper-custom-buttons {
  position: absolute;
  inset-inline-start: 0;
  inset-inline-end: 0;
  inset-block-end: 4.9rem;
  margin: auto;
}
:is(.home-section-5) .swiper-custom-buttons .swiper-button-prev,
:is(.home-section-5) .swiper-custom-buttons .swiper-button-next {
  -webkit-margin-before: 0;
          margin-block-start: 0;
}
:is(.home-section-5) .profile-image {
  --profile-image-aspect-w: 25;
  --profile-image-aspect-l: 17.125;
}
:is(.home-section-5) .profile-container {
  gap: 3rem;
}
:is(.home-section-5) .profile-summary {
  text-align: initial;
  align-items: initial;
}
:is(.home-section-5) .profiles-columns {
  --columns-gap-y: 2.75rem;
}
:is(.home-section-5) .profiles-columns .profile:nth-last-child(n+2) {
  -webkit-border-after: 1px solid var(--color-neutral);
          border-block-end: 1px solid var(--color-neutral);
  -webkit-padding-after: var(--columns-gap-y);
          padding-block-end: var(--columns-gap-y);
}
:is(.home-section-5) .section-lists-columns {
  --columns-gap-y: 1.875rem;
  --columns-gap-x: 3.125rem;
}
:is(.home-section-5) .section-lists-columns .list-title {
  margin-bottom: 0.9375rem;
}
:is(.home-section-5) .section-lists-columns .list {
  -webkit-border-after: 1px solid var(--color-neutral);
          border-block-end: 1px solid var(--color-neutral);
  -webkit-padding-after: var(--columns-gap-y);
          padding-block-end: var(--columns-gap-y);
}
:is(.home-section-5) .section-cluster {
  inline-size: 39.1875rem;
  justify-self: center;
  margin-inline: calc((100% - (var(--comp) - (var(--comp) - var(--container-gutter) * 2))) / -2);
}
:is(.home-section-5) .section-cluster .responsive-background {
  --responsive-background-overlay-opacity: 1;
  --responsive-background-overlay-background: linear-gradient(0deg, rgba(0, 0, 0, 0.20) 0%, rgba(0, 0, 0, 0.20) 100%);
}
:is(.home-section-5) .section-cluster-image, :is(.home-section-5) .section-cluster-body {
  overflow: clip;
}
:is(.home-section-5) .section-cluster-image {
  min-block-size: 32.5625rem;
  --cover-aspect-w: 39.1875;
  --cover-aspect-l: 32.5625;
}
:is(.home-section-5) .section-cluster-image, :is(.home-section-5) .section-cluster-image img {
  display: block;
}
:is(.home-section-5) .section-cluster-image-header {
  padding-block: 4.375rem;
  padding-inline: 1.25rem;
  display: grid;
  align-content: end;
  gap: 1.375rem;
}
:is(.home-section-5) .section-cluster-image-heading {
  font-size: 4.375rem;
}
:is(.home-section-5) .section-cluster-body {
  --fancy-background-elesi-width: 34.03125rem;
  --fancy-background-elesi-opacity: .25;
  --fancy-background-elesi-t: -6rem;
  --fancy-background-elesi-r: -3rem;
  --fancy-background-elesi-l: auto;
  padding-inline: 1.875rem;
  padding-block: 4.8125rem;
}
:is(.home-section-5) .section-cluster-body:has(.swiper-button-prev, .swiper-button-next) {
  -webkit-padding-after: 11.6875rem;
          padding-block-end: 11.6875rem;
  position: relative;
}
:is(.home-section-5) .section-blocks-cluster {
  gap: 0;
}
:is(.home-section-5) .section-blocks-outer {
  gap: 3.75rem;
}
:is(.home-section-5) .section-heading {
  font-size: 1.75rem;
  text-wrap: wrap;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-5):is(.section-style-padded) {
    padding-block: 6.25rem;
  }
  :is(.home-section-5) .swiper-custom-buttons {
    inset-inline-start: auto;
    inset-inline-end: 2.625rem;
    inset-block-end: 2.625rem;
  }
  :is(.home-section-5) .profile {
    justify-self: center;
  }
}
@media only screen and (min-width: 48rem) and (max-width: 74.9375rem) {
  :is(.home-section-5) .profile {
    inline-size: 25rem;
  }
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-5) .profiles-columns {
    --columns-gap-y: 3.875rem;
  }
  :is(.home-section-5) .section-lists-columns {
    --columns-gap-y: 3.125rem;
  }
  :is(.home-section-5) .section-cluster {
    inline-size: 39.1875rem;
  }
  :is(.home-section-5) .section-cluster-image, :is(.home-section-5) .section-cluster-body {
    border-radius: var(--global-radius);
    overflow: clip;
  }
  :is(.home-section-5) .section-cluster-image {
    align-self: stretch;
    min-block-size: 100%;
  }
  :is(.home-section-5) .section-cluster-image-header {
    padding-inline: 3.625rem;
  }
  :is(.home-section-5) .section-cluster-body {
    padding-block: 4.6875rem;
    padding-inline: 4.95rem;
  }
  :is(.home-section-5) .section-cluster-body:has(.swiper-button-prev, .swiper-button-next) {
    -webkit-padding-after: 9.875rem;
            padding-block-end: 9.875rem;
  }
  :is(.home-section-5) .section-blocks-outer {
    gap: 5rem;
  }
  :is(.home-section-5) .section-blocks-cluster {
    gap: 1.5rem;
  }
  :is(.home-section-5) .section-heading {
    font-size: 2.3125rem;
    max-width: 28ch;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-5):is(.section-style-padded) {
    padding-block: 7.5rem;
  }
  :is(.home-section-5) .profiles-columns {
    --columns-gap-y: 5.25rem;
  }
  :is(.home-section-5) .profile-container {
    flex-direction: row;
    align-items: center;
    gap: 6.875rem;
  }
  :is(.home-section-5) .profile-image {
    flex: 0 0 auto;
    inline-size: 25rem;
  }
  :is(.home-section-5) .section-lists-columns {
    --columns-gap-x: 5rem;
    --columns-number: 2;
    -webkit-margin-after: -3.5rem;
            margin-block-end: -3.5rem;
  }
  :is(.home-section-5) .section-container {
    --container-gutter: 3rem;
  }
  :is(.home-section-5) .section-cluster {
    inline-size: 71.25rem;
  }
  :is(.home-section-5) .section-cluster-body {
    padding-inline: 4.9375rem;
    inline-size: 45.9375rem;
  }
  :is(.home-section-5) .section-cluster-body:has(.swiper-button-prev, .swiper-button-next) {
    -webkit-padding-after: 7.875rem;
            padding-block-end: 7.875rem;
  }
  :is(.home-section-5) .section-cluster-image-header {
    padding-inline: 1.875rem;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  :is(.home-section-5) .section-feature-image {
    display: contents;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-5) .section-blocks-outer {
    gap: 6rem;
  }
  :is(.home-section-5) .section-blocks-cluster {
    gap: 1.25rem;
    grid-template-columns: 1fr auto;
  }
  :is(.home-section-5) .section-heading {
    max-width: 47ch;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-5):is(.section-style-padded) {
    padding-block: 8.75rem;
  }
  :is(.home-section-5) .profile {
    inline-size: 74.375rem;
  }
  :is(.home-section-5) .section-lists-columns {
    --columns-gap-x: 11.875rem;
    -webkit-margin-after: 3.5rem;
            margin-block-end: 3.5rem;
  }
  :is(.home-section-5) .section-container {
    --container-gutter: 3.2875rem;
  }
  :is(.home-section-5) .section-cluster {
    inline-size: 80.375rem;
  }
  :is(.home-section-5) .section-cluster-body {
    padding-inline: 6.125rem;
    inline-size: 48.2875rem;
  }
  :is(.home-section-5) .section-blocks-outer {
    gap: 5.625rem;
  }
  :is(.home-section-5) .section-blocks-cluster {
    gap: 1.875rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-5):is(.section-style-padded) {
    padding-block: 9.14rem 12.5rem;
  }
  :is(.home-section-5) .section-lists-columns {
    --columns-gap-x: 11.75rem;
    -webkit-margin-after: -0.75rem;
            margin-block-end: -0.75rem;
  }
  :is(.home-section-5) .swiper-custom-buttons {
    inset-block-end: 3.2875rem;
  }
  :is(.home-section-5) .section-container {
    --container-gutter: 19rem;
  }
  :is(.home-section-5) .section-cluster {
    inline-size: 93.875rem;
  }
  :is(.home-section-5) .section-cluster-body {
    padding-inline: 6.75rem;
    inline-size: 53.125rem;
  }
  :is(.home-section-5) .section-cluster-image-header {
    padding-inline: 3.625rem;
  }
  :is(.home-section-5) .section-blocks-outer {
    gap: 5.375rem;
  }
  :is(.home-section-5) .section-blocks-cluster {
    gap: 1.5rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :is(.home-section-5) .section-content {
    inline-size: 31.875rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.home-section-5):is(.has-home-section-6-offset)::after,
  main.has-layout-footer-offset:has(> :is(.home-section-5):last-child)::after {
    background: var(--color-dark-alt);
  }
  main.has-layout-footer-offset:has(> :is(.home-section-5):last-child) {
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
  :is(.home-section-5):is(.section-style-padded) {
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
  :is(.home-section-5):is(.section-style-margined) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
  :is(.home-section-5) .section-cluster {
    max-inline-size: none;
    inline-size: auto;
    margin-inline: calc(var(--container-gutter) * -1);
    justify-self: stretch;
  }
}

/*
* Home Section 6
-------------------------------------------------------------------------------- */
/*
* Section Offset Demo: For overlapping the section or parts of it to adjacent sections/layouts.
Sections php template parts should have classes ready for use in case overlaps are needed. DO NOT REMOVE THEM.
AVOID hard coding overlap css margins and use these variables with calc() or other similar css methods to offset instead, in case the site choses to omit overlapping or asjacent to overlapping sections due to missing content. (example: PQL44. on the case that the client chooses to omit the pa menu box, the layout breaks)

Feel free to copy/paste/comment out as needed. Find and replace `home-section-6` to rename variables and sections appropriately
Example of usage: PQL36, PQL40, PQL39
-------------------------------------------------------------------------------- */
:root {
  --home-section-6-offset: 0rem;
}
@media only screen and (min-width: 48rem) {
  :root {
    --home-section-6-offset: var(--global-radius-large);
  }
}
/*
* Section Offset Demo: Overlap this section and adjust it siblings and or the siblings' contents to it
	NOTE: To reuse on other elements, copy this css and replace:
		* `home-section-6` with `[TEMPLATE]-section-[DESIRED_NUMBER]`
		* `home-section` with `[TEMPLATE]-section`
	NOTE: Classes to use:
		.home-section-6-offset-element => the element within the section that will have the negative margins to overlap itself
		.has-home-section-6-offset => the adjacent sections/ child of adjacent sections that will have the pseudo element to adjust itself if the `home-section-6-offset-element` is next to it
		// todo replicate profile offset behavior
-------------------------------------------------------------------------------- */
.home-section-6:has(.home-section-6-offset-element):nth-child(n+2) {
  position: relative;
  z-index: 2;
}

.template-wrapper:has(:is(main, .main) > .home-section-6) .has-home-section-6-offset.home-section:not(.home-section-6):has(+ .home-section-6 .home-section-6-offset-element)::after, .home-section:not(.home-section-6):has(+ .home-section-6 .home-section-6-offset-element) .template-wrapper:has(:is(main, .main) > .home-section-6) .has-home-section-6-offset::after {
  content: "";
  block-size: var(--home-section-6-offset);
  -webkit-margin-after: min(var(--home-section-6-offset) - var(--overlap-buffer), 0px);
          margin-block-end: min(var(--home-section-6-offset) - var(--overlap-buffer), 0px);
  display: block;
  flex: 0 0 auto;
  inline-size: 100%;
}
.template-wrapper:has(:is(main, .main) > .home-section-6) .home-section-6:has(.home-section-6-offset-element):nth-child(n+2) {
  -webkit-margin-before: calc((var(--home-section-6-offset) + var(--overlap-buffer)) * -1) !important;
          margin-block-start: calc((var(--home-section-6-offset) + var(--overlap-buffer)) * -1) !important;
  border-start-start-radius: var(--home-section-6-offset);
  border-start-end-radius: var(--home-section-6-offset);
}
:is(.home-section-6) {
  background-color: var(--color-neutral-light, #DDEEF0);
  background-repeat: no-repeat;
  background-image: radial-gradient(circle 42.5rem at 40% 50%, rgba(247, 195, 162, 0.3) 0, rgba(247, 195, 162, 0.15) 35%, transparent 100%);
}
:is(.home-section-6):is(.section-style-padded) {
  padding-block: 5.625rem 5.4375rem;
}
:is(.home-section-6) .section-feature {
  gap: 5rem;
  place-items: center;
}
:is(.home-section-6) .section-feature-image-item, :is(.home-section-6) .section-feature-image, :is(.home-section-6) .section-feature-body {
  place-self: center;
}
:is(.home-section-6) .section-feature-image {
  gap: 3rem;
  place-self: center;
}
:is(.home-section-6) .section-feature-image-item {
  --cover-aspect-w: 551;
  --cover-aspect-l: 667;
}
:is(.home-section-6) .section-feature-image-item:not(.active) {
  display: none;
}
:is(.home-section-6) .section-feature-image-legend {
  place-items: center;
  place-content: center;
  gap: 1.125rem;
  display: flex;
  grid-column: 1/-1;
  flex-wrap: wrap;
}
:is(.home-section-6) .section-feature-image-legend-item {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3125rem;
  font-size: 1.0625rem;
  line-height: 1.17;
  font-weight: 500;
}
:is(.home-section-6) .section-feature-image-legend-item-circle {
  font-size: 1rem;
  width: 1em;
  border-radius: 9999em;
}
:is(.home-section-6) .section-feature-body {
  --columns-gap-y: 1.875rem;
}
:is(.home-section-6) .section-feature-body-item:nth-child(n+2) {
  -webkit-border-before: 1px solid var(--color-neutral);
          border-block-start: 1px solid var(--color-neutral);
  -webkit-padding-before: var(--columns-gap-y);
          padding-block-start: var(--columns-gap-y);
}
:is(.home-section-6) .section-feature-body-item {
  color: var(--color-neutral-dark);
}
:is(.home-section-6) .section-feature-body-item.active {
  color: var(--color-dark-alt);
}
:is(.home-section-6) .section-feature-body-item-subheading {
  -webkit-margin-after: 0.8125rem;
          margin-block-end: 0.8125rem;
}
:is(.home-section-6) .section-feature-body-item-heading {
  font-size: 2.1875rem;
  color: inherit;
  -webkit-margin-after: 0.75rem;
          margin-block-end: 0.75rem;
}
:is(.home-section-6) .section-feature-body-item-heading:is(.active *) {
  color: var(--color-primary);
}
:is(.home-section-6) .section-feature-body-item-items {
  font-size: 1.25rem;
  line-height: 1;
  color: inherit;
  font-weight: 500;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25em 2.5rem;
}
:is(.home-section-6) .section-blocks-header {
  gap: 1.875rem;
}
:is(.home-section-6) .section-blocks-outer {
  gap: 5rem;
}
:is(.home-section-6) .section-heading {
  font-size: 2.8125rem;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-6):is(.section-style-padded) {
    padding-block: 6.2875rem 6.125rem;
  }
  :is(.home-section-6) .section-feature-image-item {
    inline-size: 28rem;
    justify-self: center;
  }
  :is(.home-section-6) .section-feature-body {
    --columns-gap-y: 1.25rem;
    inline-size: 39.3125rem;
  }
  :is(.home-section-6) .section-heading {
    font-size: 4.0625rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-6):is(.section-style-padded) {
    padding-block: 6.875rem 6.875rem;
  }
  :is(.home-section-6) .home-section-6 {
    -webkit-margin-after: 1.75rem;
            margin-block-end: 1.75rem;
  }
  :is(.home-section-6) .section-container {
    --container-gutter: 5rem;
  }
  :is(.home-section-6) .section-feature {
    grid-template-columns: 1fr auto;
    gap: 4.5625rem;
  }
}
@media only screen and (min-width: 75rem) and (max-width: 87.4375rem) {
  :is(.home-section-6) .section-feature-image {
    display: contents;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-6) .section-feature-image-item {
    inline-size: 28rem;
    justify-self: center;
    order: -1;
  }
  :is(.home-section-6) .section-feature-body {
    inline-size: auto;
  }
  :is(.home-section-6) .section-blocks-outer {
    gap: 3.875rem;
  }
  :is(.home-section-6) .section-heading {
    font-size: 5rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-6):is(.section-style-padded) {
    padding-block: 5.25rem 7.9375rem;
  }
  :is(.home-section-6) .section-feature {
    display: contents;
  }
  :is(.home-section-6) .section-feature-image {
    grid-row: span 2;
    gap: 2.125rem;
  }
  :is(.home-section-6) .section-feature-image-item {
    inline-size: 36.125rem;
  }
  :is(.home-section-6) .section-feature-body {
    grid-column: -2;
  }
  :is(.home-section-6) .section-blocks-outer {
    grid-template-columns: auto 1fr;
    gap: 5.125rem 3.875rem;
  }
  :is(.home-section-6) .section-header {
    grid-column: -2;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-6):is(.section-style-padded) {
    padding-block: 6.375rem 7.3125rem;
  }
  :is(.home-section-6) .section-container {
    --container-gutter: 16.75rem;
  }
  :is(.home-section-6) .section-blocks-outer {
    gap: 0 8rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.home-section-6) .section-feature-image-legend {
    flex-direction: column;
  }
  :is(.home-section-6) .section-feature-body {
    text-align: center;
  }
  :is(.home-section-6) .section-feature-body-item-items {
    flex-direction: column;
  }
}

/*
* Home Section 7
-------------------------------------------------------------------------------- */
:is(.home-section-7):is(.section-style-padded) {
  padding-block: 3rem 6.375rem;
}
:is(.home-section-7) .section-blocks-header {
  gap: 1.8125rem;
}
:is(.home-section-7) .section-blocks-outer {
  gap: 2rem;
}
:is(.home-section-7) .section-header {
  margin-block: 4.625rem 1.25rem;
}
:is(.home-section-7) .section-heading {
  font-size: 2.8125rem;
  text-wrap: balance;
}
:is(.home-section-7) .section-subheading {
  text-wrap: balance;
}
:is(.home-section-7) .section-lead {
  max-inline-size: min(50ch, 95%);
}
:is(.home-section-7) .section-button {
  place-self: center;
}
@media only screen and (min-width: 48rem) {
  :is(.home-section-7):is(.section-style-padded) {
    padding-block: 3rem 7.6rem;
  }
  :is(.home-section-7) .swiper {
    --swiper-custom-arrow-offset-x: 6.125rem;
  }
  :is(.home-section-7) .section-blocks-outer {
    gap: 2rem;
  }
  :is(.home-section-7) .section-blocks-header {
    gap: 1.625rem;
  }
  :is(.home-section-7) .section-heading {
    font-size: 4.0625rem;
  }
  :is(.home-section-7) .section-items {
    inline-size: 26.2875rem;
    justify-self: center;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.home-section-7):is(.section-style-padded) {
    padding-block: 3rem 8.75rem;
  }
  :is(.home-section-7) .section-blocks-outer {
    gap: 3.125rem;
  }
  :is(.home-section-7) .section-header {
    margin-block: 6.375rem 1.625rem;
  }
  :is(.home-section-7) .section-heading {
    font-size: 5rem;
  }
  :is(.home-section-7) .section-lead {
    max-inline-size: 81ch;
  }
  :is(.home-section-7) .section-items {
    inline-size: 54rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.home-section-7):is(.section-style-padded) {
    padding-block: 3rem 8.875rem;
  }
  :is(.home-section-7) .section-header {
    margin-block: 5.875rem 2.75rem;
  }
  :is(.home-section-7) .section-items {
    inline-size: 81.72rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.home-section-7):is(.section-style-padded) {
    padding-block: 3rem 12.375rem;
  }
  :is(.home-section-7) .section-blocks-outer {
    gap: 3.0625rem;
  }
  :is(.home-section-7) .section-items {
    inline-size: 89.1875rem;
  }
}
/*
* Home Section 8
-------------------------------------------------------------------------------- */
/*
* Home Section 9
-------------------------------------------------------------------------------- */
/*
* Home Section 10
-------------------------------------------------------------------------------- */
/*
* Home Section 11
-------------------------------------------------------------------------------- */
/*
* Home Section 12
-------------------------------------------------------------------------------- */
:is(.home-section-12, #home-section-12) {
  background-color: var(--scheme-bg, var(--color-light-alt));
}
/* ================================================================================
Contact Template
================================================================================ */
/* Template Contact  https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/contact.md
-------------------------------------------------------------------------------- */
/*
Note: 
This file is for Contact Page only overrides for the contact information
For Contact Page only overrides for the contact informatio, apply styles to templates/template-contact.scss -> #contact-page
For styles applied globally for the contact information, apply styles to layouts/layout-contact.scss
For Footer section only overrides for the contact informatio, apply styles to layout/layout-footer.scss -> .footer-contact styles section
-------------------------------------------------------------------------------- */
/*
* Contact Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* Contact Template
-------------------------------------------------------------------------------- */
@media only screen and (min-width: 75rem) {
  :is(.contact-page, #contact-page) .section-cluster-body {
    padding-inline: 3.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.contact-page, #contact-page) .section-cluster-body {
    padding-block: 5.25rem;
    padding-inline: 5rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.contact-page, #contact-page) {
    -webkit-padding-after: 0;
            padding-block-end: 0;
  }
  :is(.contact-page, #contact-page)::after {
    background: var(--color-dark-alt);
  }
}
:is(.contact-page, #contact-page) .contact-block:is(.contact-special) {
  justify-self: center;
}
@media only screen and (min-width: 75rem) {
  :is(.contact-page, #contact-page) .contact-blocks {
    grid-template-columns: auto 1fr;
    justify-content: space-between;
    -moz-column-gap: 2.5rem;
         column-gap: 2.5rem;
  }
  :is(.contact-page, #contact-page) .contact-block:is(.contact-number, .contact-numbers) {
    grid-column: -2;
    grid-row: 3/span 2;
  }
  :is(.contact-page, #contact-page) .contact-block:is(.contact-menudirs) {
    grid-column: -2;
    grid-row: 1/span 2;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.contact-page, #contact-page) .contact-block:is(.contact-special) {
    grid-column: 5.3125rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :is(.contact-page, #contact-page) .contact-blocks {
    inline-size: -webkit-max-content;
    inline-size: -moz-max-content;
    inline-size: max-content;
    max-inline-size: 100%;
    margin-inline: auto;
  }
}
:is(.contact-page, #contact-page) .contact-block:is(.contact-number, .contact-numbers) {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
}
:is(.contact-page, #contact-page) .contact-block.contact-number {
  /* Phone number - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: templates/template-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numberColumn / @Variation A: Separate blocks
  */
}
:is(.contact-page, #contact-page) .contact-block.contact-numbers {
  /*
  @Variation B: One block
  Requires PHP: templates/template-contact.php - @Variation B: One block
  Requires SCSS: scss/layotemplatesuts/_contact.scss - @numbersColumn / @Variation B: One block
  */
}
:is(.contact-page, #contact-page) .contact-block.contact-location {
  /* Location - Contact Block Grid */
  /*
  @Variation A: Separate blocks
  Requires PHP: layouts/layout-contact.php - @Variation A: Separate blocks
  Requires SCSS: scss/layouts/_contact.scss - @Variation A: Separate blocks
  */
}
:is(.contact-page, #contact-page) .contact-block.contact-locations {
  /* Locations - Contact Block Grid */
  /*
  @Variation B: One block
  Requires PHP: layouts/layout-contact.php - @Variation B: One block
  Requires SCSS: scss/layouts/_contact.scss - @Variation B: One block
  */
}
/* ================================================================================
* 404
================================================================================ */
/* Template 404 https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/404.md
-------------------------------------------------------------------------------- */
/*
* 404 Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* 404 Template
-------------------------------------------------------------------------------- */
:is(.error404-page, #error404-page) {
  text-align: center;
}
/* ================================================================================
* About Template
================================================================================ */
/* Template About
-------------------------------------------------------------------------------- */
/*
* About Related Classes
-------------------------------------------------------------------------------- */
@media only screen and (min-width: 87.5rem) {
  :where(.about-section) .section-container {
    --container-gutter: 3.75rem;
  }
}
@media only screen and (min-width: 120rem) {
  :where(.about-section) .section-container {
    --container-gutter: 17.5rem;
  }
}
/* Add helper classes specific to this template as needed */
/*
* About Template
-------------------------------------------------------------------------------- */
@media only screen and (min-width: 120rem) {
  :is(.about-page, #about-page) .section-container {
    --container-gutter: 17.5rem;
  }
}
@media only screen and (max-width: 47.9375rem) {
  :is(.about-page, #about-page) .section-cluster-image {
    min-block-size: 30.4375rem;
  }
}

/*
* About Section 1
-------------------------------------------------------------------------------- */
/*
* About Section 2
-------------------------------------------------------------------------------- */
:is(.about-section-2, #about-section-2) {
  background-color: var(--scheme-bg, var(--color-dark-alt));
  color: var(--scheme-fg, var(--color-light));
}
/*
* About Section 3
-------------------------------------------------------------------------------- */
/* ================================================================================
Coupons Template
================================================================================ */
/* Template Coupons - Grid
-------------------------------------------------------------------------------- */
/*
* Coupons Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* Coupons Template
-------------------------------------------------------------------------------- */
#coupons-page .coupons:is(.columns) {
  --columns-gap-x: 2.1875rem;
  --columns-gap-y: 2.1875rem;
}
#coupons-page .coupon {
  inline-size: 28.6875rem;
}
@media only screen and (min-width: 75rem) {
  #coupons-page .coupons:is(.columns) {
    --columns-number: 2;
  }
}
@media only screen and (min-width: 87.5rem) {
  #coupons-page .coupons:is(.columns) {
    --columns-number: 3;
  }
}
/* ================================================================================
FAQs Template
================================================================================ */
/* Template FAQs
-------------------------------------------------------------------------------- */
/*
* FAQs Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* FAQs Template
-------------------------------------------------------------------------------- */
:is(.faqs-page, #faqs-page) .list {
  max-inline-size: 52.1875rem;
  margin-inline: auto;
}
/* Template gallery https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/gallery.md
-------------------------------------------------------------------------------- */
/*
* gallery Template
-------------------------------------------------------------------------------- */
:is(.gallery-page, #gallery-page) .gallery:is(.columns) {
  --columns-gap-x: 4.375rem;
  --columns-gap-y: 4.375rem;
  place-content: center;
  place-items: start center;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  inline-size: 100%;
  margin-inline: auto;
}
.photo {
  inline-size: 43.75rem;
  overflow: clip;
  text-align: center;
  -webkit-padding-after: var(--columns-gap-y);
          padding-block-end: var(--columns-gap-y);
  -webkit-border-after: 1px solid var(--color-neutral);
          border-block-end: 1px solid var(--color-neutral);
}
.photo-columns {
  --columns-gap-x: 1.5rem;
  --columns-gap-y: 3rem;
}
.photo .cover {
  background: var(--color-dark-alt);
  --cover-aspect-w: 169;
  --cover-aspect-l: 225;
}
.photo-thumbnail:is(:hover, :focus) .photo-img {
  opacity: 0.4;
  border-radius: var(--global-radius);
}
.gallery-contain .photo-img > * {
  inline-size: 90% !important;
  block-size: 80% !important;
  -o-object-fit: cover !important;
  object-fit: contain !important;
  -o-object-position: center center !important;
     object-position: center center !important;
  margin: auto !important;
}
.photo-fullsize {
  margin-inline: auto;
  background: var(--color-light);
}
.photo-fullsize-img {
  display: flex;
  place-items: center;
  place-content: center;
  flex: 1 1;
  background: var(--scheme-bg);
}
.photo-fullsize img {
  flex: 1 1;
}
.photo-fullsize :is(.photo-fullsize-img, img) {
  max-height: -webkit-max-content;
  max-height: -moz-max-content;
  max-height: max-content;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  inline-size: 100%;
  height: 100%;
}
.photo-title {
  font-size: 1.75rem;
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
}
.popup-body .photo-title {
  text-align: center;
  -webkit-margin-before: 3.25rem;
          margin-block-start: 3.25rem;
}
.popup-body .photo-description {
  margin-block: 0.75rem 1.25rem;
  text-align: center;
  text-wrap: balance;
}

:is(.gallery-page, #gallery-page) .popup-body {
  text-align: center;
}
:is(.gallery-page, #gallery-page) .section-blocks-outer {
  row-gap: 6.75rem;
}
@media only screen and (min-width: 48rem) {
  .photo-columns {
    --columns-number: 2;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.gallery-page, #gallery-page) .section-blocks {
    --default-gap-y: 5rem;
  }
  :is(.gallery-page, #gallery-page) .section-blocks-outer {
    row-gap: 4.75rem;
  }
  :is(.gallery-page, #gallery-page) .section-body {
    order: 99;
    grid-column: 1/-1;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.gallery-page, #gallery-page) .gallery:is(.columns) {
    --columns-number: 2;
  }
  :is(.gallery-page, #gallery-page) .section-blocks-outer {
    row-gap: 3rem;
  }
}
/* ================================================================================
* Directory Grid Template
================================================================================ */
/* Template Menu Directories https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/menudirs.md
-------------------------------------------------------------------------------- */
/*
* Menu Directories Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* Menu Directories Grid Template
-------------------------------------------------------------------------------- */
:is(.menudirs-page, #menudirs-page) .menudir-menu:is(.columns) {
  --columns-gap-x: 4rem;
  justify-content: center;
  justify-items: center;
}
:is(.menudirs-page, #menudirs-page) .menudir:nth-last-child(n+2) {
  -webkit-border-after: 1px solid var(--color-neutral);
          border-block-end: 1px solid var(--color-neutral);
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  -webkit-padding-after: 2rem;
          padding-block-end: 2rem;
}
:is(.menudirs-page, #menudirs-page) .home-section-6 {
  border-radius: var(--global-radius-large);
}
:is(.menudirs-page, #menudirs-page) .home-section-6 .section-container {
  --container-gutter: var(--container-gutter);
}
:is(.menudirs-page, #menudirs-page) .section-blocks-outer {
  gap: 5.625rem;
}
@media only screen and (min-width: 48rem) {
  :is(.menudirs-page, #menudirs-page) .menudir-menu:is(.columns) {
    --columns-number: 2;
  }
  :is(.menudirs-page, #menudirs-page) .menudir-menu:nth-last-child(n+2) {
    -webkit-margin-after: 3.75rem;
            margin-block-end: 3.75rem;
    -webkit-padding-after: 3.75rem;
            padding-block-end: 3.75rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.menudirs-page, #menudirs-page) .menudir-menu:is(.columns) {
    --columns-number: 3;
  }
  :is(.menudirs-page, #menudirs-page) .menudir-menu li:nth-child(-n+3) {
    -webkit-border-before: 0;
            border-block-start: 0;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 {
    padding-block: 5.1875rem 5rem;
    inline-size: 70rem;
    justify-self: center;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-container {
    --container-gutter: var(--container-gutter);
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-blocks-feature, :is(.menudirs-page, #menudirs-page) .home-section-6 .section-blocks-outer {
    gap: 4.6875rem 4rem;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-feature-image {
    display: contents;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-feature-image-item {
    inline-size: 28.4375rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.menudirs-page, #menudirs-page) .home-section-6 {
    inline-size: 82rem;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-container {
    --container-gutter: 8.25rem;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.menudirs-page, #menudirs-page) .menudir-menu:is(.columns) {
    --columns-number: 4;
  }
  :is(.menudirs-page, #menudirs-page) .menudir-menu li:nth-child(-n+4) {
    -webkit-border-before: 0;
            border-block-start: 0;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 {
    inline-size: 87.5rem;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-container {
    --container-gutter: 11.25rem;
  }
  :is(.menudirs-page, #menudirs-page) .section-container {
    --container-gutter: 16.25rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :is(.menudirs-page, #menudirs-page) .home-section-6 {
    margin-inline: calc(var(--container-gutter) * -1);
    border-radius: 0;
    justify-self: center;
    inline-size: 100vi;
  }
  :is(.menudirs-page, #menudirs-page) .home-section-6 .section-container {
    --container-gutter: var(--container-gutter);
  }
}
/* ================================================================================
* Case Results Template
================================================================================ */
/* Template Results https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/results.md
-------------------------------------------------------------------------------- */
/*
* Results Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* Results Template
-------------------------------------------------------------------------------- */
:is(.results-page, #results-page) .results:is(.columns) {
  --columns-gap-x: 3rem;
  --columns-gap-y: 3rem;
  justify-content: center;
  justify-items: center;
}
:is(.results-page, #results-page) .result {
  -webkit-border-after: 1px solid var(--color-neutral-lighter);
          border-block-end: 1px solid var(--color-neutral-lighter);
  padding-inline: 2rem;
  padding-block: 0 var(--columns-gap-y);
  inline-size: 37.5rem;
}
:is(.results-page, #results-page) .result-pointer-reference:is(:hover, :focus, :focus-within) {
  /* background-color: var(--color-neutral-light); */
}
@media only screen and (min-width: 75rem) {
  :is(.results-page, #results-page) .results:is(.columns) {
    --columns-number: 2;
  }
}
@media only screen and (min-width: 87.5rem) {
  :is(.results-page, #results-page) .results:is(.columns) {
    --columns-number: 3;
  }
}
/* ================================================================================
* Profiles/ Team Grid Template
================================================================================ */
/* Template Team https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/team.md
-------------------------------------------------------------------------------- */
/*
* Team Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/* team groups */
.team-group:nth-child(n+2) {
  -webkit-margin-before: 4rem;
          margin-block-start: 4rem;
}
.team-group-title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
/*
* Team/Profiles Page
-------------------------------------------------------------------------------- */
:is(.team-page, #team-page) .profiles:is(.columns) {
  --columns-gap-x: 3rem;
  --columns-gap-y: 3rem;
  justify-content: center;
  justify-items: center;
}
:is(.team-page, #team-page) .profile {
  inline-size: 25rem;
}
@media only screen and (min-width: 48rem) {
  :is(.team-page, #team-page) .profiles:is(.columns) {
    --columns-number: 2;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.team-page, #team-page) .profiles:is(.columns) {
    --columns-number: 3;
  }
}
/* ================================================================================
* Testimonials Template
================================================================================ */
/* Template Testimonials Areas https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/testimonials.md
-------------------------------------------------------------------------------- */
/*
* Testimonials Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* Testimonials Template
-------------------------------------------------------------------------------- */
:is(.testimonials-page, #testimonials-page) .testimonials:is(.columns) {
  --columns-gap-x: 3.1875rem;
  --columns-gap-y: 3.1875rem;
  justify-content: center;
  justify-items: center;
}
.testimonials-featured {
  margin-inline: auto;
  max-inline-size: 100%;
}
.testimonials-featured :is(.swiper) {
  --swiper-custom-arrow-offset-x: max(33vi,var(--container-gutter));
  padding-block: var(--overlap-buffer);
  margin-block: calc(var(--overlap-buffer) * -1);
}
.testimonials-featured :is(.swiper) .swiper-slide {
  inline-size: 300px;
}
.testimonials-featured .testimonial {
  text-align: initial;
}
.testimonials-featured .testimonial-container {
  align-items: start;
  padding-inline: 0;
}
.testimonials-featured .testimonial-highlight {
  --clamp-text-cap: 3;
}
.testimonials-featured .testimonial-quote {
  --clamp-text-cap: 5;
}

:is(.testimonials-page, #testimonials-page) .testimonial {
  inline-size: 53.125rem;
  --fancy-background-elesi-width: 34.03125rem;
  --fancy-background-elesi-opacity: .25;
  --fancy-background-elesi-t: -6rem;
  --fancy-background-elesi-r: -3rem;
  --fancy-background-elesi-l: auto;
  padding-inline: var(--container-gutter);
  padding-block: 4.8125rem;
  border-radius: var(--global-radius);
}
@media only screen and (min-width: 48rem) {
  :is(.testimonials-page, #testimonials-page) .testimonial {
    padding-block: 4.6875rem;
    padding-inline: 4.95rem;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.testimonials-page, #testimonials-page) .testimonial {
    padding-block: 5.5625rem 8.25rem;
    padding-inline: 6.72rem;
  }
}
/* ================================================================================
* Videos Template
================================================================================ */
/* Template Videos https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/videos.md
-------------------------------------------------------------------------------- */
/*
* Videos Related Classes
-------------------------------------------------------------------------------- */
/* Add helper classes specific to this template as needed */
/*
* CustomRowName Template
-------------------------------------------------------------------------------- */
:is(.videos-page, #videos-page) .videos:is(.columns) {
  --columns-gap-x: 3rem;
  --columns-gap-y: 3rem;
  justify-content: center;
  justify-items: center;
  max-inline-size: -webkit-max-content;
  max-inline-size: -moz-max-content;
  max-inline-size: max-content;
  margin-inline: auto;
}
:is(.videos-page, #videos-page) .video {
  inline-size: 31.25rem;
}
@media only screen and (min-width: 48rem) {
  :is(.videos-page, #videos-page) .videos:is(.columns) {
    --columns-number: 2;
  }
}
@media only screen and (min-width: 75rem) {
  :is(.videos-page, #videos-page) .videos:is(.columns) {
    --columns-number: 3;
  }
}
/* ================================================================================
* Profile Detail Template
================================================================================ */
/* Template Profile Areas https://github.com/1point21interactive/1p21_wp_boilerplate/blob/master/wp-content/themes/1p21-boilerplate/docs/template/profile.md
-------------------------------------------------------------------------------- */
/*
* Profile Contact Info
-------------------------------------------------------------------------------- */
.profile-contact a:not(:hover, :focus) {
  color: inherit;
  text-decoration: none;
}
.profile-contact-list-item-label {
  -webkit-margin-end: 0.5em;
          margin-inline-end: 0.5em;
}
/*
* Profile Detail Template
-------------------------------------------------------------------------------- */
body.onep21-template-single-profile {
  --profile-image-offset: -4.375rem;
}
@media only screen and (min-width: 75rem) {
  body.onep21-template-single-profile {
    --profile-image-offset: 12.5rem;
    --profile-sidebar-offset: 0rem;
  }
}
@media only screen and (min-width: 87.5rem) {
  body.onep21-template-single-profile {
    --profile-image-offset: -6.875rem;
  }
}
/*
* Section Offset: For overlapping the section or parts of it to adjacent sections/layouts Feel free to copy/paste/comment out as needed. Find and replace `profile-section-1` to rename variables and sections appropriately
Example of usage: PQL36
-------------------------------------------------------------------------------- */
:root {
  --profile-section-1-offset: 6.25rem;
}
/*
* Section Offset Demo: Overlap this section and adjust it siblings and or the siblings' contents to it
	NOTE: To reuse on other elements, copy this css and replace `profile-section-1` with `profile-section-[DESIRED_NUMBER]`
	NOTE: Classes to use:
		.profile-section-1-offset-element => the element within the section that will have the negative margins to overlap itself
		.has-profile-section-1-offset => the adjacent sections/ child of adjacent sections that will have the pseudo element to adjust itself if the `profile-section-1-offset-element` is next to it
-------------------------------------------------------------------------------- */
.template-wrapper:has(:is(main, .main) > .profile-section-1) .has-profile-section-1-offset:is(.profile-section-1 + .profile-section:not(.profile-section-1),
.profile-section-1 + .profile-section:not(.profile-section-1) *) .profile-section-1:nth-last-child(n+2) {
  position: relative;
  z-index: 2;
}
.template-wrapper:has(:is(main, .main) > .profile-section-1) .has-profile-section-1-offset:is(.profile-section-1 + .profile-section:not(.profile-section-1),
.profile-section-1 + .profile-section:not(.profile-section-1) *) {
  isolation: isolate;
}
.template-wrapper:has(:is(main, .main) > .profile-section-1) .has-profile-section-1-offset:is(.profile-section-1 + .profile-section:not(.profile-section-1),
.profile-section-1 + .profile-section:not(.profile-section-1) *)::before {
  content: "";
  block-size: var(--profile-section-1-offset);
  -webkit-margin-before: min(var(--profile-section-1-offset) - var(--overlap-buffer), 0px);
          margin-block-start: min(var(--profile-section-1-offset) - var(--overlap-buffer), 0px);
  display: block;
  flex: 0 0 auto;
  inline-size: 100%;
}
.template-wrapper:has(:is(main, .main) > .profile-section-1) .profile-section-1:nth-last-child(n+2) {
  -webkit-padding-after: var(--overlap-buffer) !important;
          padding-block-end: var(--overlap-buffer) !important;
}
.template-wrapper:has(:is(main, .main) > .profile-section-1) .profile-section-1:nth-last-child(n+2) .profile-section-1-offset-element {
  -webkit-margin-after: calc((var(--profile-section-1-offset) + var(--overlap-buffer)) * -1) !important;
          margin-block-end: calc((var(--profile-section-1-offset) + var(--overlap-buffer)) * -1) !important;
}

:is(.single-profile-page, #single-profile-page):is(.profile-page-sections) {
  padding-block: 0;
}
:is(.single-profile-page, #single-profile-page):is(.profile-page-sections) :is(.profile-section-1) .profile-section-1-offset-element:is(.default-section-sidebar) {
  -webkit-padding-after: 0;
          padding-block-end: 0;
}
:is(.single-profile-page, #single-profile-page):is(.profile-page-full) {
  padding-block: 0;
}
:is(.single-profile-page, #single-profile-page) .section-blocks-header {
  gap: 1rem;
}
:is(.single-profile-page, #single-profile-page) .section-heading {
  max-inline-size: none;
}
:is(.single-profile-page, #single-profile-page) .section-divider {
  --fancy-border-margin-y: 2rem;
}
@media only screen and (min-width: 75rem) {
  :is(.single-profile-page, #single-profile-page):is(.profile-page-simple) .default-section-main:has(+ .default-section-sidebar:last-child) {
    -webkit-margin-after: 0;
            margin-block-end: 0;
  }
  :is(.single-profile-page, #single-profile-page):is(.profile-page-sections) :is(.profile-section-2) .has-profile-section-1-offset:is(.default-section-main)::before {
    content: none;
  }
}
@media only screen and (min-width: 120rem) {
  :is(.single-profile-page, #single-profile-page) .default-sections {
    --default-sidebar-width: 35rem;
    --default-gap-x: 7.5rem;
  }
}
@media only screen and (max-width: 74.9375rem) {
  :is(.single-profile-page, #single-profile-page):is(.profile-page-sections) :is(.profile-section-2) .has-profile-section-1-offset:is(.default-section-sidebar)::before {
    content: none;
  }
  :is(.single-profile-page, #single-profile-page) .section-image {
    max-inline-size: 100%;
    inline-size: 22.5rem;
    margin-inline: auto;
  }
  :is(.single-profile-page, #single-profile-page) .section-awards:not(.widget), :is(.single-profile-page, #single-profile-page) .section-header {
    text-align: center;
  }
}
.profile-section-1 {
  color: var(--scheme-fg, var(--color-light));
  background: var(--scheme-bg, var(--color-dark-alt));
}
@media only screen and (min-width: 75rem) {
  .profile-section-1 .default-section-sidebar {
    align-self: end;
  }
  .profile-section-1 .default-section-main {
    align-self: center;
  }
}
@media only screen and (max-width: 74.9375rem) {
  .profile-section-1 {
    text-align: center;
  }
}
@media only screen and (min-width: 75rem) {
  .profile-section-2 .section-lists {
    -webkit-padding-before: 0;
            padding-block-start: 0;
  }
}
