* {
  box-sizing: border-box;
}

body {
  color: var(--color-foreground);
  background: var(--color-background);
  display: flex;
  flex-direction: column;
  margin: 0;
  min-height: 100svh;
  font-variation-settings: 'slnt' 0;
}

:root {
  --hover-lift-amount: 4px;
  --hover-scale-amount: 1.03;
  --hover-subtle-zoom-amount: 1.015;
  --hover-shadow-color: var(--color-shadow);
  --hover-transition-duration: 0.25s;
  --hover-transition-timing: ease-out;
  --surface-transition-duration: 0.3s;
  --surface-transition-timing: var(--ease-out-quad);
}

html {
  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: rgb(var(--color-foreground-rgb) / var(--opacity-40)) var(--color-background);
  scroll-behavior: smooth;
}

html[scroll-lock] {
  overflow: hidden;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

img {
  width: 100%;
  height: auto;
}

input,
textarea,
select {
  font: inherit;
  border-radius: var(--style-border-radius-inputs);
}

input:hover {
  background-color: var(--color-input-hover-background);
}

/** override ios and firefox defaults */
select {
  background-color: var(--color-background);
  color: currentcolor;
}

.collection-card,
.featured-blog-posts-card {
  width: 100%;
  position: relative;
  height: 100%;
}

/* Editorial layout */
.resource-list:not(.hidden--desktop) .collection-card--flexible-aspect-ratio,
.resource-list:not(.hidden--desktop) .blog-post-card--flexible-aspect-ratio {
  .collection-card__image,
  .featured-blog-posts-card__image,
  .blog-placeholder-svg {
    aspect-ratio: 99;
    height: 100%;
  }

  .collection-card__inner,
  .featured-blog-posts-card__inner {
    display: flex;
    flex-direction: column;
    height: 100%;
  }

  .collection-card__content,
  .featured-blog-posts-card__content {
    flex-shrink: 0;
  }

  &:not(.collection-card--image-bg) .collection-card__content,
  .featured-blog-posts-card__content {
    height: auto;
  }
}

.collection-card__inner,
.featured-blog-posts-card__inner {
  width: 100%;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  z-index: var(--layer-flat);
  pointer-events: none;
}

.collection-card__content,
.featured-blog-posts-card__content {
  display: flex;
  position: relative;
  height: 100%;
  width: 100%;
  gap: var(--gap);
}

.collection-card__link,
.featured-blog-posts-card__link {
  position: absolute;
  inset: 0;

  /* allows focus outline to have radius in supported browsers */
  border-radius: var(--border-radius);
}

.product-card,
.collection-card,
.resource-card,
.predictive-search-results__card--product,
.predictive-search-results__card {
  position: relative;
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
  z-index: var(--layer-flat);
}

.product-card__link {
  position: absolute;
  inset: 0;
}

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

.product-card__content slideshow-component {
  --cursor: pointer;
}

.predictive-search-results__card .product-card,
.predictive-search-results__card .collection-card,
.predictive-search-results__card .resource-card {
  transition: none;
  will-change: auto;
}

@media (any-pointer: fine) and (prefers-reduced-motion: no-preference) {
  .card-hover-effect-lift .product-card:hover,
  .card-hover-effect-lift .collection-card:hover,
  .card-hover-effect-lift .resource-card:hover,
  .card-hover-effect-lift .predictive-search-results__card:hover {
    transform: translateY(calc(-1 * var(--hover-lift-amount)));
  }

  .card-hover-effect-lift .header .product-card:hover,
  .card-hover-effect-lift .header .collection-card:hover,
  .card-hover-effect-lift .header .resource-card:hover,
  .card-hover-effect-lift .header-drawer .product-card:hover,
  .card-hover-effect-lift .header-drawer .collection-card:hover,
  .card-hover-effect-lift .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-scale .product-card:hover,
  .card-hover-effect-scale .collection-card:hover,
  .card-hover-effect-scale .resource-card:hover,
  .card-hover-effect-scale .predictive-search-results__card:hover {
    transform: scale(var(--hover-scale-amount));
  }

  .card-hover-effect-scale .header .product-card:hover,
  .card-hover-effect-scale .header .collection-card:hover,
  .card-hover-effect-scale .header .resource-card:hover,
  .card-hover-effect-scale .header-drawer .product-card:hover,
  .card-hover-effect-scale .header-drawer .collection-card:hover,
  .card-hover-effect-scale .header-drawer .resource-card:hover {
    transform: none;
  }

  .card-hover-effect-subtle-zoom .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card__image {
    overflow: hidden;
    transition: transform var(--hover-transition-duration) var(--hover-transition-timing);
  }

  .predictive-search-results__card .card-gallery,
  .predictive-search-results__card .collection-card__image,
  .predictive-search-results__card .product-card__image,
  .predictive-search-results__card .resource-card__image {
    transition: none;
  }

  .card-hover-effect-subtle-zoom .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .predictive-search-results__card:hover {
    transform: scale(var(--hover-subtle-zoom-amount));
  }

  .card-hover-effect-subtle-zoom .header .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header .resource-card:hover .resource-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .card-gallery,
  .card-hover-effect-subtle-zoom .header-drawer .collection-card:hover .collection-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .product-card:hover .product-card__image,
  .card-hover-effect-subtle-zoom .header-drawer .resource-card:hover .resource-card__image {
    transform: none;
  }

  .predictive-search-results__card .product-card:hover,
  .predictive-search-results__card .collection-card:hover,
  .predictive-search-results__card .resource-card:hover,
  .header .product-card:hover,
  .header .collection-card:hover,
  .header .resource-card:hover,
  .header-drawer .product-card:hover,
  .header-drawer .collection-card:hover,
  .header-drawer .resource-card:hover {
    transform: none;
    box-shadow: none;
  }
}

dialog {
  /* the ::backdrop inherits from the originating element, custom properties must be set on the dialog element */
  --backdrop-color-rgb: var(--color-shadow-rgb);

  background-color: var(--color-background);
  color: var(--color-foreground);
}

p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}

.wrap-text {
  overflow-wrap: break-word;
  word-break: break-word;
  hyphens: auto;
}

p:empty {
  display: none;
}

:first-child:is(p, h1, h2, h3, h4, h5, h6),
:first-child:empty + :where(p, h1, h2, h3, h4, h5, h6) {
  margin-block-start: 0;
}

/* Remove bottom margin from last text item, or previous to last if the last is empty */
:last-child:is(p, h1, h2, h3, h4, h5, h6),
:where(p, h1, h2, h3, h4, h5, h6):nth-child(2):has(+ :last-child:empty) {
  margin-block-end: 0;
}

/* view transitions */
@media (prefers-reduced-motion: no-preference) {
  @view-transition {
    navigation: auto;
  }

  /* Keep page interactive while view transitions are running */
  :root {
    view-transition-name: none;
  }

  /* Have the root transition during page navigation */
  html:active-view-transition-type(page-navigation),
  html:active-view-transition-type(product-image-transition) {
    view-transition-name: root-custom;
  }

  ::view-transition {
    pointer-events: none;
  }

  html:active-view-transition-type(page-navigation) main[data-page-transition-enabled='true'] {
    view-transition-name: main-content;
  }

  html:active-view-transition-type(page-navigation) main[data-product-transition='true'][data-template*='product'] {
    view-transition-name: none;
  }

  ::view-transition-old(main-content) {
    animation: var(--view-transition-old-main-content);
  }

  ::view-transition-new(main-content) {
    animation: var(--view-transition-new-main-content);
  }

  html:active-view-transition-type(product-image-transition) {
    [data-view-transition-type='product-image-transition'] {
      view-transition-name: product-image-transition;
    }

    [data-view-transition-type='product-details'] {
      view-transition-name: product-details;
    }
  }

  ::view-transition-group(product-image-transition) {
    z-index: 1;
  }

  ::view-transition-group(product-image-transition),
  ::view-transition-group(product-details) {
    animation-duration: var(--animation-speed);
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-old(product-image-transition),
  ::view-transition-new(product-image-transition) {
    block-size: 100%;
    overflow: hidden;
    object-fit: cover;
    animation-duration: 0.25s;
    animation-timing-function: var(--animation-easing);
  }

  ::view-transition-new(product-details) {
    animation: var(--view-transition-new-main-content);
  }
}

/* Focus */
*:focus-visible {
  outline: var(--focus-outline-width) solid currentcolor;
  outline-offset: var(--focus-outline-offset);
}

@supports not selector(:focus-visible) {
  *:focus {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }
}

.focus-inset {
  outline-offset: calc(var(--focus-outline-width) * -1);
}

/* Layout */
.content-for-layout {
  flex: 1;
}

/* Set up page widths & margins */
.page-width-wide,
.page-width-normal,
.page-width-narrow,
.page-width-content {
  --page-margin: 16px;
}

@media screen and (min-width: 750px) {
  .page-width-wide,
  .page-width-normal,
  .page-width-narrow,
  .page-width-content {
    --page-margin: 40px;
  }
}

.page-width-wide {
  /* NOTE: This results in a page width of 2400px because of how we set up margins with grid */
  --page-content-width: var(--wide-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-normal {
  --page-content-width: var(--normal-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-narrow,
.page-width-content {
  /* NOTE: This results in a page width of 1400px because of how we set up margins with grid */
  --page-content-width: var(--narrow-page-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

.page-width-content {
  --page-content-width: var(--normal-content-width);
  --page-width: calc(var(--page-content-width) + (var(--page-margin) * 2));
}

/* Section width full vs. page
   The reason we use a grid to contain the section is to allow for the section to have a
   full-width background image even if the section content is constrained by the page width. Do not try
   to rewrite this to max-width: --page-width; margin: 0 auto;, it doesn't work. */
.section {
  --full-page-grid-central-column-width: min(
    var(--page-width) - var(--page-margin) * 2,
    calc(100% - var(--page-margin) * 2)
  );
  --full-page-grid-margin: minmax(var(--page-margin), 1fr);
  --full-page-grid-with-margins: var(--full-page-grid-margin) var(--full-page-grid-central-column-width)
    var(--full-page-grid-margin);

  /* Utility variable gives the grid's first column width. Provides an offset width for components like carousels */
  --util-page-margin-offset: max(
    var(--page-margin),
    calc((100% - min(var(--page-content-width), 100% - var(--page-margin) * 2)) / 2)
  );

  /* Offset for full-width sections to account for the page margin,
  used for Marquee — note that --util-page-margin-offset doesn't work here */
  --full-page-margin-inline-offset: calc(((100vw - var(--full-page-grid-central-column-width)) / 2) * -1);

  width: 100%;

  /* This is required to make background images work, which are <img> rendered absolutely */
  position: relative;

  /* Set up the grid */
  display: grid;
  grid-template-columns: var(--full-page-grid-with-margins);
  min-height: var(--section-min-height, 'auto');
}

/* Place all direct children in the center column by default */
.section > * {
  grid-column: 2;
}

/* Make the actual section background transparent, and instead apply it to a separate sibling element to enable stacking with hero shadow  */
.shopify-section:not(.header-section) :is(.section, .cart__summary-container) {
  background: transparent;
}

.shopify-section:not(.header-section):has(.section) {
  position: relative;
}

.shopify-section:not(.header-section) .section-background {
  content: '';
  position: absolute;
  inset: 0;
  z-index: var(--layer-section-background);
}

/* For page-width sections, all content goes in the center column */
.section--page-width > * {
  grid-column: 2;
}

/* For full-width sections, content spans all columns */
.section--full-width > * {
  grid-column: 1 / -1;
}

@media screen and (max-width: 749px) {
  .section--mobile-full-width > * {
    grid-column: 1 / -1;
  }
}

/* Some page-width sections should still extend all the way to the right edge of the page, e.g. collection carousel */
.section--page-width.section--full-width-right > * {
  grid-column: 2 / 4;
}

/* For full-width sections with margin, content still spans full width but with space on the sides */
.section--full-width.section--full-width-margin > * {
  grid-column: 1 / -1;

  @media screen and (min-width: 750px) {
    padding-left: var(--page-margin);
    padding-right: var(--page-margin);
  }
}

/* Some section content break out to full width of the page */
.section > .force-full-width {
  grid-column: 1 / -1;
}

.section--height-small {
  --section-min-height: var(--section-height-small);
}

.section--height-medium {
  --section-min-height: var(--section-height-medium);
}

.section--height-large {
  --section-min-height: var(--section-height-large);
}

.section--height-full-screen {
  --section-min-height: 100svh;
}

.section-content-wrapper.section-content-wrapper {
  min-height: calc(var(--section-min-height, 'auto') - var(--section-height-offset, 0px));
  position: relative;
  width: 100%;
  height: 100%;
}

/* Utility */

.hidden {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

@media screen and (max-width: 749px) {
  .hidden--mobile,
  .mobile\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

@media screen and (min-width: 750px) {
  .hidden--desktop,
  .desktop\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

.hide-when-empty:empty {
  /* stylelint-disable-next-line declaration-no-important */
  display: none !important;
}

.visually-hidden:not(:focus, :active) {
  /* stylelint-disable-next-line declaration-no-important */
  position: absolute !important;
  overflow: hidden;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

@media screen and (max-width: 749px) {
  .is-visually-hidden-mobile:not(:focus, :active) {
    /* stylelint-disable-next-line declaration-no-important */
    position: absolute !important;
    overflow: hidden;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    border: 0;
    clip: rect(0 0 0 0);
    /* stylelint-disable-next-line declaration-no-important */
    word-wrap: normal !important;
  }
}

.contents {
  display: contents;
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.grid {
  --centered-column-number: 12;
  --full-width-column-number: 14;
  --centered: column-1 / span var(--centered-column-number);
  --full-width: column-0 / span var(--full-width-column-number);

  display: flex;
  flex-direction: column;
}

@media screen and (min-width: 750px) {
  .grid {
    display: grid;
    gap: 0;
    grid-template-columns: var(--margin-4xl) repeat(var(--centered-column-number), minmax(0, 1fr)) var(--margin-4xl);
    grid-template-areas: 'column-0 column-1 column-2 column-3 column-4 column-5 column-6 column-7 column-8 column-9 column-10 column-11 column-12 column-13';
  }
}

@media screen and (min-width: 1400px) {
  .grid {
    grid-template-columns:
      1fr repeat(
        var(--centered-column-number),
        minmax(0, calc((var(--page-width) - var(--page-margin) * 2) / var(--centered-column-number)))
      )
      1fr;
  }
}

.flex {
  display: flex;
  gap: var(--gap-md);
}

.flip-x {
  scale: -1 1;
}

.flip-y {
  scale: 1 -1;
}

.list-unstyled {
  margin: 0;
  padding: 0;
  list-style: none;
}

.skip-to-content-link {
  position: absolute;
  overflow: hidden;
  height: 1px;
  left: -99999px;
  /* stylelint-disable-next-line declaration-no-important */
  word-wrap: normal !important;
}

.skip-to-content-link:focus {
  z-index: var(--layer-temporary);
  overflow: auto;
  width: auto;
  height: auto;
  padding: var(--padding-lg) var(--padding-4xl);
  left: var(--margin-lg);
  top: var(--margin-lg);
  background-color: var(--color-background);
  box-shadow: 0 0 0 var(--focus-outline-offset) var(--color-background);
}

.text-left {
  --text-align: left;

  text-align: left;
}

.text-center {
  --text-align: center;

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

.user-select-text {
  user-select: text;
}

.justify-left {
  justify-content: left;
}

.justify-center {
  justify-content: center;
}

.justify-right {
  justify-content: right;
}

.title--aligned-center {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.background-image-container {
  overflow: hidden;
  position: absolute;
  inset: 0;
  opacity: var(--image-opacity);
}

.background-image-container img,
.background-image-container svg {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.background-image-fit img,
.background-image-fit svg {
  object-fit: contain;
}

.svg-wrapper {
  color: currentcolor;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  pointer-events: none;
}

.svg-wrapper--smaller {
  width: var(--icon-size-2xs);
  height: var(--icon-size-2xs);
}

.svg-wrapper--small {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.svg-wrapper > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
}

.relative {
  position: relative;
}

/* Icons */
.icon-success,
.icon-error {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  flex-shrink: 0;
}

.icon-success {
  color: var(--color-success);
}

.icon-error {
  fill: var(--color-error);
}

.icon-default {
  fill: currentColor;
}

[data-placeholder='true'] * {
  cursor: default;
}

slideshow-component [data-placeholder='true'] * {
  cursor: grab;
}

/* Base text and heading styles */
body,
.paragraph:not(.button),
.paragraph > * {
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  text-transform: var(--font-paragraph--case);
  -webkit-font-smoothing: antialiased;
  color: var(--color, var(--color-foreground));
}

/* Ensure inputs with type presets maintain minimum 16px on mobile to prevent iOS zoom */
@media screen and (max-width: 1200px) {
  input.paragraph.paragraph,
  input.paragraph.paragraph:not([type]),
  textarea.paragraph.paragraph,
  select.paragraph.paragraph {
    font-size: max(1rem, var(--font-paragraph--size));
  }
}

.paragraph > small {
  font-size: smaller;
}

/* Typography presets */

h1,
.h1.h1,
.text-block.h1 > * {
  font-family: var(--font-h1--family);
  font-style: var(--font-h1--style);
  font-weight: var(--font-h1--weight);
  font-size: var(--font-h1--size);
  line-height: var(--font-h1--line-height);
  letter-spacing: var(--font-h1--letter-spacing);
  text-transform: var(--font-h1--case);
  color: var(--color, var(--font-h1-color));
}

@media screen and (max-width: 1200px) {
  input.h1.h1,
  textarea.h1.h1,
  select.h1.h1 {
    font-size: max(1rem, var(--font-h1--size));
  }
}

h2,
.h2.h2,
.text-block.h2 > * {
  font-family: var(--font-h2--family);
  font-style: var(--font-h2--style);
  font-weight: var(--font-h2--weight);
  font-size: var(--font-h2--size);
  line-height: var(--font-h2--line-height);
  letter-spacing: var(--font-h2--letter-spacing);
  text-transform: var(--font-h2--case);
  color: var(--color, var(--font-h2-color));
}

@media screen and (max-width: 1200px) {
  input.h2.h2,
  textarea.h2.h2,
  select.h2.h2 {
    font-size: max(1rem, var(--font-h2--size));
  }
}

h3,
.h3,
.h3.h3,
.text-block.h3 > * {
  font-family: var(--font-h3--family);
  font-style: var(--font-h3--style);
  font-weight: var(--font-h3--weight);
  font-size: var(--font-h3--size);
  line-height: var(--font-h3--line-height);
  letter-spacing: var(--font-h3--letter-spacing);
  text-transform: var(--font-h3--case);
  color: var(--color, var(--font-h3-color));
}

@media screen and (max-width: 1200px) {
  input.h3,
  textarea.h3,
  select.h3 {
    font-size: max(1rem, var(--font-h3--size));
  }
}

h4,
.h4.h4,
.text-block.h4 > * {
  font-family: var(--font-h4--family);
  font-style: var(--font-h4--style);
  font-weight: var(--font-h4--weight);
  font-size: var(--font-h4--size);
  line-height: var(--font-h4--line-height);
  letter-spacing: var(--font-h4--letter-spacing);
  text-transform: var(--font-h4--case);
  color: var(--color, var(--font-h4-color));
}

@media screen and (max-width: 1200px) {
  input.h4.h4,
  textarea.h4.h4,
  select.h4.h4 {
    font-size: max(1rem, var(--font-h4--size));
  }
}

h5,
.h5.h5,
.text-block.h5 > * {
  font-family: var(--font-h5--family);
  font-style: var(--font-h5--style);
  font-weight: var(--font-h5--weight);
  font-size: var(--font-h5--size);
  line-height: var(--font-h5--line-height);
  letter-spacing: var(--font-h5--letter-spacing);
  text-transform: var(--font-h5--case);
  color: var(--color, var(--font-h5-color));
}

@media screen and (max-width: 1200px) {
  input.h5.h5,
  textarea.h5.h5,
  select.h5.h5 {
    font-size: max(1rem, var(--font-h5--size));
  }
}

h6,
.h6.h6,
.text-block.h6 > * {
  font-family: var(--font-h6--family);
  font-style: var(--font-h6--style);
  font-weight: var(--font-h6--weight);
  font-size: var(--font-h6--size);
  line-height: var(--font-h6--line-height);
  letter-spacing: var(--font-h6--letter-spacing);
  text-transform: var(--font-h6--case);
  color: var(--color, var(--font-h6-color));
}

@media screen and (max-width: 1200px) {
  input.h6.h6,
  textarea.h6.h6,
  select.h6.h6 {
    font-size: max(1rem, var(--font-h6--size));
  }
}

:first-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-start: 0;
}

:last-child:is(.h1, .h2, .h3, .h4, .h5, .h6) {
  margin-block-end: 0;
}

/* Links */
a {
  --button-color: var(--color, var(--color-primary));

  color: var(--button-color);
  text-decoration-color: transparent;
  text-decoration-thickness: 0.075em;
  text-underline-offset: 0.125em;
  transition: text-decoration-color var(--animation-speed) var(--animation-easing),
    color var(--animation-speed) var(--animation-easing);
}

:is(h1, h2, h3, h4, h5, h6, p) > a:hover {
  --button-color: var(--color, var(--color-primary-hover));
}

/* Add underline to text using our paragraph styles only. */
p:not(.h1, .h2, .h3, .h4, .h5, .h6) a:where(:not(.button, .button-primary, .button-secondary)),
.rte
  :is(p, ul, ol, table):not(.h1, .h2, .h3, .h4, .h5, .h6)
  a:where(:not(.button, .button-primary, .button-secondary)) {
  text-decoration-color: currentcolor;

  &:hover {
    text-decoration-color: transparent;
    color: var(--color-primary-hover);
  }
}

.container-background-image {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}

details[open] .summary-closed {
  display: none;
}

details:not([open]) .summary-open {
  display: none;
}

details[open] > summary .icon-animated > svg {
  transform: rotate(180deg);
}

/* iOS fix: hide the default arrow on the summary */
summary::-webkit-details-marker {
  display: none;
}

/* When header is transparent, pull the first main content section up to sit under the floating header */
body:has(.header[transparent]) .content-for-layout > .shopify-section:first-child {
  margin-top: calc(var(--header-group-height) * -1);
}

body:has(.header[transparent]) #header-group > .header-section {
  z-index: var(--layer-sticky);
}

/* All other header group content should be beneath the floating header,
but above the rest of the page content */
body:has(.header[transparent]) #header-group > *:not(.header-section) {
  z-index: calc(var(--layer-sticky) - 1);
}

/* Featured collection block */
.featured-collection-block {
  width: 100%;
}

/* Product grid */
.product-grid-container {
  display: block;
  width: 100%;
  padding-block: var(--padding-block-start) var(--padding-block-end);

  @media screen and (min-width: 750px) {
    display: grid;
  }
}

.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--product-grid-gap);
  margin: auto;
  padding: 0;
  list-style: none;
}

@media screen and (min-width: 750px) {
  .product-grid {
    grid-template-columns: var(--product-grid-columns-desktop);
  }
}

.product-grid :is(h3, p) {
  margin: 0;
}

.product-grid__item {
  border: var(--product-card-border-width) solid rgb(var(--color-border-rgb) / var(--product-card-border-opacity));
}

.product-grid--organic[product-grid-view='default'] .product-grid__item {
  height: fit-content;
}

.product-grid__card.product-grid__card {
  display: flex;
  flex-flow: column nowrap;
  gap: var(--product-card-gap);
  align-items: var(--product-card-alignment);
  text-decoration: none;
  color: var(--color, var(--color-foreground));
  padding-block: var(--padding-block-start) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  overflow: hidden;
}

[product-grid-view='zoom-out'] .product-grid__card {
  row-gap: var(--padding-xs);
}

[product-grid-view='default'] {
  --product-grid-gap: 16px;
  --padding-block-start: 24px;
  --padding-block-end: 24px;
  --padding-inline-start: 0px;
  --padding-inline-end: 0px;
}

[product-grid-view='default'] .product-grid__item {
  padding-block: 0;
}

[product-grid-view='mobile-single'],
.product-grid-mobile--large {
  @media screen and (max-width: 749px) {
    grid-template-columns: 1fr;
  }
}

.product-grid__card .group-block > * {
  @media screen and (max-width: 749px) {
    flex-direction: column;
  }
}

ul[product-grid-view='zoom-out'] .product-grid__card > * {
  display: none;
}

ul[product-grid-view='zoom-out'] .product-grid__card .card-gallery {
  display: block;
}

[product-grid-view='zoom-out']
  .card-gallery
  > :is(quick-add-component, .product-badges, slideshow-component > slideshow-controls) {
  display: none;
}

ul[product-grid-view='zoom-out'] .card-gallery > img {
  display: block;
}

[product-grid-view='zoom-out'] {
  --product-grid-columns-desktop: repeat(
    10,
    minmax(clamp(50px, calc(100% - 9 * var(--product-grid-gap)) / 10, 80px), 1fr)
  );
}

.product-grid-view-zoom-out--details {
  display: none;
}

.product-grid-view-zoom-out--details .h4,
.product-grid-view-zoom-out--details span,
.product-grid-view-zoom-out--details s {
  font-size: var(--font-size--xs);
  font-family: var(--font-paragraph--family);
}

.product-grid-view-zoom-out--details span {
  font-weight: 500;
}

.product-grid-view-zoom-out--details .h4 {
  line-height: 1.3;
  font-weight: 400;
}

.product-grid-view-zoom-out--details > span.h6,
.product-grid-view-zoom-out--details > div.h6 > product-price {
  display: inline-block;
  line-height: 0;
  margin-top: var(--margin-2xs);
}

.product-grid-view-zoom-out--details > span.h6 > *,
.product-grid-view-zoom-out--details > div.h6 > * > * {
  line-height: 1.2;
}

@media (prefers-reduced-motion: no-preference) {
  :root:active-view-transition-type(product-grid) {
    details[open] floating-panel-component {
      view-transition-name: panel-content;

      .checkbox *,
      .facets__pill-label {
        transition: none;
      }

      .facets--vertical & {
        view-transition-name: none;
      }
    }

    .product-grid {
      view-transition-name: product-grid;
    }

    footer {
      view-transition-name: footer;
    }

    .product-grid__item,
    floating-panel-component {
      transition: none;
    }
  }
}

::view-transition-group(panel-content) {
  z-index: 1;
}

::view-transition-new(product-grid) {
  animation-delay: 150ms;
  animation-name: fadeInUp;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
}

results-list[initialized] {
  .product-grid__item {
    transition: opacity var(--animation-speed) var(--animation-easing),
      transform var(--animation-speed) var(--animation-easing);

    @starting-style {
      opacity: 0;
      transform: translateY(10px);
    }
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Collection and product list cards have equal heights */
:is(.product-grid__item, .resource-list__item) .product-card {
  display: grid;
  height: 100%;
}

/* Video background */
.video-background,
.video-background * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.video-background--cover * {
  object-fit: cover;
}

.video-background--contain * {
  object-fit: contain;
}

.text-block {
  width: 100%;
}

.text-block > *:first-child,
.text-block > *:first-child:empty + * {
  margin-block-start: 0;
}

.text-block > *:last-child,
.text-block > *:has(+ *:last-child:empty) {
  margin-block-end: 0;
}

/* This is to deal with the margin applied to the p when custom styles are enabled. The p isn't the first child anymore due to the style tag */
.text-block > style + * {
  margin-block-start: 0;
}

/* Dialog */
.dialog-modal {
  border: none;
  box-shadow: var(--shadow-popover);

  @media screen and (min-width: 750px) {
    border-radius: var(--style-border-radius-popover);
    max-width: var(--normal-content-width);
  }

  @media screen and (max-width: 749px) {
    max-width: 100%;
    max-height: 100%;
    height: 100dvh;
    width: 100dvw;
    padding: var(--padding-md);
  }
}

.dialog-modal::backdrop {
  transition: backdrop-filter var(--animation-speed) var(--animation-easing);
  backdrop-filter: brightness(1);
  background: rgb(var(--backdrop-color-rgb) / var(--backdrop-opacity));
}

.dialog-modal[open] {
  animation: elementSlideInTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    animation: backdropFilter var(--animation-speed) var(--animation-easing) forwards;
    transition: opacity var(--animation-speed) var(--animation-easing);
  }
}

.dialog-modal.dialog-closing {
  animation: elementSlideOutTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    opacity: 0;
  }
}

/* stylelint-disable value-keyword-case */
.dialog-drawer {
  --dialog-drawer-opening-animation: move-and-fade;
  --dialog-drawer-closing-animation: move-and-fade;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: move-and-fade;
  --dialog-drawer-closing-animation: move-and-fade;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  --start-x: var(--custom-transform-from, 100%);
  --end-x: var(--custom-transform-to, 0px);
  --start-opacity: 1;

  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

.dialog-drawer[open].dialog-closing {
  --start-x: 0px;
  --end-x: 100%;
  --start-opacity: 1;
  --end-opacity: 1;

  animation: var(--dialog-drawer-closing-animation) var(--animation-speed) var(--animation-easing);
}

.dialog-drawer--right[open] {
  --start-x: -100%;
  --start-opacity: 1;
}

.dialog-drawer--right[open].dialog-closing {
  --start-x: 0px;
  --end-x: -100%;
  --start-opacity: 1;
  --end-opacity: 1;

  animation: var(--dialog-drawer-closing-animation) var(--animation-speed) var(--animation-easing);
}

/* Buttons */
.button,
.button-secondary,
button.shopify-payment-button__button--unbranded {
  --text-align: center;

  display: grid;
  align-content: center;
  text-decoration: none;
  text-align: var(--text-align);
  color: var(--button-color);
  appearance: none;
  background-color: var(--button-background-color);
  border: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
  line-height: var(--font-paragraph--line-height);
  margin-block: 0;
  transition: color var(--animation-speed) var(--animation-easing),
    box-shadow var(--animation-speed) var(--animation-easing),
    background-color var(--animation-speed) var(--animation-easing);
  cursor: pointer;
  width: fit-content;
  box-shadow: inset 0 0 0 var(--button-border-width) var(--button-border-color);
  padding-block: var(--button-padding-block);
  padding-inline: var(--button-padding-inline);
}

.button {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
  border-radius: var(--style-border-radius-buttons-primary);
}

.button:not(.button-secondary, .button-unstyled) {
  outline-color: var(--button-background-color);
}

.button-secondary {
  font-family: var(--button-font-family-secondary);
  text-transform: var(--button-text-case-secondary);
  border-radius: var(--style-border-radius-buttons-secondary);
}

button.shopify-payment-button__button--unbranded {
  font-family: var(--button-font-family-primary);
  text-transform: var(--button-text-case-primary);
}

textarea,
input {
  background-color: var(--color-input-background);
  border-color: var(--color-input-border);
}

textarea::placeholder,
input::placeholder {
  color: var(--color-input-text);
}

textarea:not(:placeholder-shown)::placeholder,
input:not(:placeholder-shown)::placeholder {
  opacity: 0;
}

/* The declaration above is messing with buttons that have an attribute of hidden as it overwrites the display value */
.button[hidden] {
  display: none;
}

.button[aria-disabled='true'],
.button-secondary[aria-disabled='true'],
.button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.button,
button.shopify-payment-button__button--unbranded {
  --button-color: var(--color-primary-button-text);
  --button-background-color: var(--color-primary-button-background);
  --button-border-color: var(--color-primary-button-border);
  --button-border-width: var(--style-border-width-primary);
}

.button:hover,
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  --button-color: var(--color-primary-button-hover-text);
  --button-background-color: var(--color-primary-button-hover-background);
  --button-border-color: var(--color-primary-button-hover-border);
}

.button-secondary {
  --button-color: var(--color-secondary-button-text);
  --button-background-color: var(--color-secondary-button-background);
  --button-border-color: var(--color-secondary-button-border);
  --button-border-width: var(--style-border-width-secondary);
}

.button-secondary:hover {
  --button-color: var(--color-secondary-button-hover-text);
  --button-background-color: var(--color-secondary-button-hover-background);
  --button-border-color: var(--color-secondary-button-hover-border);
}

/* Needed to override the default Shopify styles */
button.shopify-payment-button__button--unbranded:hover:not([disabled]) {
  background-color: var(--button-background-color);
}

.button-unstyled {
  display: block;
  padding: 0;
  background-color: inherit;
  color: inherit;
  border: 0;
  border-radius: 0;
  overflow: hidden;
  box-shadow: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-size: var(--font-paragraph--size);
}

.button-unstyled:hover {
  background-color: inherit;
}

.button-unstyled--with-icon {
  color: var(--color-foreground);
  display: flex;
  gap: var(--gap-2xs);
  align-items: center;
}

.button-unstyled--transparent {
  background-color: transparent;
  box-shadow: none;
}

/* Show more */

.show-more__button {
  color: var(--color-primary);
  cursor: pointer;
}

.show-more__button:hover {
  @media screen and (min-width: 750px) {
    color: var(--color-primary-hover);
  }
}

.show-more__label {
  text-align: start;
  font-size: var(--font-size--body-md);
  font-family: var(--font-paragraph--family);
}

.show-more__button .svg-wrapper {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

.show-more[data-expanded='true'] .show-more__label--more,
.show-more[data-expanded='false'] .show-more__label--less {
  display: none;
}

.link {
  display: inline-block;
  text-align: center;
}

shopify-accelerated-checkout,
shopify-accelerated-checkout-cart {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-primary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

.product-form-buttons:has(.add-to-cart-button.button-secondary)
  :is(shopify-accelerated-checkout, shopify-accelerated-checkout-cart) {
  --shopify-accelerated-checkout-button-border-radius: var(--style-border-radius-buttons-secondary);
  --shopify-accelerated-checkout-button-block-size: var(--height-buy-buttons);
}

/* Collapsible row */

.icon-caret svg {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.icon-caret--forward svg {
  transform: rotate(-90deg);
}

.icon-caret--backward svg {
  transform: rotate(90deg);
}

summary {
  display: flex;
  align-items: center;
  cursor: pointer;
  list-style: none;
  padding-block: var(--padding-sm);
}

summary:hover {
  color: var(--color-primary-hover);
}

summary .svg-wrapper {
  margin-inline-start: auto;
  height: var(--icon-size-xs);
  width: var(--icon-size-xs);
  transition: transform var(--animation-speed) var(--animation-easing);
}

/* Shared plus/minus icon animations */
summary .icon-plus :is(.horizontal, .vertical),
.show-more__button .icon-plus :is(.horizontal, .vertical) {
  transition: transform var(--animation-speed) var(--animation-easing);
  transform: rotate(0deg);
  transform-origin: 50% 50%;
  opacity: 1;
}

details[open] > summary .icon-plus .horizontal,
.details-open > summary .icon-plus .horizontal,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .horizontal {
  transform: rotate(90deg);
}

details[open] > summary .icon-plus .vertical,
.details-open > summary .icon-plus .vertical,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .vertical {
  transform: rotate(90deg);
  opacity: 0;
}

/* Product Media */
media-gallery {
  display: block;
  width: 100%;
}

:where(media-gallery, .product-grid__item) {
  .media-gallery__grid {
    grid-template-columns: 1fr;
    gap: var(--image-gap);
  }
}

.product-media-gallery__slideshow--single-media slideshow-container {
  @media screen and (max-width: 749px) {
    grid-area: unset;
  }
}

:not(.dialog-zoomed-gallery) > .product-media-container {
  /* width and overflow forces children to shrink to parent width */
  --slide-width: round(up, 100%, 1px);

  display: flex;
  aspect-ratio: var(--gallery-aspect-ratio, var(--media-preview-ratio));
  max-height: var(--constrained-height);
  width: 100%;

  /* Relative position needed for video and 3d models */
  position: relative;
  overflow: hidden;

  &:where(.constrain-height) {
    /* arbitrary offset value based on average theme spacing and header height */
    --viewport-offset: 400px;
    --constrained-min-height: 300px;
    --constrained-height: max(var(--constrained-min-height), calc(100vh - var(--viewport-offset)));

    margin-right: auto;
    margin-left: auto;
  }
}

media-gallery:where(.media-gallery--grid) .media-gallery__grid {
  display: none;
}

media-gallery.media-gallery--grid .media-gallery__grid .product-media-container {
  /* Needed for safari to stretch to full grid height */
  height: 100%;
}

.product-media :is(deferred-media, product-model) {
  position: absolute;
}

@media screen and (max-width: 749px) {
  .product-media-container.constrain-height {
    max-height: none;
  }
}

@media screen and (min-width: 750px) {
  .product-media-container.constrain-height {
    --viewport-offset: var(--header-height, 100px);
    --constrained-min-height: 500px;
  }

  body:has(header-component[transparent]) .product-media-container.constrain-height {
    --viewport-offset: 0px;
  }

  .media-gallery--two-column .media-gallery__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .media-gallery--large-first-image .product-media-container:first-child,
  .media-gallery--two-column .product-media-container:only-child {
    /* First child spans 2 columns */
    grid-column: span 2;
  }

  /* Display grid view as a carousel on mobile, grid on desktop */
  media-gallery:is(.media-gallery--grid) slideshow-component {
    display: none;
  }

  media-gallery:where(.media-gallery--grid) .media-gallery__grid {
    display: grid;
  }
}

.product-media-container--model {
  /* Usefull when view in your space is shown */
  flex-direction: column;
}

.shopify-model-viewer-ui__controls-area {
  bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
}

.product-media-container img {
  aspect-ratio: inherit;
  object-fit: contain;
}

.product-media-container.media-fit-contain img {
  object-position: center center;
}

.product-media-container.media-fit {
  --product-media-fit: cover;

  img {
    object-fit: var(--product-media-fit);
  }
}

/* Media gallery zoom dialog */
.product-media-container__zoom-button {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: var(--layer-flat);
  cursor: zoom-in;
  background-color: transparent;

  &:hover {
    background-color: transparent;
  }
}

zoom-dialog dialog {
  width: 100vw;
  height: 100vh;
  border: none;
  margin: 0;
  padding: 0;
  max-width: 100%;
  max-height: 100%;
  background: #fff;
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
  scrollbar-width: none;

  &[open] {
    opacity: 1;
  }

  @media (prefers-reduced-motion: no-preference) {
    scroll-behavior: smooth;
  }

  &::backdrop {
    background: transparent;
  }
}

/* Animate the UI elements in only after the view transition is complete */
.close-button {
  position: fixed;
  top: var(--margin-lg);
  right: var(--margin-lg);
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  z-index: var(--layer-flat);
  background-color: transparent;
  display: flex;
  align-items: center;
  justify-content: center;

  /* For the outline radius */
  border-radius: 50%;
}

/* This triggers iOS < 16.4. The outline bug is not recognized as a lack of @supports */

@supports not (background-color: rgb(from red 150 g b / alpha)) {
  /**
    There is a bug in safari < 16.4 that causes the outline to not follow the elements border radius. This is a workaround.
    Using element selector to increase specificity.
  **/

  .close-button:focus-visible {
    outline: none;
    overflow: visible;
  }

  .close-button:focus-visible::after {
    content: '';
    position: absolute;
    inset: calc(-1 * var(--focus-outline-offset));
    border: var(--focus-outline-width) solid currentColor;
    border-radius: 50%;
    display: inherit;
  }
}

.dialog--closed .close-button {
  animation: elementSlideOutBottom calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
}

.dialog-thumbnails-list-container {
  position: fixed;
  width: 100%;
  bottom: 0;
  display: flex;
  z-index: var(--layer-raised);
}

.dialog-thumbnails-list {
  position: relative;
  display: inline-flex;
  flex-direction: row;
  gap: 8px;
  bottom: 0;
  overflow-x: auto;
  opacity: 0;
  padding: var(--padding-lg);
  margin-inline: auto;
  scrollbar-width: none;
  animation: thumbnailsSlideInBottom calc(var(--animation-speed) * 0.75) var(--animation-easing) forwards;
  animation-delay: calc(var(--animation-speed) * 1.5);
}

.dialog--closed .dialog-thumbnails-list {
  animation: thumbnailsSlideOutBottom var(--animation-speed) var(--animation-easing) forwards;
}

@media screen and (min-width: 750px) {
  .dialog-thumbnails-list {
    position: fixed;
    flex-direction: column;
    inset: 50% var(--margin-lg) auto auto;
    right: 0;
    max-height: calc(100vh - 200px);
    overflow-y: auto;
    animation: thumbnailsSlideInTop calc(var(--animation-speed) * 0.5) var(--animation-easing) forwards;
    animation-delay: calc(var(--animation-speed) * 2);
  }

  .dialog--closed .dialog-thumbnails-list {
    animation: thumbnailsSlideOutTop var(--animation-speed) var(--animation-easing) forwards;
  }
}

.dialog-thumbnails-list__thumbnail {
  width: var(--thumbnail-width);
  height: auto;
  transition: transform var(--animation-speed) var(--animation-easing);
  flex-shrink: 0;
  border-radius: var(--media-radius);

  img {
    height: 100%;
    object-fit: cover;
    border-radius: var(--media-radius);
    aspect-ratio: var(--aspect-ratio);
  }

  &:is([aria-selected='true']) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: calc(var(--focus-outline-offset) / 2);
    border: var(--style-border-width) solid rgb(var(--color-border-rgb) / var(--media-border-opacity));
  }
}

.close-button:hover {
  background-color: transparent;
  opacity: 0.8;
}

.close-button svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

/* Product media */
.product-media {
  display: flex;
  flex: 1;
}

/* If the product media is already providing an image cover, hide images provided by sibling deferred-media */
.product-media__image ~ * .deferred-media__poster-image {
  display: none;
}

/* If the product media is playing, hide the preview image */
.product-media-container:has(.deferred-media__playing) .product-media__image {
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
}

/* Deferred media & Product model  */
:is(product-model, deferred-media) {
  /* Height needed to make sure when it's set to be stretched, it takes the full height */
  height: 100%;
  width: 100%;
  position: relative;
}

product-model model-viewer,
/* Media that have a poster button sibling providing the size should be absolute-positioned.
Otherwise, it should be a block to rely on its own size */
:is(deferred-media, product-model) > .deferred-media__poster-button ~ *:not(template) {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;

  /* Required to make sure the absolute position respects the padding of the wrapper: */
  padding: inherit;
}

slideshow-slide .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  bottom: var(--padding-sm);
  right: var(--padding-sm);
}

.dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
  /* Move the controls above the thumbnails. Need to calculate the height of the thumbnails list */
  bottom: calc(var(--thumbnail-width) / var(--media-preview-ratio) + var(--padding-lg) * 2);
  right: var(--padding-lg);
}

@media screen and (max-width: 749px) {
  slideshow-component:has(:not(.mobile\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }
}

@media screen and (min-width: 750px) {
  slideshow-component:has(:not(.desktop\:hidden) :is(.slideshow-controls__dots, .slideshow-controls__counter))
    .shopify-model-viewer-ui__controls-area {
    /* Position the controls just above the counter */
    bottom: calc(var(--minimum-touch-target) + var(--padding-sm));
  }

  .dialog-zoomed-gallery .shopify-model-viewer-ui__controls-area.shopify-model-viewer-ui__controls-area {
    /* Move the controls up to match the padding on the thumbnails */
    bottom: var(--padding-lg);

    /* Move the controls to the left of the thumbnails list on the right */
    right: calc(var(--thumbnail-width) + var(--padding-lg) * 2);
  }
}

:is(deferred-media, .video-placeholder-wrapper).border-style {
  /* Apply the border radius to the video */
  overflow: hidden;
}

deferred-media {
  /* The overflow hidden in the deferred-media won't let the button show the focus ring */
  &:has(:focus-visible) {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  @supports not selector(:focus-visible) {
    &:has(:focus) {
      outline: var(--focus-outline-width) solid currentcolor;
      outline-offset: var(--focus-outline-offset);
    }
  }
}

.deferred-media__poster-button {
  width: 100%;
  height: 100%;
  aspect-ratio: var(--video-aspect-ratio, auto);
}

.deferred-media__poster-button.deferred-media__playing {
  opacity: 0;
  transition: opacity 0.3s ease;
}

deferred-media img {
  height: 100%;
  object-fit: cover;
  transition: opacity 0.3s ease;
}

deferred-media iframe {
  width: 100%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

deferred-media[data-media-loaded] img {
  opacity: 0;
}

.deferred-media__poster-icon,
.video-placeholder-wrapper__poster-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.deferred-media__poster-icon svg,
.video-placeholder-wrapper__poster-icon svg {
  width: var(--button-size);
  height: var(--button-size);
  color: var(--color-white);
  filter: drop-shadow(var(--shadow-button));

  &:hover {
    color: rgb(var(--color-white-rgb) / var(--opacity-80));
  }

  @media screen and (min-width: 750px) {
    width: 4rem;
    height: 4rem;
  }
}

deferred-media[class] :is(.deferred-media__poster-button img, .deferred-media__poster-button ~ video) {
  /* only apply this on the video block not product media */
  object-fit: cover;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

.button-shopify-xr {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: var(--padding-md);
}

.button-shopify-xr > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  margin-inline-end: var(--margin-md);
}

.button-shopify-xr[data-shopify-xr-hidden] {
  display: none;
}

/* Swatches */
.swatch {
  --color-border: rgb(var(--color-foreground-rgb) / var(--style-border-swatch-opacity));
  --min-width-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height-unitless: 15.9999; /* want to avoid division by 0 */
  --min-height: 16px;
  --min-width: 16px;

  /* mobile values */
  --scaling-factor: 0.5;
  --max-swatch-size: 28px;
  --max-pill-size: 20px;
  --max-filter-size: 32px;

  /* From the settings */
  --offset-swatch-width: calc(var(--variant-picker-swatch-width-unitless) - var(--min-width-unitless));
  --offset-swatch-height: calc(var(--variant-picker-swatch-height-unitless) - var(--min-height-unitless));

  /**
    Offset values are obtained from the following formulas:
      offset-width = width - min-width
      offset-height = height - min-height

    The offset-scaled-width and heigth are obtained by extending the line from
    [min,min] to [W,H] and taking the intersection with a square that starts at
    [min,min] and ends at [max,max].

    The extending line forms right angle triangles with the [min,min]->[max,max]
    box that enable us to derive the following formulas

    We also want the result to always be smaller than the input (pdp > everywhere else)
    by some scaling factor.
  */
  --offset-scaled-width: calc(
    var(--scaling-factor) * var(--offset-swatch-width) / var(--offset-swatch-height) * var(--offset-max-swatch-size)
  );
  --offset-scaled-height: calc(
    var(--scaling-factor) * var(--offset-swatch-height) / var(--offset-swatch-width) * var(--offset-max-swatch-size)
  );
  --offset-max-swatch-size: calc(var(--max-swatch-size) - var(--min-width));

  /* width = min(m + sU, (m + s * W'/H' * M'), M) */
  --swatch-width: min(
    calc(var(--min-width) + var(--scaling-factor) * var(--offset-swatch-width) * 1px),
    calc(var(--min-width) + var(--offset-scaled-width)),
    var(--max-swatch-size)
  );

  /* height = min(m + sV, (m + s * H'/W' * M'), M) */
  --swatch-height: min(
    calc(var(--min-height) + var(--scaling-factor) * var(--offset-swatch-height) * 1px),
    calc(var(--min-height) + var(--offset-scaled-height)),
    var(--max-swatch-size)
  );

  display: block;
  background: var(--swatch-background);
  background-position: var(--swatch-focal-point, center);
  border-radius: var(--variant-picker-swatch-radius);
  border: var(--style-border-swatch-width) var(--style-border-swatch-style) var(--color-border);
  width: var(--swatch-width);
  height: var(--swatch-height);

  /* This is different than `background-size: cover` because we use `box-sizing: border-box`,
   * doing it like makes the background clip under the border without repeating.
   */
  background-size: var(--swatch-width) var(--swatch-height);

  &.swatch--unavailable {
    border-style: dashed;
  }

  &.swatch--unscaled {
    /* for when you want fixed sizing (e.g. pdp) */
    --swatch-width: var(--variant-picker-swatch-width);
    --swatch-height: var(--variant-picker-swatch-height);
  }

  &.swatch--filter {
    --swatch-width: var(--max-filter-size);
    --swatch-height: var(--max-filter-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  &.swatch--pill {
    --swatch-width: var(--max-pill-size);
    --swatch-height: var(--max-pill-size);

    border-radius: var(--variant-picker-swatch-radius);
  }

  /* swatches in filters and pills always have a border  */
  &.swatch--filter,
  &.swatch--pill {
    --style-border-swatch-width: var(--variant-picker-border-width);
    --style-border-swatch-style: var(--variant-picker-border-style);
    --color-border: rgb(var(--color-foreground-rgb) / var(--variant-picker-border-opacity));
  }

  &.swatch--variant-image {
    background-size: cover;
  }

  @media screen and (min-width: 750px) {
    /* desktop values */
    --max-swatch-size: 32px;
    --max-pill-size: 16px;
    --max-filter-size: 28px;
    --scaling-factor: 0.65;
  }
}

.variant-picker .variant-option--buttons label:has(.swatch) {
  border-radius: var(--variant-picker-swatch-radius);
}

.sticky-content {
  position: sticky;
  top: var(--sticky-header-offset, 0);
  z-index: var(--layer-flat);
}

@media screen and (min-width: 750px) {
  .sticky-content--desktop,
  .sticky-content--desktop.full-height--desktop > .group-block {
    position: sticky;
    top: var(--sticky-header-offset, 0);
    z-index: var(--layer-flat);
  }
}

.price,
.compare-at-price,
.unit-price {
  white-space: nowrap;
}

.unit-price {
  display: block;
  font-size: min(0.85em, var(--font-paragraph--size));
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

.tax-note.tax-note.tax-note {
  font-size: min(0.85em, var(--font-paragraph--size));
  font-weight: var(--font-paragraph--weight);
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

product-price.text-block:is(.h1, .h2, .h3, .h4, .h5, .h6) > *:not(.tax-note) {
  margin-block: 0;
}

.compare-at-price {
  opacity: 0.4;
  text-decoration-line: line-through;
  text-decoration-thickness: 1.5px;
}

.card-gallery {
  position: relative;
}

@container (max-width: 70px) {
  .card-gallery:hover .quick-add__button {
    display: none;
  }
}

/* Drawer */
.drawer {
  background-color: var(--color-background);
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  width: var(--sidebar-width);
  z-index: var(--layer-raised);
  transform: translateX(-120%);
  transition: transform var(--animation-speed) var(--animation-easing);
}

.drawer[data-open='true'] {
  transform: translateX(0);
}

.drawer-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.drawer__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--drawer-header-block-padding) var(--drawer-inline-padding);
}

.drawer__title {
  font-size: var(--font-h2--size);
  margin: 0;
}

.drawer__close {
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
}

.drawer__content {
  display: block;
  padding: var(--drawer-content-block-padding) var(--drawer-inline-padding);
  width: 100%;
}

/* Background overlay */
.background-overlay {
  position: relative;

  &::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--background-overlay-color, rgb(0 0 0 / 15%));
  }
}

/* Spacing style */
.spacing-style {
  --spacing-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --spacing-scale: var(--spacing-scale-default);
  }

  /* Must disable this, when you use these with calc and another unit type, things break — see logo.liquid */
  /* stylelint-disable length-zero-no-unit */
  --padding-block: 0px;
  --padding-block-start: var(--padding-block, 0px);
  --padding-block-end: var(--padding-block, 0px);
  --padding-inline: 0px;
  --padding-inline-start: var(--padding-inline, 0px);
  --padding-inline-end: var(--padding-inline, 0px);
  --margin-block: 0px;
  --margin-block-start: var(--margin-block, 0px);
  --margin-block-end: var(--margin-block, 0px);
  --margin-inline: 0px;
  --margin-inline-start: var(--margin-inline, 0px);
  --margin-inline-end: var(--margin-inline, 0px);
}

.spacing-style,
.inherit-spacing {
  padding-block: calc(var(--padding-block-start) + var(--section-top-offset, 0px)) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  margin-block: var(--margin-block-start) var(--margin-block-end);
  margin-inline: var(--margin-inline-start) var(--margin-inline-end);
}

/* Size style */
.size-style {
  width: var(--size-style-width-mobile, var(--size-style-width));
  height: var(--size-style-height-mobile, var(--size-style-height));

  @media screen and (min-width: 750px) {
    width: var(--size-style-width);
    height: var(--size-style-height);
  }
}

/* Custom Typography style */
.custom-typography,
.custom-typography > * {
  font-family: var(--font-family);
  font-weight: var(--font-weight);
  text-transform: var(--text-transform);
  text-wrap: var(--text-wrap);
  line-height: var(--line-height);
  letter-spacing: var(--letter-spacing);
}

.custom-typography {
  h1 {
    line-height: var(--line-height--display, var(--line-height));
  }

  h2,
  h3,
  h4 {
    line-height: var(--line-height--heading, var(--line-height));
  }

  p {
    line-height: var(--line-height--body, var(--line-height));
  }
}

.custom-font-size,
.custom-font-size > * {
  font-size: var(--font-size);
}

.custom-font-weight,
.custom-font-weight > * {
  font-weight: var(--weight);
}

/* Border override style */
.border-style {
  border-width: var(--border-width);
  border-style: var(--border-style);
  border-color: var(--border-color);
  border-radius: var(--border-radius);
}

/* Gap scaling style */
.gap-style,
.layout-panel-flex {
  --gap-scale: var(--spacing-scale-md);

  @media screen and (min-width: 990px) {
    --gap-scale: var(--spacing-scale-default);
  }
}

.layout-panel-flex {
  display: flex;
  gap: var(--gap);
  height: 100%;
}

.layout-panel-flex--row {
  flex-flow: row var(--flex-wrap);
  justify-content: var(--horizontal-alignment);
  align-items: var(--vertical-alignment);
}

.layout-panel-flex--column {
  flex-flow: column var(--flex-wrap);
  align-items: var(--horizontal-alignment);
  justify-content: var(--vertical-alignment);
}

@media screen and (max-width: 749px) {
  .mobile-column {
    flex-flow: column nowrap;
    align-items: var(--horizontal-alignment);
    justify-content: var(--vertical-alignment-mobile);
  }

  .layout-panel-flex--row:not(.mobile-column) {
    flex-wrap: var(--flex-wrap-mobile);

    > .menu {
      flex: 1 1 min-content;
    }

    > .text-block {
      flex: 1 1 var(--max-width--display-tight);
    }

    > .image-block {
      flex: 1 1 var(--size-style-width-mobile-min);
    }

    > .button {
      flex: 0 0 fit-content;
    }
  }
}

@media (min-width: 750px) {
  .layout-panel-flex {
    flex-direction: var(--flex-direction);
  }
}

/* Form fields */
.field {
  position: relative;
  width: 100%;
  display: flex;
  transition: box-shadow var(--animation-speed) ease;
}

.field__input {
  flex-grow: 1;
  text-align: left;
  border-radius: var(--style-border-radius-inputs);
  transition: box-shadow var(--animation-speed) ease, background-color var(--animation-speed) ease;
  padding: var(--input-padding);
  box-shadow: var(--input-box-shadow);
  background-color: var(--color-input-background);
  color: var(--color-input-text);
  border: none;
  outline: none;
  font-size: var(--font-paragraph--size);

  &:autofill {
    background-color: var(--color-input-background);
    color: var(--color-input-text);
  }
}

.field__input:is(:focus, :hover) {
  box-shadow: var(--input-box-shadow-focus);
  background-color: var(--color-input-hover-background);
}

.field__input--button-radius {
  border-radius: var(--style-border-radius-buttons-primary);
}

.field__input--button-padding {
  padding-inline: var(--padding-3xl);
}

.field__label {
  color: rgb(var(--color-input-text-rgb) / var(--opacity-80));
  font-size: var(--font-paragraph--size);
  left: var(--input-padding-x);
  top: 50%;
  transform: translateY(-50%);
  margin-bottom: 0;
  pointer-events: none;
  position: absolute;
  transition: top var(--animation-speed) ease, font-size var(--animation-speed) ease;
}

/* RTE styles */
.rte,
.shopify-policy__title {
  :is(h1, h2, h3, h4, h5, h6) {
    margin-block: clamp(1.5rem, 1em * 3.3, 2.5rem) clamp(1rem, 1em * 0.25, 2rem);
  }

  :first-child:is(p, h1, h2, h3, h4, h5, h6),
  :first-child:empty + :is(p, h1, h2, h3, h4, h5, h6) {
    margin-block-start: 0;
  }

  ul,
  ol {
    margin-block-start: 0;
    padding-inline-start: 1.5em;
  }

  /* Only apply margin-block-end to the higher level list, not nested lists */
  :is(ul, ol):not(:is(ul, ol) :is(ul, ol)) {
    margin-block-end: 1em;
  }

  blockquote {
    margin-inline: 1.5em 2.3em;
    margin-block: 3.8em;
    padding-inline-start: 0.8em;
    border-inline-start: 1.5px solid rgb(var(--color-foreground-rgb) / var(--opacity-25));
    font-style: italic;
    font-weight: 500;
  }

  .rte-table-wrapper {
    overflow-x: auto;
  }

  table {
    /* stylelint-disable-next-line declaration-no-important */
    width: 100% !important;
    border-collapse: collapse;
  }

  tr:not(:has(td)),
  thead {
    background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
    font-weight: bold;
    text-transform: uppercase;
  }

  tr:has(td) {
    border-bottom: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-10));
  }

  th,
  td {
    text-align: start;
    padding-inline: var(--padding-md);
    padding-block: var(--padding-sm);
  }
}

.shopify-policy__container {
  padding-block: var(--padding-xl);
}

.checkbox {
  --checkbox-size: 22px;
  --checkbox-top: 50%;
  --checkbox-left: 1.5px;
  --checkbox-offset: 3px;
  --checkbox-border-radius: 7px;
  --checkbox-label-padding: 8px;
  --checkbox-path-opacity: 0;
  --checkbox-cursor: pointer;
  --checkbox-border: 1px solid rgb(var(--color-foreground-rgb) / var(--opacity-35-55));

  position: relative;
  display: flex;
  align-items: center;

  @media screen and (min-width: 750px) {
    --checkbox-size: 16px;
    --checkbox-border-radius: 5px;
    --checkbox-label-padding: 6px;
  }

  &:has(.checkbox__input:checked) {
    --checkbox-path-opacity: 1;
  }

  &.checkbox--disabled {
    --checkbox-cursor: not-allowed;
  }
}

.checkbox__input {
  position: absolute;
  opacity: 0;
  margin: 0;
  width: var(--checkbox-size);
  height: var(--checkbox-size);

  /* Outline is on the SVG instead, to allow it to have border-radius */
  &:focus-visible {
    outline: none;
  }

  &:focus-visible + .checkbox__label .icon-checkmark {
    outline: var(--focus-outline-width) solid currentcolor;
    outline-offset: var(--focus-outline-offset);
  }

  &:checked + .checkbox__label .icon-checkmark {
    background-color: var(--color-foreground);
    border-color: var(--color-foreground);
  }

  &:disabled + .checkbox__label .icon-checkmark {
    background-color: var(--input-disabled-background-color);
    border-color: var(--input-disabled-border-color);
  }
}

.checkbox__label {
  position: relative;
  display: inline-flex;
  cursor: var(--checkbox-cursor);
  line-height: var(--checkbox-size);
  min-width: var(--minimum-touch-target);
}

.checkbox .icon-checkmark {
  height: var(--checkbox-size);
  width: var(--checkbox-size);
  flex-shrink: 0;
  border: var(--checkbox-border);
  border-radius: var(--checkbox-border-radius);
  background-color: var(--color-background);
}

.checkbox__label-text {
  padding-inline-start: var(--checkbox-label-padding);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.checkbox .icon-checkmark path {
  stroke: var(--color-background);
  opacity: var(--checkbox-path-opacity);
  transition: opacity var(--animation-speed) var(--animation-easing);
}

.checkbox__input:disabled + .checkbox__label {
  color: var(--input-disabled-text-color);
}

/* Add to cart button */
.button[id^='BuyButtons-ProductSubmitButton-'] {
  position: relative;
  overflow: hidden;
}

/* Cart bubble */
.cart-bubble {
  --cart-padding: 0.2em;

  position: relative;
  width: 20px;
  aspect-ratio: 1;
  border-radius: 50%;
  border-width: 0;
  display: flex;
  line-height: normal;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-button-text);
  padding-inline: var(--cart-padding);
}

.cart-bubble__background {
  position: absolute;
  inset: 0;
  background-color: var(--color-primary-button-background);
  border-radius: var(--style-border-radius-lg);
}

.cart-bubble__text {
  font-size: var(--font-size--3xs);
  z-index: var(--layer-flat);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Quantity selector */
.quantity-selector {
  --quantity-selector-width: 124px;

  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--color-input-text);
  background-color: var(--color-input-background);
  border: var(--style-border-width-inputs) solid var(--color-input-border);
  border-radius: var(--style-border-radius-inputs);
  flex: 1 1 var(--quantity-selector-width);
  align-self: stretch;
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    background-color: var(--color-input-hover-background);
  }
}

.product-form-buttons:has(.add-to-cart-button.button-secondary) .quantity-selector {
  border-radius: var(--style-border-radius-buttons-secondary);
}

.quantity-selector :is(.quantity-minus, .quantity-plus) {
  /* Unset button styles */
  padding: 0;
  background: transparent;
  box-shadow: none;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  width: var(--minimum-touch-target);
  height: var(--minimum-touch-target);
  flex-shrink: 0;
  color: var(--color-input-text);
}

.quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-inputs);
  border-end-start-radius: var(--style-border-radius-inputs);
}

.quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-inputs);
  border-end-end-radius: var(--style-border-radius-inputs);
}

.product-details .quantity-selector {
  border-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-minus {
  border-start-start-radius: var(--style-border-radius-buttons-primary);
  border-end-start-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-buttons-primary);
  border-end-end-radius: var(--style-border-radius-buttons-primary);
}

.quantity-selector .svg-wrapper {
  transition: transform var(--animation-speed) var(--animation-easing);
}

.quantity-selector svg {
  width: var(--icon-size-xs);
  height: var(--icon-size-xs);
}

:is(.quantity-minus, .quantity-plus):active .svg-wrapper {
  transform: scale(0.9);
}

.quantity-selector input[type='number'] {
  margin: 0;
  text-align: center;
  border: none;
  appearance: none;
  max-width: calc(var(--quantity-selector-width) - var(--minimum-touch-target) * 2);
  border-radius: var(--style-border-radius-buttons);
  color: var(--color-input-text);
  background-color: transparent;
}

/* Chrome, Safari, Edge, Opera */
.quantity-selector input[type='number']::-webkit-inner-spin-button,
.quantity-selector input[type='number']::-webkit-outer-spin-button {
  appearance: none;
}

/* Firefox */
.quantity-selector input[type='number'] {
  appearance: textfield;
}

/* Pills (used in facets and predictive search) */

.pills__pill {
  --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5-15));

  color: var(--color-foreground);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--gap-sm);
  min-width: 48px;
  padding: 6px 12px;
  border-radius: var(--style-border-radius-pills);
  cursor: pointer;
  background-color: var(--pills-pill-background-color);
  transition: background-color var(--animation-speed) var(--animation-easing);

  &:hover {
    --pills-pill-background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  }

  @media screen and (max-width: 749px) {
    padding: var(--padding-xs) var(--padding-md);
  }
}

.pills__pill > .svg-wrapper {
  --close-icon-opacity: 0.4;
  --icon-stroke-width: 1px;

  color: var(--color-foreground);
}

.pills__pill--swatch {
  @media screen and (max-width: 749px) {
    padding-inline-start: var(--padding-sm);
  }
}

.pills__pill--swatch .swatch {
  margin-right: -4px;
}

.pills__pill--desktop-small {
  @media screen and (min-width: 750px) {
    font-size: var(--font-size--xs);
  }
}

/* Fly to cart animation */
fly-to-cart {
  --offset-y: 10px;

  position: fixed;
  width: var(--width, 40px);
  height: var(--height, 40px);
  left: 0;
  top: 0;
  z-index: calc(infinity);
  pointer-events: none;
  border-radius: var(--style-border-radius-buttons-primary);
  overflow: hidden;
  object-fit: cover;
  background-size: cover;
  background-position: center;
  opacity: 0;
  background-color: var(--color-foreground);
  translate: var(--start-x, 0) var(--start-y, 0);
  transform: translate(-50%, -50%);
  animation-name: travel-x, travel-y, travel-scale;
  animation-timing-function: var(--x-timing), var(--y-timing), var(--scale-timing);
  animation-duration: 0.6s;
  animation-composition: accumulate;
  animation-fill-mode: both;
}

fly-to-cart.fly-to-cart--main {
  --x-timing: cubic-bezier(0.7, -5, 0.98, 0.5);
  --y-timing: cubic-bezier(0.15, 0.57, 0.9, 1.05);
  --scale-timing: cubic-bezier(0.85, 0.05, 0.96, 1);
}

fly-to-cart.fly-to-cart--quick {
  --x-timing: cubic-bezier(0, -0.1, 1, 0.32);
  --y-timing: cubic-bezier(0, 0.92, 0.92, 1.04);
  --scale-timing: cubic-bezier(0.86, 0.08, 0.98, 0.98);

  animation-duration: 0.6s;
}

fly-to-cart.fly-to-cart--sticky {
  --x-timing: cubic-bezier(0.98, -0.8, 0.92, 0.5);
  --y-timing: cubic-bezier(0.14, 0.56, 0.92, 1.04);
  --scale-timing: cubic-bezier(0.86, 0.08, 0.98, 0.98);
  --radius: var(--style-border-radius-buttons-primary);

  @media (max-width: 749px) {
    --x-timing: cubic-bezier(0.98, -0.1, 0.92, 0.5);
  }

  animation-duration: 0.8s;
}

@keyframes travel-scale {
  0% {
    opacity: var(--start-opacity, 1);
  }

  5% {
    opacity: 1;
  }

  100% {
    border-radius: 50%;
    opacity: 1;
    transform: translate(-50%, calc(-50% + var(--offset-y))) scale(0.25);
  }
}

@keyframes travel-x {
  to {
    translate: var(--travel-x, 0) 0;
  }
}

@keyframes travel-y {
  to {
    translate: 0 var(--travel-y, 0);
  }
}

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* ------------------------------------------------------------------------------ */

/* Animation declarations - to be kept at the bottom of the file for ease of find */
@keyframes grow {
  0% {
    transform: scale(1);
  }

  50% {
    transform: scale(1.2);
  }

  100% {
    transform: scale(1);
  }
}

@keyframes move-and-fade {
  from {
    transform: translate(var(--start-x, 0), var(--start-y, 0));
    opacity: var(--start-opacity, 0);
  }

  to {
    transform: translate(var(--end-x, 0), var(--end-y, 0));
    opacity: var(--end-opacity, 1);
  }
}

@keyframes slideInTopViewTransition {
  from {
    transform: translateY(100px);
  }
}

@keyframes elementSlideInTop {
  from {
    margin-top: var(--padding-sm);
    opacity: 0;
  }

  to {
    margin-top: 0;
    opacity: 1;
  }
}

@keyframes elementSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

@keyframes elementSlideInBottom {
  from {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes elementSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-1 * var(--padding-sm)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInTop {
  from {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }

  to {
    transform: translateY(-50%);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutTop {
  from {
    transform: translateY(-50%);
    opacity: 1;
  }

  to {
    transform: translateY(calc(-50% + var(--margin-lg)));
    opacity: 0;
  }
}

@keyframes thumbnailsSlideInBottom {
  from {
    transform: translateY(100%);
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes thumbnailsSlideOutBottom {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(100%);
    opacity: 0;
  }
}

@keyframes search-element-slide-in-bottom {
  0% {
    transform: translateY(20px);
    opacity: 0;
  }

  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes search-element-slide-out-bottom {
  0% {
    transform: translateY(0);
    opacity: 1;
  }

  100% {
    transform: translateY(20px);
    opacity: 0;
  }
}

@keyframes dialogZoom {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }

  to {
    opacity: 0;
    transform: scale(0.95) translateY(1em);
  }
}

@keyframes thumbnail-selected {
  0%,
  100% {
    box-shadow: 0 0 0 2px transparent;
    scale: 0.9;
  }

  50% {
    box-shadow: 0 0 0 2px #000;
    scale: 1;
  }
}

@keyframes backdropFilter {
  from {
    backdrop-filter: brightness(1);
  }

  to {
    backdrop-filter: brightness(0.75);
  }
}

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes modalSlideInTop {
  from {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }

  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes modalSlideOutTop {
  from {
    transform: translateY(0);
    opacity: 1;
  }

  to {
    transform: translateY(var(--padding-sm));
    opacity: 0;
  }
}

.bubble {
  display: inline-flex;
  height: calc(var(--variant-picker-swatch-height) / 1.5);
  font-size: var(--font-size--xs);
  border-radius: 20px;
  min-width: 20px;
  padding: 0 6px;
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-10-25));
  color: var(--color-foreground);
  align-items: center;
  justify-content: center;
}

.bubble svg {
  width: 12px;
  height: 12px;
}

.top-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(-50px 0 0 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .top-shadow--mobile::before {
    display: none;
  }
}

.bottom-shadow::before {
  content: '';
  box-shadow: 0 0 10px var(--color-shadow);
  position: absolute;
  z-index: var(--layer-lowest);
  inset: 0;
  clip-path: inset(0 0 -50px 0); /* stylelint-disable-line */
}

@media (min-width: 750px) {
  .bottom-shadow--mobile::before {
    display: none;
  }
}

.video-placeholder-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

:not(deferred-media) > .video-placeholder-wrapper {
  width: var(--video-placeholder-width);
}

.video-placeholder-wrapper > * {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/*
 * Slideshow Component
 */
slideshow-component {
  --cursor: grab;
  --slide-offset: 6px;

  position: relative;
  display: flex;
  flex-direction: column;
  timeline-scope: var(--slideshow-timeline);
}

slideshow-component.slideshow--content-below-media slideshow-slide {
  display: grid;
}

.slideshow--content-below-media slideshow-slide :is(.slide__image-container, .slide__content) {
  position: static;
}

.slideshow--content-below-media slideshow-slide {
  grid-template-rows: var(--grid-template-rows);

  @media screen and (min-width: 750px) {
    grid-template-rows: var(--grid-template-rows-desktop);
  }
}

.slide__content {
  opacity: 0;
  animation: slide-reveal both linear;
  animation-timeline: var(--slideshow-timeline);

  @media (prefers-reduced-motion) {
    opacity: 1;
    animation: none;
  }
}

.slideshow--single-media {
  --cursor: default;
}

a slideshow-component {
  --cursor: pointer;
}

/*
 * Slideshow Slides
 */
slideshow-slides {
  width: 100%;
  position: relative;
  display: flex;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-color: transparent transparent;
  scrollbar-width: none;
  gap: var(--slideshow-gap, 0);
  cursor: var(--cursor);
  min-height: var(--slide-min-height);

  @media (prefers-reduced-motion) {
    scroll-behavior: auto;
  }

  &::-webkit-scrollbar {
    width: 0;
  }

  &::-webkit-scrollbar-track {
    background: transparent;
  }

  &::-webkit-scrollbar-thumb {
    background: transparent;
    border: none;
  }

  @media screen and (min-width: 750px) {
    min-height: var(--slide-min-height-desktop);
  }
}

slideshow-component[disabled='true'] slideshow-slides {
  overflow: hidden;
}

slideshow-component[mobile-disabled] slideshow-slides {
  @media screen and (max-width: 749px) {
    overflow: hidden;
  }
}

slideshow-slide {
  position: relative;
  scroll-snap-align: center;
  width: var(--slide-width, 100%);
  max-height: 100%;
  flex-shrink: 0;
  view-timeline-name: var(--slideshow-timeline);
  view-timeline-axis: inline;
  content-visibility: auto;
  contain-intrinsic-size: auto none;
  border-radius: var(--corner-radius, 0);
  overflow: hidden;

  slideshow-component[actioned] &,
  &[aria-hidden='false'] {
    content-visibility: visible;
  }

  slideshow-component slideshow-slide:not([aria-hidden='false']) {
    content-visibility: hidden;
  }

  &[hidden]:not([reveal]) {
    display: none;
  }

  /* Make inactive slides appear clickable */
  &[aria-hidden='true'] {
    cursor: pointer;
  }
}

slideshow-slide .slide__image-container--rounded {
  border-radius: var(--corner-radius, 0);
}

slideshow-slide.product-media-container--tallest {
  content-visibility: visible;
}

@media screen and (max-width: 749px) {
  /* Media gallery has a peeking slide on the right side always, and on the left side when the current slide is the last one */
  .media-gallery--hint
    :is(
      slideshow-slide:has(+ slideshow-slide[aria-hidden='false']:last-of-type),
      slideshow-slide[aria-hidden='false'] + slideshow-slide
    ) {
    content-visibility: auto;

    slideshow-component[actioned] & {
      content-visibility: visible;
    }
  }
}

/*
 * Collection and Resource list carousels have peeking slides on both sides.
 * Card galleries preview the next or previous images on 'pointerenter', so we
 * try to kick load them beforehand (they are lazy loaded otherwise).
 */
:is(.resource-list__carousel, .card-gallery)
  :is(
    slideshow-slide:has(+ slideshow-slide[aria-hidden='false']),
    slideshow-slide[aria-hidden='false'] + slideshow-slide
  ) {
  content-visibility: auto;

  slideshow-component[actioned] & {
    content-visibility: visible;
  }
}

/*
 * Be specific about HTML children structure to avoid targeting nested slideshows.
 * Ensure that the content is 'visible' while scrolling instead of 'auto' to avoid issues in Safari.
 */
slideshow-component:is([dragging], [transitioning], :hover) > slideshow-container > slideshow-slides > slideshow-slide {
  content-visibility: visible;
}

slideshow-slides[gutters*='start'] {
  padding-inline-start: var(--gutter-slide-width, 0);
  scroll-padding-inline-start: var(--gutter-slide-width, 0);
}

slideshow-slides[gutters*='end'] {
  padding-inline-end: var(--gutter-slide-width, 0);
}

slideshow-component[dragging] {
  --cursor: grabbing;

  * {
    pointer-events: none;
  }
}

slideshow-component[dragging] slideshow-arrows {
  display: none;
}

slideshow-container {
  width: 100%;
  display: block;
  position: relative;
  grid-area: container;
  container-type: inline-size;
}

@media screen and (min-width: 750px) {
  .media-gallery--carousel slideshow-component:has(slideshow-controls[thumbnails]) {
    &:has(slideshow-controls[pagination-position='right']) {
      display: grid;
      grid-template:
        'container controls' auto
        'arrows controls' min-content
        / 1fr auto;
    }

    &:has(slideshow-controls[pagination-position='left']) {
      display: grid;
      grid-template:
        'controls container' auto
        'controls arrows' min-content
        / auto 1fr;
    }

    slideshow-controls[pagination-position='left'] {
      order: -1;
    }
  }
}

/* Slideshow Play/Pause */
.slideshow-control:is(.icon-pause, .icon-play) {
  color: var(--color-active);

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

  svg {
    display: none;
  }
}

slideshow-component:is([autoplay]) {
  &:is([paused]) {
    .icon-play > svg {
      display: block;
    }
  }

  &:not([paused]) {
    .icon-pause > svg {
      display: block;
    }
  }
}

/* Slideshow Arrows */
slideshow-arrows {
  --cursor-previous: w-resize;
  --cursor-next: e-resize;

  position: absolute;
  inset: 0;
  display: flex;
  z-index: var(--layer-heightened);
  pointer-events: none;
  mix-blend-mode: difference;
  align-items: flex-end;

  &[position='left'] {
    justify-content: flex-start;
    padding-inline: var(--padding-xs);
  }

  &[position='right'] {
    justify-content: flex-end;
    padding-inline: var(--padding-xs);
  }

  &[position='center'] {
    justify-content: space-between;
    align-items: center;
  }
}

slideshow-arrows:has(.slideshow-control--shape-square),
slideshow-arrows:has(.slideshow-control--shape-circle) {
  mix-blend-mode: normal;
}

slideshow-component[disabled='true'] slideshow-arrows {
  display: none;
}

slideshow-arrows .slideshow-control {
  pointer-events: auto;
  opacity: 0;
  min-height: var(--minimum-touch-target);
  min-width: var(--minimum-touch-target);
  padding: 0 var(--padding-xs);
  color: var(--color-white);
}

slideshow-arrows .slideshow-control.slideshow-control--style-none {
  display: none;
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  padding-inline: 0 var(--padding-md);
  opacity: 1;
}

.card-gallery slideshow-arrows .slideshow-control {
  /* Align icons with quick-add button */
  padding-inline: var(--padding-xl);

  @container (max-width: 249px) {
    padding-inline: 0 var(--padding-sm);
  }
}

:not(.media-gallery--carousel)
  > :is(slideshow-component:hover, slideshow-component:focus-within):not(:has(slideshow-controls:hover))
  > slideshow-container
  > slideshow-arrows
  .slideshow-control {
  animation: arrowsSlideIn var(--animation-speed) var(--animation-easing) forwards;
}

@keyframes arrowsSlideIn {
  from {
    transform: translate(var(--padding-sm), 0);
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@keyframes slide-reveal {
  0% {
    translate: calc(var(--slideshow-slide-offset, 6) * 1rem) 0;
    opacity: 0;
  }

  50% {
    opacity: 1;
  }

  100% {
    translate: calc(var(--slideshow-slide-offset, 6) * -1rem) 0;
    opacity: 0;
  }
}

.block-resource-list {
  display: flex;
  flex-direction: column;
  row-gap: var(--gap);
  min-width: 0;
  min-height: 0;
  container-type: inline-size;
  container-name: resource-list;
}

.section-resource-list,
.section-carousel {
  row-gap: var(--gap);
}

.section-resource-list__content {
  display: flex;
  flex-direction: column;
  align-items: var(--horizontal-alignment);
  gap: var(--gap);
  width: 100%;
}

.section-resource-list__content:empty {
  display: none;
}

.section-resource-list__header:is(:empty, :has(.group-block-content:empty)),
.section-resource-list__content:empty {
  display: none;
}

.section-resource-list.section--full-width product-card-link > .group-block,
.section-carousel.section--full-width product-card-link > .group-block {
  @media screen and (max-width: 749px) {
    padding-inline: max(var(--padding-xs), var(--padding-inline-start))
      max(var(--padding-xs), var(--padding-inline-end));
  }
}

.resource-list--carousel-mobile {
  display: block;

  @media screen and (min-width: 750px) {
    display: none;
  }
}

.resource-list {
  --resource-list-mobile-gap-max: 9999px;
  --resource-list-column-gap: min(var(--resource-list-column-gap-desktop), var(--resource-list-mobile-gap-max));
  --resource-list-row-gap: min(var(--resource-list-row-gap-desktop), var(--resource-list-mobile-gap-max));

  width: 100%;

  @media screen and (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }

  @container resource-list (max-width: 749px) {
    --resource-list-mobile-gap-max: 12px;
  }
}

.resource-list--grid {
  display: grid;
  gap: var(--resource-list-row-gap) var(--resource-list-column-gap);
  grid-template-columns: var(--resource-list-columns-mobile);

  @media screen and (min-width: 750px) {
    grid-template-columns: var(--resource-list-columns);
  }

  @container resource-list (max-width: 449px) {
    grid-template-columns: var(--resource-list-columns-mobile);
  }

  @container resource-list(min-width: 450px) and (max-width: 749px) {
    --resource-list-columns-per-row: 3;

    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    /* Avoid orphan in last row when there are 4, 7, or 10 items */
    &:has(.resource-list__item:first-child:nth-last-child(3n + 1)),
    /* Clean two full rows when there are 8 items */
    &:has(.resource-list__item:first-child:nth-last-child(8n)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 750px) {
    grid-template-columns: repeat(var(--resource-list-columns-per-row), 1fr);

    &:has(.resource-list__item:first-child:nth-last-child(n + 9)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(n + 7):nth-last-child(-n + 8)) {
      --resource-list-columns-per-row: 4;
    }

    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 3;
    }

    &:has(.resource-list__item:first-child:nth-last-child(5)) {
      --resource-list-columns-per-row: 5;
    }

    &:has(.resource-list__item:first-child:nth-last-child(-n + 4)) {
      --resource-list-columns-per-row: 4;
    }
  }

  @container resource-list (min-width: 1200px) {
    &:has(.resource-list__item:first-child:nth-last-child(6)) {
      --resource-list-columns-per-row: 6;
    }
  }
}

.resource-list__item {
  height: 100%;
  color: var(--color-foreground);
  text-decoration: none;
}

.resource-list__carousel {
  --slide-width: 60vw;

  width: 100%;
  position: relative;
  container-type: inline-size;
  container-name: resource-list-carousel;

  .slideshow-control[disabled] {
    display: none;
  }

  .slideshow-control--next {
    margin-inline-start: auto;
  }
}

@container resource-list-carousel (max-width: 749px) {
  .resource-list__carousel .resource-list__slide {
    --slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
  }
}

@container resource-list-carousel (min-width: 750px) {
  .resource-list__carousel .resource-list__slide {
    --section-slide-width: calc(
      (100% - (var(--resource-list-column-gap) * (var(--column-count) - 1)) - var(--peek-next-slide-size)) /
        var(--column-count)
    );
    --fallback-slide-width: clamp(150px, var(--mobile-card-size, 60cqw), var(--slide-width-max));
    --slide-width: var(--section-slide-width, var(--fallback-slide-width));
  }
}

.resource-list__carousel slideshow-slides {
  gap: var(--resource-list-column-gap);

  /* Add padding to prevent hover animations from being clipped in slideshow
     15px accommodates:
     - Scale effect (9px on each side from 1.03 scale)
     - Lift effect (4px upward movement)
     - Shadow (15px spread with -5px offset)
     Using 16px for better alignment with our spacing scale */

  margin-block: -16px;
  padding-block: 16px;
}

.resource-list__carousel slideshow-arrows {
  padding-inline: var(--util-page-margin-offset);
}

.resource-list__carousel .resource-list__slide {
  width: var(--slide-width);
  flex: 0 0 auto;
  scroll-snap-align: start;
  min-width: 0;
}

/* Base styles */
.group-block,
.group-block-content {
  position: relative;
}

.group-block:has(> video-background-component),
.group-block:has(> .background-image-container) {
  overflow: hidden;
}

.group-block-content {
  height: 100%;
  width: 100%;
}

/* Container styles */
.section-content-wrapper.section-content-wrapper:where(.layout-panel-flex) .group-block--fill {
  flex: 1;
}

/* Flex behavior for width variants */
.layout-panel-flex--row > .group-block--width-fit {
  flex: 0;
}

.layout-panel-flex--row > .group-block--width-fill {
  flex: 1;
}

.layout-panel-flex--row > .group-block--width-custom {
  flex-basis: var(--size-style-width);
}

/* Dimension utilities - Height */
.group-block--height-fit {
  height: auto;
}

.group-block--height-custom,
.group-block--height-fill {
  height: var(--size-style-height);
}

/* Flex behavior for height variants */
.layout-panel-flex--column > .group-block--height-fit {
  flex: 0 1 auto;
}

.layout-panel-flex--column > .group-block--height-fill {
  flex: 1;
}

.layout-panel-flex--column > .group-block--height-custom {
  flex-basis: var(--size-style-height);
}

accordion-custom {
  details {
    &::details-content,
    .details-content {
      block-size: 0;
      overflow-y: clip;
      opacity: 0;
      interpolate-size: allow-keywords;
      transition: content-visibility var(--animation-speed-slow) allow-discrete,
        padding-block var(--animation-speed-slow) var(--animation-easing),
        opacity var(--animation-speed-slow) var(--animation-easing),
        block-size var(--animation-speed-slow) var(--animation-easing);
    }

    /* Disable transitions when the content toggle is not caused by the direct user interaction, e.g. opening the filters on mobile. */
    &:not(:focus-within)::details-content,
    &:not(:focus-within) .details-content {
      transition: none;
    }

    &:not([open]) {
      &::details-content,
      .details-content {
        padding-block: 0;
      }
    }

    &[open] {
      &::details-content,
      .details-content {
        opacity: 1;
        block-size: auto;

        @starting-style {
          block-size: 0;
          opacity: 0;
          overflow-y: clip;
        }

        &:focus-within {
          overflow-y: visible;
        }
      }
    }
  }
}

accordion-custom[data-disable-on-mobile='true'] summary {
  @media screen and (max-width: 749px) {
    cursor: auto;
  }
}

accordion-custom[data-disable-on-desktop='true'] summary {
  @media screen and (min-width: 750px) {
    cursor: auto;
  }
}

text-component {
  --shimmer-text-color: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  --shimmer-color-light: rgb(var(--color-foreground-rgb) / var(--opacity-10));
  --shimmer-speed: 1.25s;

  display: inline-block;
  position: relative;
  transition: color var(--animation-speed-slow) ease;
  line-height: 1;

  &::after {
    content: attr(value);
    position: absolute;
    inset: 0;
    color: transparent;
    opacity: 0;
    transition: opacity var(--animation-speed-slow) var(--animation-easing);
    pointer-events: none;
    background-image: linear-gradient(
      -85deg,
      var(--shimmer-text-color) 10%,
      var(--shimmer-color-light) 50%,
      var(--shimmer-text-color) 90%
    );
    background-clip: text;
    background-size: 200% 100%;
    background-position: 100% 0;
    place-content: center;
  }

  &[shimmer] {
    color: transparent;

    &::after {
      opacity: 1;
      animation: text-shimmer var(--shimmer-speed) infinite linear;
    }
  }
}

@keyframes text-shimmer {
  0% {
    background-position: 100% 0;
  }

  100% {
    background-position: -100% 0;
  }
}

/* Animation transitions */
.transition-background-color {
  transition: background-color var(--animation-speed-medium) ease-in-out;
}

.transition-transform {
  transition: transform var(--animation-speed-medium) var(--animation-timing-bounce);
}

.transition-border-color {
  transition: border-color var(--animation-speed-medium) var(--animation-timing-hover);
}

/* Global scrollbar styles */

/* Webkit browsers */
::-webkit-scrollbar {
  width: 20px;
}

::-webkit-scrollbar-track {
  background-color: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
  border-radius: 20px;
  border: 6px solid transparent;
  background-clip: content-box;
  transition: background-color 0.2s;
}

::-webkit-scrollbar-thumb:hover {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-60));
}

@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

/* Product card title truncation - applied only to zoom-out view */
[product-grid-view='zoom-out'] :is(.product-card, .product-grid__card) :is(h4, .h4) {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
}

/* Product card title truncation - applied on mobile regardless of view */
@media screen and (max-width: 749px) {
  :is(.product-card, .product-grid__card) :is(h4, .h4) {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    -webkit-line-clamp: 3;
  }
}

.product-card:hover,
.collection-card:hover,
.resource-card:hover,
.predictive-search-results__card--product:hover,
.predictive-search-results__card:hover {
  position: relative;
  z-index: var(--layer-raised);
  transition: transform var(--hover-transition-duration) var(--hover-transition-timing),
    box-shadow var(--hover-transition-duration) var(--hover-transition-timing);
}

.header .product-card:hover,
.header .collection-card:hover,
.header .resource-card:hover,
.header-drawer .product-card:hover,
.header-drawer .collection-card:hover,
.header-drawer .resource-card:hover {
  z-index: auto;
  transform: none;
  box-shadow: none;
}

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}

/* Adobe Font Override */
:root {
  --font-body-family: "proxima-nova", sans-serif !important;
  --font-heading-family: "proxima-nova", sans-serif !important;
}

/* Force override for elements that sometimes ignore variables */
body, h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, p, a, .button, .btn {
  font-family: "proxima-nova", sans-serif !important;
}

.button-secondary {
--button-padding-inline: 60px;
    --button-padding-block: 12px;
    font-weight: 600;}

    .button {
--button-padding-inline: 60px;
    --button-padding-block: 12px;
      font-weight: 600;}

.menu-list__link {
    padding-inline: 1.5rem !important;
  font-size:  0.95rem !important; }

  a:hover {
      color: #009882 !important;
  }

/* =============================================================
   REFINED PRODUCT CARD STYLING
   ============================================================= */

/* 1. Target the custom product-card element only */
product-card.product-card {
  position: relative !important;
  overflow: visible !important;
}

/* 2. Style the specific text-block inside product cards (Fixed Width) */
product-card.product-card .text-block {
  position: absolute !important;
  bottom: 25px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  z-index: 10 !important;
  
  /* The Fixed Pill Design */
  background: #ffffff !important;
  height: 40px !important;      /* Fixed height for uniformity */
  width: 200px !important;      /* Fixed width - adjust to your preference */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50px !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12) !important;
  padding: 0 15px !important;   /* Internal spacing for long text */
}

/* 3. Text and Link Styling (Centered & Clipped) */
product-card.product-card .text-block p,
product-card.product-card .text-block a {
  margin: 0 !important;
  font-size: 12px !important;   /* Slightly smaller to fit fixed width */
  font-weight: 600 !important;
  color: #000000 !important;
  text-transform: uppercase !important;
  letter-spacing: 0px !important;
  
  /* Critical for Fixed Width: */
  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important; /* Adds "..." if name is too long */
  width: 100% !important;
}

/* 4. Hide secondary details (h3) if you only want the pill */
product-card.product-card .product-grid-view-zoom-out--details {
  display: none !important;
}

/* =============================================================
   MOBILE OVERRIDES: PRODUCT CARD PILLS
   ============================================================= */

@media screen and (max-width: 749px) {
  /* 1. Shrink the pill width to prevent touching card edges */
  product-card.product-card .text-block {
    width: 140px !important;    /* Reduced from 200px */
    height: 32px !important;    /* Slightly shorter height for mobile */
    bottom: 15px !important;    /* Bring it closer to the bottom edge */
    padding: 0 10px !important; /* Tighter internal padding */
  }

  /* 2. Smaller font for the handle/title inside the pill */
  product-card.product-card .text-block p,
  product-card.product-card .text-block a {
    font-size: 0.8rem !important; /* Smaller, cleaner font for mobile */
    font-weight: 600 !important;
    letter-spacing: 0px !important; /* Tiny bit of spacing for legibility */
  }
}

/* =============================================================
   MOBILE OVERRIDES: PRODUCT CARD REFINEMENT
   ============================================================= */

@media screen and (max-width: 749px) {
  /* 1. Adjust the Card Border Radius */
  product-card.product-card, 
  product-card.product-card .product-media__image,
  product-card.product-card .border-style {
    border-radius: 15px !important;
  }

  /* 2. Shrink the pill width to prevent touching card edges */
  product-card.product-card .text-block {
    width: 140px !important;    
    height: 34px !important;    
    bottom: 15px !important;    
    padding: 0 10px !important; 
  }

  /* 3. Smaller font for the handle/title inside the pill */
  product-card.product-card .text-block p,
  product-card.product-card .text-block a {
    font-size: 10px !important; 
    font-weight: 600 !important;
  }
}
  
.page-width-narrow, .page-width-content {
  --page-content-width: 100%;
--page-width: 100%;
}

iframe {
  border-radius: 20px;
}

@media (max-width: 980px) {
iframe {
  border-radius: 15px !important;
}}


@media screen and (max-width: 749px) {
  /* Create a 2-column layout: Logo on left, Icons on right */
  .header__columns {
    display: grid !important;
    grid-template-areas: "logo icons" !important;
    grid-template-columns: 1fr auto !important;
    align-items: center;
  }

  /* Assign the logo to the left area */
  .header__columns .header-logo {
    grid-area: logo !important;
    justify-content: flex-start !important;
    margin-left: 20px;
  }

  /* Group Hamburger and Search to the right area */
  .header__columns .header__drawer,
  .header__columns .search-action {
    grid-area: icons !important;
    justify-self: end !important;
  }

  /* Add spacing between the Hamburger and Search icon */
  .header__columns .header__drawer {
    margin-right: 45px !important;
  }

  .header__columns .search-action {
    margin-right: 5px !important;
  }

  /* 1. Sticky Functionality */
  #shopify-section-header {
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 1000;
    background-color: #ffffff;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
  }

  /* 2. Layout: Logo on left, Icons on right */
  .header__columns {
    display: grid !important;
    grid-template-areas: "logo icons" !important;
    grid-template-columns: 1fr auto !important;
    align-items: center;
    padding: 10px 15px;
  }

  .header__columns .header-logo {
    grid-area: logo !important;
    justify-content: flex-start !important;
  }

  .header__columns .header__drawer,
  .header__columns .search-action {
    grid-area: icons !important;
    justify-self: end !important;
  }

  /* Spacing for icons */
  .header__columns .header__drawer {
    margin-right: 45px !important; 
  }
}

@media (max-width: 980px) {
.custom-font-size, .custom-font-size>* {
  font-size: 0.85rem;
}

.button-secondary {
  font-size: 0.7rem !important;
  --button-padding-block: 10px;
  --button-padding-inline: 50px;
  letter-spacing: 0.2px;
}

.menu-drawer__menu-item--mainlist {
  font-size: 1rem !important;
}
}

@media screen and (max-width: 749px) {
  /* 1. Force the container into a 2-column wrapping grid */
  #shopify-section-template--17531950268519__section_HRR47C .layout-panel-flex--row:not(.mobile-column) {
    display: flex !important;
    flex-flow: row wrap !important;
    gap: 16px !important;
    justify-content: center !important;
  }

  /* 2. Set columns to 50% width and stack content vertically */
  #shopify-section-template--17531950268519__section_HRR47C .layout-panel-flex--row:not(.mobile-column) > * {
    flex: 0 0 calc(50% - 8px) !important;
    max-width: calc(50% - 8px) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    margin-bottom: 0px !important;
    border-radius: 10px !important;
  }

  /* 3. Ensure the image is on top and full width of its column */
  #shopify-section-template--17531950268519__section_HRR47C img {
    width: 100% !important;
    height: auto !important;
    order: 1 !important;
  }

  /* 4. Ensure text blocks follow the image */
  #shopify-section-template--17531950268519__section_HRR47C .rich-text__blocks,
  #shopify-section-template--17531950268519__section_HRR47C h2,
  #shopify-section-template--17531950268519__section_HRR47C p {
    width: 100% !important;
    order: 2 !important;

  }

  /* 4. Ensure text blocks follow the image */
  #shopify-section-template--17531950268519__section_HRR47C .rich-text__blocks,
  #shopify-section-template--17531950268519__section_HRR47C p {
    font-size: 0.7rem !important;
  }
}

@media screen and (max-width: 749px) {
  /* 1. Container: Allow items to sit side-by-side and wrap */
  #shopify-section-template--17531950268519__section_rFJEyL .group-block-content {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 10px !important;
  }

  /* 2. ICON & HEADER: Let them share the first row */
  #shopify-section-template--17531950268519__section_rFJEyL .icon-block,
  #shopify-section-template--17531950268519__section_rFJEyL .text-block--AT1lYcmlCL3VKNE9ZY__text_qxJqiz {
    flex: 0 0 auto !important;
    width: auto !important;
    margin: 0 !important;
  }

  /* 3. BODY TEXT: Force to 100% width to drop it to the next row */
  #shopify-section-template--17531950268519__section_rFJEyL .text-block--AYkNoOEhBK1N6dXZ5T__text_UnVTpW {
    flex: 0 0 100% !important;
    width: 100% !important;
    margin-top: 5px !important;
  }

  /* 4. BUTTON: Force to 100% width (or fit-content if you prefer it small) */
  #shopify-section-template--17531950268519__section_rFJEyL .button-secondary {
    flex: 0 0 100% !important;
    width: 100% !important;
    display: block !important;
    text-align: center !important;
  }

/* 5. RESIZE ICON */
#shopify-section-template--17531950268519__section_rFJEyL .icon-block img {
  width: 28px !important;
  height: auto !important;
  min-width: unset !important;
  object-fit: contain !important;
}

/* Optional: Add a tiny bit of space between icon and text */
#shopify-section-template--17531950268519__section_rFJEyL .icon-block {
  margin-right: 8px !important;
}

/* 6. STRIP BUTTON STYLING & ALIGN LEFT */
#shopify-section-template--17531950268519__section_rFJEyL .button-secondary {
  /* Remove Box Styles */
  background: none !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  box-shadow: none !important;
  min-height: unset !important;
  min-width: unset !important;

  /* Alignment */
  display: inline-block !important;
  text-align: left !important;
  justify-content: flex-start !important;
  width: 100% !important;

  /* Optional: Add an underline so it still looks clickable */
  text-decoration: underline !important;
  text-underline-offset: 4px;
}

/* Ensure the container doesn't force the button to center */
#shopify-section-template--17531950268519__section_rFJEyL .group-block-content {
  align-items: flex-start !important;
}
}

/* MOBILE ONLY: FLIP VIDEO TO TOP FOR COMPANY INFO SECTION */
@media screen and (max-width: 749px) {
  /* 1. Target this specific section's container */
  #shopify-section-template--17531950268519__section_qeJqfF [data-testid="section-content"] {
    display: flex !important;
    flex-direction: column !important;
  }

  /* 2. Move the Video (deferred-media) to the first position */
  #shopify-section-template--17531950268519__section_qeJqfF deferred-media {
    order: -1 !important;
    margin-bottom: 20px !important;
  }

  /* 3. Ensure the Text Group stays below */
  #shopify-section-template--17531950268519__section_qeJqfF .group-block {
    order: 2 !important;
  }
}

/* =============================================================
   MOBILE MENU
   ============================================================= */

/* MOBILE ONLY: FULL WIDTH DRAWER */
@media screen and (max-width: 749px) {
  /* 1. Target the main drawer container */
  .menu-drawer, 
  #Details-menu-drawer-container .menu-drawer,
  .header__row--mobile .menu-drawer {
    width: 100% !important;
    max-width: 100vw !important;
    min-width: 100vw !important;
  }

  /* 2. Remove the "gap" or background overlay on the right */
  .menu-drawer-container,
  #Details-menu-drawer-container {
    width: 100% !important;
  }

  /* 3. Ensure the internal container stretches to the edges */
  .menu-drawer__inner-container {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* MOBILE DRAWER: FULL WIDTH & CLEANUP */
@media screen and (max-width: 749px) {
  /* 1. Force the drawer to 100% of the screen */
  .menu-drawer,
  #Details-menu-drawer-container .menu-drawer {
    width: 100vw !important;
    max-width: 100vw !important;
    min-width: 100vw !important;
  }

  /* 2. Hide the theme's default header and close button */
  .menu-drawer__header, 
  .menu-drawer__close-button,
  .menu-drawer button[aria-label*="close"] {
    display: none !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  /* 3. Ensure our custom header stretches across the full width */
  .drawer-header-custom {
    display: flex !important;
    position: sticky;
    top: 0;
    z-index: 10;
    padding: 20px 12px 20px 20px !important;
    margin-bottom: 15px;
  }
}

/* Increase spacing between mobile menu items */
.menu-drawer__menu > li {
  margin-bottom: 7px !important;
}

/* Add extra padding to the links themselves for a larger touch area */
.menu-drawer__menu-item--mainlist {
  padding-top: 7px !important;
  padding-bottom: 7px !important;
}

.menu-drawer__menu--childlist a {
  font-size: 0.8rem !important;
  color: #777777;
  letter-spacing: 0.5px;
}

.custom-teal-close svg {
  width: 26px !important;
  height: 26px !important;
  min-width: 26px !important;
  min-height: 26px !important;
}

.menu-drawer__menu {
  padding-left: 22px !important;
}

/* Move Video to Top on Mobile for specific section */
@media screen and (max-width: 749px) {
  #shopify-section-template--17532833464423__section_FieLy8 .section-content-wrapper {
    display: flex !important;
    flex-direction: column-reverse !important;
  }

  /* Optional: Add spacing between the video and the text below it */
  #shopify-section-template--17532833464423__section_FieLy8 deferred-media {
    margin-bottom: 0px !important;
  }

#shopify-section-template--17532833464423__section_FieLy8 p {
  font-size: 0.85rem !important;
}
}

@media screen and (max-width: 749px) {
  /* 1. Apply 2-column grid to both sections */
  #shopify-section-template--17532833464423__section_XnFWDD .section-content-wrapper,
  #shopify-section-template--17532833464423__section_BdMhhV .section-content-wrapper {
    display: grid !important;
    grid-template-columns: 30px 1fr !important;
    column-gap: 12px !important;
    row-gap: 25px !important;
    align-items: start !important;
    --padding-block-start: 0px !important;
    padding-top: 0px !important; 
  }

  /* 2. Resize icons in both sections */
  #shopify-section-template--17532833464423__section_XnFWDD .icon-block,
  #shopify-section-template--17532833464423__section_BdMhhV .icon-block {
    width: 28px !important;
    margin: 0 !important;
  }

  #shopify-section-template--17532833464423__section_XnFWDD .icon-block__media,
  #shopify-section-template--17532833464423__section_BdMhhV .icon-block__media {
    width: 28px !important;
    height: auto !important;
  }

  /* 3. Force text to the second column for both */
  #shopify-section-template--17532833464423__section_XnFWDD .group-block,
  #shopify-section-template--17532833464423__section_BdMhhV .group-block {
    grid-column: 2 !important;
    width: 100% !important;
    padding-inline-end: 0px;
  }

  /* 4. Tighten text spacing for both */
  #shopify-section-template--17532833464423__section_XnFWDD .group-block-content,
  #shopify-section-template--17532833464423__section_BdMhhV .group-block-content {
    gap: 4px !important;
  }

  /* 5. Reduce Line Height for body text in these sections */
  #shopify-section-template--17532833464423__section_XnFWDD p,
  #shopify-section-template--17532833464423__section_BdMhhV p {
    line-height: 1.3 !important; /* Tighter line height for a cleaner look */
    margin-top: 0 !important;
    font-size: 0.8rem;
  }
}

/* Disable reveal animation for slideshow cards */
slideshow-component .reveal-on-scroll {
  transform: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  transition: none !important;
  animation: none !important;
}

/* Ensure the container doesn't have a timeline effect fighting the layout */
slideshow-component {
  view-timeline: none !important;
}

/* RESTORED: Move image to top and remove inline padding on mobile */
@media screen and (max-width: 749px) {
  /* 1. Target the wrappers to flip the order */
  #shopify-section-template--17533154820199__section_FieLy8 .section-content-wrapper,
  #shopify-section-template--17533563863143__section_RLajwe .section-content-wrapper,
  #shopify-section-template--17533109502055__section_FieLy8 .section-content-wrapper,
  #shopify-section-template--17533369614439__section_CUdbWU .section-content-wrapper {
    display: flex !important;
    flex-direction: column-reverse !important; /* This puts image on top */
    --padding-inline-end: 0px !important;
    padding-right: 0px !important; 
    gap: 10px
  }

  /* 2. Target the text and titles to remove right padding and force full width */
  #shopify-section-template--17533154820199__section_FieLy8 .text-block,
  #shopify-section-template--17533563863143__section_RLajwe .text-block,
  #shopify-section-template--17533109502055__section_FieLy8 .text-block,
  #shopify-section-template--17533369614439__section_CUdbWU .text-block,
  #shopify-section-template--17533154820199__section_FieLy8 h1, 
  #shopify-section-template--17533154820199__section_FieLy8 h3 {
    --padding-inline-end: 0px !important;
    padding-right: 0px !important;
    --width: 100% !important;
    --max-width: 100% !important;
    width: 100% !important;
    text-align: left !important;
  }

  /* 3. Add spacing under the image so it doesn't touch the title */
  #shopify-section-template--17533154820199__section_FieLy8 .image-block,
  #shopify-section-template--17533563863143__section_RLajwe .image-block,
  #shopify-section-template--17533109502055__section_FieLy8 .image-block,
  #shopify-section-template--17533369614439__section_CUdbWU .image-block {
    margin-bottom: 25px !important;
  }
}

/* =============================================================
   MOBILE FOOTER
   ============================================================= */

/* Hide Entire Footer Section and its background on Mobile */
@media screen and (max-width: 749px) {
  .footer-content,
  .footer {
    display: none !important;
  }
}

/* Remove top padding for the specific divider line */
@media screen and (max-width: 749px) {
  .divider-sections--17531950399591__divider_LVMY9K {
    --padding-block-start: 0px !important;
    padding-top: 0px !important;
  }
}

/* Final Footer Cleanup: Swapped Order, Centered, Small Text */
@media screen and (max-width: 749px) {
  /* 1. Stack everything vertically and center it */
  #shopify-section-sections--17531950399591__section_zDxDjf .section-content-wrapper {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    padding-bottom: 40px !important; 
    --gap: 0px !important; /* Removes the theme's default gap */
  }

  /* 2. Swap Order: Policy links (Block 2) on top, Copyright (Block 1) on bottom */
  #shopify-section-sections--17531950399591__section_zDxDjf .group-block:nth-child(1) {
    order: 2 !important;
  }
  #shopify-section-sections--17531950399591__section_zDxDjf .group-block:nth-child(2) {
    order: 1 !important;
    margin-bottom: 5px !important; /* Increased space for clarity */
  }

  /* 3. FORCE alignment to center for the Policy container and Text Block */
  #shopify-section-sections--17531950399591__section_zDxDjf .group-block-content,
  #shopify-section-sections--17531950399591__section_zDxDjf .text-block--AbzdYNFB0Si9GOFh1Q__text_gxEikw {
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    --horizontal-alignment: center !important;
    display: block !important; /* Changed to block to allow text-align to work */
    width: 100% !important;
  }

  /* 4. Ensure every block expands to full width */
  #shopify-section-sections--17531950399591__section_zDxDjf .group-block,
  #shopify-section-sections--17531950399591__section_zDxDjf .text-block {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
    text-align: center !important;
    margin: 0 auto !important;
  }

  /* 5. Set the very small font size and reset margins */
  #shopify-section-sections--17531950399591__section_zDxDjf p,
  #shopify-section-sections--17531950399591__section_zDxDjf a {
    font-size: 0.55rem !important; 
    line-height: 1.6 !important;
    margin: 0 !important;
    text-align: center !important;
    display: inline-block !important; /* Allows them to sit side by side but center within the block */
  }
}

a {
  text-decoration: none;
}

/* =============================================================
   MOBILE MENU
   ============================================================= */

/* Fix Contact Dropdown (Submenu 6) alignment */
@media screen and (min-width: 990px) {
  /* 1. Target the main container that holds the dropdown */
  .menu-list__submenu:has(#submenu-6) {
    left: auto !important;
    right: 0 !important; /* Anchor it to the right edge of the 'Contact' link */
    width: 320px !important; /* Force a standard width instead of page-width */
    min-width: 280px !important;
    transform: none !important;
  }

  /* 2. Fix the inner container and the grid */
  #submenu-6, 
  #submenu-6 .mega-menu,
  #submenu-6 .mega-menu__grid {
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    left: auto !important;
    right: 0 !important;
  }

  /* 3. Force the list to stack vertically and center/left align */
  [data-menu-list-id="MegaMenuList-5"] {
    --menu-columns-desktop: 1 !important; /* Force 1 column instead of 6 */
    display: block !important;
    padding: 20px !important;
  }

  /* 4. Ensure the items inside are visible and tidy */
  [data-menu-list-id="MegaMenuList-5"] .mega-menu__column {
    width: 100% !important;
    display: block !important;
  }
}

/* Final Arrow Fix - Larger, Bolder, and Vertically Centered */
@media screen and (min-width: 990px) {
  .menu-list__link[aria-haspopup="true"] {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .menu-list__link[aria-haspopup="true"] .menu-list__link-title::after {
    content: " \25BE" !important; 
    font-size: 16px !important; 
    display: inline-block !important;
    color: currentColor !important;
    font-weight: bold !important;
    line-height: 0 !important; /* Forces the character box to collapse for better centering */
    margin-left: 6px !important;
    
    /* This is the magic part to move it up */
    transform: translateY(-2px) !important; 
  }
}

/* =============================================================
   MOBILE PAGE STACKING FIXES
   ============================================================= */

/* Full Width Mobile Fix for Multiple Sections */
@media screen and (max-width: 749px) {
  /* 1. Remove outer section constraints */
  #shopify-section-template--17531950170215__section_HVVNnL,
  #shopify-section-template--17531950268519__section_G497MJ,
  #shopify-section-template--17533563863143__section_PqjQA4,
  #shopify-section-template--17533369614439__section_Xktk6J {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* 2. Target the main content wrappers */
  #shopify-section-template--17531950170215__section_HVVNnL .section-content-wrapper,
  #shopify-section-template--17531950268519__section_G497MJ .section-content-wrapper,
  #shopify-section-template--17533563863143__section_PqjQA4 .section-content-wrapper,
  #shopify-section-template--17533369614439__section_Xktk6J .section-content-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    padding-top: 25px !important;    
    padding-bottom: 25px !important;
    display: flex !important;
    justify-content: center !important;
    margin: 0 !important;
  }

  /* 3. Force the floating white boxes to 92% width */
  #shopify-section-template--17531950170215__section_HVVNnL .group-block,
  #shopify-section-template--17531950268519__section_G497MJ .group-block,
  #shopify-section-template--17533563863143__section_PqjQA4 .group-block,
  #shopify-section-template--17533369614439__section_Xktk6J .group-block {
    width: 92% !important;
    max-width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    border-radius: 15px !important;
    height: auto !important;
    min-height: fit-content !important;
    --size-style-width: 100% !important;
  }

  /* 4. Fix internal vertical padding and stacking */
  #shopify-section-template--17531950170215__section_HVVNnL .group-block-content,
  #shopify-section-template--17531950268519__section_G497MJ .group-block-content,
  #shopify-section-template--17533563863143__section_PqjQA4 .group-block-content,
  #shopify-section-template--17533369614439__section_Xktk6J .group-block-content {
    padding-top: 40px !important;
    padding-bottom: 10px !important;
    flex-direction: column !important;
    gap: 30px !important;
    display: flex !important;
  }

  /* 5. Fix text and form alignment */
  #shopify-section-template--17531950170215__section_HVVNnL .text-block,
  #shopify-section-template--17531950268519__section_G497MJ .text-block,
  #shopify-section-template--17533563863143__section_PqjQA4 .text-block,
  #shopify-section-template--17533369614439__section_Xktk6J .text-block,
  #shopify-section-template--17531950170215__section_HVVNnL .contact-form,
  #shopify-section-template--17531950268519__section_G497MJ .contact-form,
  #shopify-section-template--17533563863143__section_PqjQA4 .contact-form,
  #shopify-section-template--17533369614439__section_Xktk6J .contact-form {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 25px !important;
    padding-right: 25px !important;
    --size-style-width: 100% !important;
  }
}

/* Swap Image and Text on Mobile for Referral Section */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533563863143__section_YJftqF .section-content-wrapper {
    display: flex !important;
    flex-direction: column-reverse !important;
  }

  /* Adjust spacing after swap so the image isn't too close to the text above it */
  #shopify-section-template--17533563863143__section_YJftqF .group-block:last-child {
    margin-bottom: 20px !important;
  }
}

/* =============================================================
   SEARCH CARDS
   ============================================================= */

.resource-card__content .price {
  display: none;
}

/* Overlay Resource Card Title inside the Search Image */
.resource-card {
  position: relative !important;
  display: block !important;
}

/* Refined Resource Card Title: Smaller, Standard Bold, and Centered */
.resource-card__content {
  position: absolute !important;
  bottom: 15px !important; 
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;        /* Ensure it spans the card width */
  display: flex !important;
  justify-content: center !important; /* Horizontally center the pill */
  align-items: center !important;
  pointer-events: none;
  z-index: 10 !important;
}

.resource-card__title {
  background: rgba(255, 255, 255, 0.9) !important;
  backdrop-filter: blur(4px) !important;
  -webkit-backdrop-filter: blur(4px) !important;
  
  /* Text styling */
  font-size: 12px !important;     /* Small but legible */
  font-weight: 600 !important;    /* Standard Bold (not extra heavy) */
  color: #000 !important;
  margin: 0 !important;           /* Remove default margins that might offset centering */
  
  /* Pill Shape and Spacing */
  padding: 6px 15px !important; 
  border-radius: 40px !important;
  width: fit-content !important;
  white-space: nowrap !important; /* Keep the title on one line */
  box-shadow: 0 2px 8px rgba(0,0,0,0.1) !important;
}

/* Ensure price is hidden */
.resource-card__content [ref="priceContainer"] {
  display: none !important;
}


/* =============================================================
   PAGE: CONTACT PARTNERS
   ============================================================= */

/* MIDDLE EAST - CONSOLIDATED DESKTOP & MOBILE */

/* 1. DESKTOP STYLING */
#shopify-section-template--17533799235687__section_RtwGnk .section-content-wrapper {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  gap: 20px !important;
}

/* Column Widths: 25% | 25% | 50% */
#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(1) { flex: 0 0 25% !important; display: flex !important; }
#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(2) { flex: 0 0 25% !important; }
#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(3) { flex: 0 0 50% !important; }

/* Desktop Row Centering & Height Sync */
#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(2) .text-block,
#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(3) .text-block {
  min-height: 160px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
}

#shopify-section-template--17533799235687__section_RtwGnk .group-block:nth-child(2) .text-block {
  text-align: center !important;
  align-items: center !important;
}

/* 2. MOBILE INTERWEAVING (749px and down) */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533799235687__section_RtwGnk .section-content-wrapper {
    display: grid !important;
    grid-template-columns: 100% !important;
    gap: 15px !important;
  }

  /* Dissolve containers for shuffling */
  #shopify-section-template--17533799235687__section_RtwGnk .group-block,
  #shopify-section-template--17533799235687__section_RtwGnk .group-block-content {
    display: contents !important;
  }

  #shopify-section-template--17533799235687__section_RtwGnk .text-block {
    min-height: auto !important;
  }

  /* Specific Row Ordering */
  /* Middle East Title */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--ARTNDakJUakVKeDB1Q__text_F7G6fc { order: 1 !important; margin-bottom: 20px !important; }

  /* Pair 1: Distribution Center */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AT0Zzekd0d0kwK3plM__text_jtkGf4 { order: 2 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AWWdxMXVYT0M5TUpsW__text_jVMjez { order: 3 !important; margin-bottom: 30px !important; }

  /* Pair 2: UAE */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AMDlkbmJGTHYvbFlRM__text_qQAmfj { order: 4 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--ARVdndGRQRVFXRFlCS__text_xGcwFR { order: 5 !important; margin-bottom: 30px !important; }

  /* Pair 3: Saudi Arabia */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AT1FZSitaOGJpRjVwd__text_fBjMtm { order: 6 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AN3FwSUdQdGx4Mi96b__text_9f3jCB { order: 7 !important; margin-bottom: 30px !important; }

  /* Pair 4: Bahrain */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--Ac1dhNXp0UGthams0d__text_QNTfXi { order: 8 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AYmtpRW51RFNpYTg1N__text_893A4m { order: 9 !important; margin-bottom: 30px !important; }

  /* Pair 5: Jordan */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AN21rZVJNNmxwcjhqS__text_xjycng { order: 10 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AcFRSa2pkVjMwT2FWZ__text_xUjYTH { order: 11 !important; margin-bottom: 30px !important; }

  /* Pair 6: Lebanon */
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AWXNPOXE0YU1yZGVUb__text_nCEma9 { order: 12 !important; }
  #shopify-section-template--17533799235687__section_RtwGnk .text-block--AeTdrRWh1RlRYUlZSS__text_rTz3Jf { order: 13 !important; }
}

/* NORTH AMERICA - FINAL SYNC & CENTER */

/* 1. Main Row Container */
#shopify-section-template--17533799235687__section_tqjK6N .section-content-wrapper {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important; /* Critical for Column 1 height */
  gap: 20px !important;
}

/* 2. Column Widths 25 / 25 / 50 */
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(1) { flex: 0 0 25% !important; display: flex !important; }
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(2) { flex: 0 0 25% !important; }
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(3) { flex: 0 0 50% !important; }

/* 3. Group 1: PERFECT CENTERING */
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(1) .group-block-content {
  height: 100% !important;
  width: 100% !important;
}

#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(1) .text-block {
  height: 100% !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* Vertical Center */
  align-items: center !important;     /* Horizontal Center */
  text-align: center !important;
  margin: 0 !important;
}

#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(1) .text-block p {
  margin: 0 !important; /* Removes default Shopify spacing */
}

/* 4. Columns 2 & 3: Row Height Sync */
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(2) .text-block,
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(3) .text-block {
  flex: 0 0 auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  min-height: 160px !important; /* Ensure they have enough presence */
  margin: 0 !important;
}

/* 5. Center Country Tags */
#shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(2) .text-block {
  align-items: center !important;
  text-align: center !important;
}

/* EUROPE SECTION - FINAL SYNC & CENTER */

/* 1. Main Row Container */
#shopify-section-template--17533799235687__section_g4hqMy .section-content-wrapper {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  gap: 20px !important;
  width: 100% !important;
}

/* 2. Column Widths 25 / 25 / 50 */
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(1) { flex: 0 0 25% !important; display: flex !important; }
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(2) { flex: 0 0 25% !important; }
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(3) { flex: 0 0 50% !important; }

/* 3. Group 1: Europe Title Centering */
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(1) .group-block-content,
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(1) .text-block {
  height: 100% !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* Vertical */
  align-items: center !important;     /* Horizontal */
  text-align: center !important;
  margin: 0 !important;
}

#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(1) .text-block p {
  margin: 0 !important;
}

/* 4. Columns 2 & 3: Row Height Sync */
#shopify-section-template--17533799235687__section_g4hqMy .group-block-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
  height: 100% !important;
}

#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(2) .text-block,
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(3) .text-block {
  flex: 1 !important; /* Makes Germany match the Address height */
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}

/* 5. Center Germany Tag */
#shopify-section-template--17533799235687__section_g4hqMy .group-block:nth-child(2) .text-block {
  align-items: center !important;
  text-align: center !important;
}

/* Mobile Fix */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533799235687__section_g4hqMy .section-content-wrapper {
    flex-direction: column !important;
  }
  #shopify-section-template--17533799235687__section_g4hqMy .group-block {
    flex: 0 0 100% !important;
  }
}

/* HEADER ROW - FINAL ALIGNMENT FIX */

/* 1. Force the row to use a 20px gap to match the directory rows */
#shopify-section-template--17533799235687__section_XV63Lz .section-content-wrapper {
  display: flex !important;
  flex-direction: row !important;
  gap: 20px !important; /* This is the key to alignment */
  width: 100% !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* 2. Lock Widths to 25% / 25% / 50% */
#shopify-section-template--17533799235687__section_XV63Lz .group-block:nth-child(1) { 
  flex: 0 0 25% !important; 
  max-width: 25% !important;
}
#shopify-section-template--17533799235687__section_XV63Lz .group-block:nth-child(2) { 
  flex: 0 0 25% !important; 
  max-width: 25% !important;
}
#shopify-section-template--17533799235687__section_XV63Lz .group-block:nth-child(3) { 
  flex: 0 0 50% !important; 
  max-width: 50% !important;
}

/* 3. Center Text within the columns */
#shopify-section-template--17533799235687__section_XV63Lz .group-block-content,
#shopify-section-template--17533799235687__section_XV63Lz .text-block {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  text-align: center !important;
}

/* 4. Hide Header on Mobile (Matches directory stacking) */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533799235687__section_XV63Lz {
    display: none !important;
  }
}

  /* NORTH AMERICA ONLY: PILL HEIGHT TWEAK */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533799235687__section_tqjK6N .group-block:nth-child(1) .text-block {
    padding: 5px 20px !important;
  }
}

/* 1. THE LOOK: PILLS & SPACING (North America, Middle East, & Europe) */
@media screen and (max-width: 749px) {

  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .section-content-wrapper {
    gap: 0px !important; 
    display: grid !important;
    grid-template-columns: 100% !important;
  }

  /* Region Title Pills (Black) */
  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .group-block:nth-child(1) .text-block {
    background-color: #000000;
    color: #ffffff !important;
    border-radius: 50px !important;
    padding: 10px 20px;
    width: 100% !important;
    margin: 0 0 10px 0 !important;
    min-height: auto !important;
    display: flex !important;
    justify-content: center !important;
    /* Force height sync by killing Shopify's internal padding */
    --padding-block-start: 0px !important;
    --padding-block-end: 0px !important;
  }

  /* Country Tags (Green Pill) */
  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .group-block:nth-child(2) .text-block {
    background-color: #009882 !important;
    border-radius: 50px !important;
    padding: 10px 20px !important;
    width: 100% !important;
    min-height: auto !important;
    display: flex !important;
    justify-content: center !important;
    margin-bottom: 15px !important; 
    --padding-block-start: 0px !important;
    --padding-block-end: 0px !important;
  }
  
  /* Address Boxes */
  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .group-block:nth-child(3) .text-block {
    background-color: #f4f5f7 !important;
    border-radius: 15px !important;
    padding: 20px !important;
    width: 100% !important;
    min-height: auto !important;
    text-align: left !important;
    margin-bottom: 30px !important; 
  }

  /* Text Alignment Reset */
  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .text-block p {
    margin: 0 !important;
    width: 100% !important;
    text-align: center !important;
  }

  :is(#shopify-section-template--17533799235687__section_tqjK6N, 
      #shopify-section-template--17533799235687__section_RtwGnk,
      #shopify-section-template--17533799235687__section_g4hqMy) .group-block:nth-child(3) .text-block p {
    text-align: left !important;
    line-height: 1.4 !important;
  }
}

/* 3. THE BRAIN - EUROPE ORDERING */
@media screen and (max-width: 749px) {
  #shopify-section-template--17533799235687__section_g4hqMy .group-block,
  #shopify-section-template--17533799235687__section_g4hqMy .group-block-content { display: contents !important; }

  /* Europe Title */
  #shopify-section-template--17533799235687__section_g4hqMy .text-block--AaDhuTWR5bitHV2Q3U__text_JJDyHJ { order: 1 !important; }
  /* Germany Pair */
  #shopify-section-template--17533799235687__section_g4hqMy .text-block--AK2JuK3hxTGtXTnFxM__text_yqXXmz { order: 2 !important; }
  #shopify-section-template--17533799235687__section_g4hqMy .text-block--ARlprNFVod2xEdkhTQ__text_tykzFj { order: 3 !important; }
}

  /* NORTH AMERICA - CONSOLIDATED MOBILE FIX */
@media screen and (max-width: 749px) {
  /* 1. Setup Grid & Dissolve Containers - REQUIRED for order to work */
  #shopify-section-template--17533799235687__section_tqjK6N .section-content-wrapper {
    display: grid !important;
    grid-template-columns: 100% !important;
    gap: 0px !important; 
  }
  #shopify-section-template--17533799235687__section_tqjK6N .group-block,
  #shopify-section-template--17533799235687__section_tqjK6N .group-block-content {
    display: contents !important;
  }

  /* 2. THE BLACK PILL (North America Title) */
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--AU1paS2JCZTVzMWtMN__text_yq4fDz { 
    order: 1 !important; 
    background-color: #000000 !important;
    color: #ffffff !important;
    border-radius: 50px !important;
    padding: 10px 20px !important; 
    margin: 0 0 15px 0 !important; 
    --padding-block-start: 0px !important;
    --padding-block-end: 0px !important;
    font-size: 1.5rem !important; 
    --font-size: 1.5rem !important;
    line-height: 1.2 !important;
    display: flex !important;
    justify-content: center !important;
    min-height: auto !important;
  }

  /* 3. THE GREEN PILLS (Canada & USA Headers) */
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--AMkM5ZFkxVStRTlZiV__text_h9TpKb, 
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--ATjBPcGFCU3pRWm1Ea__text_nBDzih {
    order: 2 !important;
    padding: 10px 20px !important;
    margin-bottom: 15px !important;
    --padding-block-start: 0px !important;
    --padding-block-end: 0px !important;
    line-height: 1.2 !important;
    font-size: 1.5rem !important;
    --font-size: 1.5rem !important;
    display: flex !important;
    justify-content: center !important;
  }

  /* 4. SET THE INTERWEAVING ORDER */
  /* Canada */
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--AMkM5ZFkxVStRTlZiV__text_h9TpKb { order: 2 !important; }
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--AVWpiMWJ0TUlGb2E1Y__text_3HF94J { order: 3 !important; margin-bottom: 30px !important; }

  /* USA */
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--ATjBPcGFCU3pRWm1Ea__text_nBDzih { order: 4 !important; }
  #shopify-section-template--17533799235687__section_tqjK6N .text-block--ATi83YWU2eU9UeStMW__text_qdB7dt { order: 5 !important; margin-bottom: 30px !important; }
}


/* =============================================================
   BLOG LISTING: CARD STYLING
   ============================================================= */

/* 1. Main Card Container: Border, Rounding, and Spacing */
.blog-post-card.custom-grid-item {
  display: flex !important;
  flex-direction: column !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 15px !important;
  overflow: hidden !important;
  background-color: #ffffff !important;
  padding-bottom: 20px !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.blog-post-card.custom-grid-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 15px rgba(0,0,0,0.05) !important;
}

/* 2. Content Alignment (Inside the border) */
.blog-post-card__content {
  padding: 10px 25px 0 25px !important;
}

/* 3. Title Styling: Force 100% width and set font */
.blog-post-card .blog-post-card__title-link .text-block {
  width: 100% !important;
  max-width: 100% !important;
  font-size: 1.2rem !important;
  line-height: 1.2 !important;
  font-weight: 700;
  color: #000 !important;
  letter-spacing: -0.3px;
}

/* 4. "Read More" Link Logic */
.blog-post-card__content-text a {
  visibility: hidden;
  position: relative;
  font-size: 0 !important;
}

.blog-post-card__content-text a::before {
  content: "Read more";
  visibility: visible;
  font-size: 0.9rem;
  font-weight: 600;
  display: inline-block;
  color: #009882;
}

@media (max-width: 980px) {
  .blog-post-card__content {
  padding: 0px 20px 0px 20px !important;
}

.blog-post-card .blog-post-card__title-link .text-block {
  line-height: 1.05!important;
}
}

/* =============================================================
   SINGLE BLOG POST: ARTICLE HEADER
   ============================================================= */

/* 1. The Title Divider Line */
.text-block--AdGYzc2pPZDkwRE9ob__blog-post-title {
  border-bottom: 2px solid #e0e0e0 !important;
  padding-bottom: 30px !important;
  margin-bottom: 10px !important;
  width: 100% !important;
}

.text-block--AdGYzc2pPZDkwRE9ob__blog-post-title h1 {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

@media (max-width: 980px) {
.text-block--AdGYzc2pPZDkwRE9ob__blog-post-title {
  padding-bottom: 20px !important;}}

/* =============================================================
   FEATURED BLOG GRID: FINAL OPTIMIZED
   ============================================================= */

/* 1. Main Card: Consistent height and border */
.featured-blog-posts-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  height: 100% !important;
  border: 1px solid #e0e0e0 !important;
  border-radius: 15px !important;
  overflow: hidden !important;
  background-color: #ffffff !important;
  padding-bottom: 15px !important; 
  transition: transform 0.2s ease;
}

/* 2. Image: Standard landscape ratio */
.featured-blog-posts-card .featured-blog-posts-card__image {
  aspect-ratio: 3 / 2 !important;
  width: 100% !important;
  border-radius: 0 !important;
  margin: 0 !important;
}

/* 3. Inner Wrapper: Kill stretch */
.featured-blog-posts-card__inner {
  height: auto !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 0 !important;
}

/* 4. Content Area: Tight spacing and padding */
 .featured-blog-posts-card__content {
  padding: 20px 25px 0px 20px !important; 
  height: auto !important;
  flex-grow: 0 !important;
  display: block !important; 
}

/* 5. Typography: Title & Excerpt */
.featured-blog-posts-card__content h4 {
  margin: 0 0 4px 0 !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  letter-spacing: -0.3px;
}

.blog-post-card__content-text {
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.4 !important;
  font-size: 0.9rem !important;
  --padding-block-start: 0px !important;
  --padding-block-end: 0px !important;
}

/* 6. Read More Link: Branded color */
.featured-blog-posts-card .blog-post-card__content-text::after {
  content: "Read more";
  display: block;
  margin-top: 6px !important;
  font-size: 0.95rem;
  font-weight: 600;
  color: #009882;
}


/* =============================================================
   MOBILE BLOG CARD: FIX ALL SLIDES
   ============================================================= */

@media screen and (max-width: 749px) {
  /* 1. Target EVERY slide in the sequence */
  slideshow-slide.resource-list__slide,
  [ref="slides[]"] {
    width: 100% !important;
    padding-right: 0 !important;
    padding-left: 0 !important;
    margin-right: 0 !important;
  }

  /* 2. Fix the inner container for all cards */
  .resource-list__item {
    width: 100% !important;
    padding: 0 5px !important; /* Small even gap on both sides */
    box-sizing: border-box !important;
    display: block !important;
  }

  /* 3. Force the card to fill the container */
  .featured-blog-posts-card {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  /* 4. Fix the text width inside every card */
  .featured-blog-posts-card__content,
  .featured-blog-posts-card__content rte-formatter {
    width: 100% !important;
    max-width: 100% !important;
    display: block !important;
  }
}


/* =============================================================
   FILTER DROPDOWN: SHOW ALL OPTIONS BY DEFAULT
   ============================================================= */

/* 1. Force all hidden list items to be visible */
.facets__inputs-list-item[ref="showMoreItems[]"],
.facets__inputs-list-item.mobile\:hidden {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
    opacity: 1 !important;
}

/* 2. Remove the height restriction on the wrapper */
.facets__inputs-wrapper[ref="showMoreContent"] {
    max-height: none !important;
    height: auto !important;
    overflow: visible !important;
}

/* 3. Completely hide the "Show More" button */
.show-more-component .show-more__button,
.show-more__button {
    display: none !important;
}

/* 4. Ensure the floating panel expands to fit everything */
.facets__inputs.facets__panel-content {
    max-height: 80vh !important; /* Limits it to 80% of screen height so it doesn't go off-page */
    overflow-y: auto !important;   /* Adds a scrollbar ONLY if it's longer than the screen */
}

/* =============================================================
   ZOOMED OUT PRODUCT CARDS
   ============================================================= */

/* 1. Hide the title and pill blocks without collapsing the card */
[product-grid-view="zoom-out"] .product-grid-view-zoom-out--details,
[product-grid-view="zoom-out"] .product-card .text-block,
[product-grid-view="zoom-out"] .product-card__content > a:not(.card-gallery) {
    display: none !important;
}

/* 2. Force the image gallery to stay visible */
[product-grid-view="zoom-out"] .card-gallery {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    width: 100% !important;
}

/* 3. Ensure the card content container doesn't shrink to zero */
[product-grid-view="zoom-out"] .product-card__content {
    display: flex !important;
    height: auto !important;
    min-height: 50px; /* Gives the card a safety floor */
    --product-card-gap: 0px !important;
}

/* 4. Fix for themes that hide the whole card if text is missing */
[product-grid-view="zoom-out"] .product-card {
    display: block !important;
    visibility: visible !important;
}

/* =============================================================
   HOME PAGE: INTERIOR FILM SECTION (RESPONSIVE)
   ============================================================= */

/* DESKTOP ONLY: Apply equal height logic */
@media screen and (min-width: 750px) {
  #shopify-section-template--17531950268519__section_HRR47C .section-content-wrapper {
    display: flex !important;
    align-items: stretch !important;
  }

  #shopify-section-template--17531950268519__section_HRR47C [data-testid="group-block"] {
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
  }

  #shopify-section-template--17531950268519__section_HRR47C .group-block-content {
    flex: 1 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    height: 100% !important;
  }
}

/* MOBILE & DESKTOP: Clean up spacing and text alignment */
#shopify-section-template--17531950268519__section_HRR47C .group-block-content {
  padding-bottom: 20px !important; /* Balanced space at the bottom */
}

#shopify-section-template--17531950268519__section_HRR47C rte-formatter {
  margin-top: 0 !important;
}

/* MOBILE ONLY: Ensure blocks don't collapse or overlap */
@media screen and (max-width: 749px) {
  #shopify-section-template--17531950268519__section_HRR47C [data-testid="group-block"] {
    height: auto !important; /* Allow content to dictate height on mobile */
    margin-bottom: 10px !important; /* Add breathing room between stacked cards */
  }
  
  #shopify-section-template--17531950268519__section_HRR47C .section-content-wrapper {
    display: block !important; /* Return to standard stack */
  }

  #shopify-section-template--17531950268519__section_HRR47C .group-block-content {
  padding-bottom: 0px !important; /* Balanced space at the bottom */
}

  .text-block--AWHdyWG5ueWxYeGNrN__text_4tKRzW,
  .text-block--AZ0hjOVBvcGZtMzkzR__text_3NJ3WG,
  .text-block--AMnMvblZKZHE5TisxV__text_Bqxpht,
  .text-block--AdUMyV2ZIS0pzTjFtN__text_kRwEfH {
    padding: 10px 20px 0 20px;
    margin-bottom: -5px;
  }
}

/* Custom styling for the Background Image Section */
#shopify-section-template--17532833464423__section_gNWfDG .background-image-container img {
  width: 95% !important;
  margin: 0 auto !important;
  display: block !important;
  border-radius: 20px;
}

@media (max-width: 980px) {
.text-block--ARTR1Wk1QbSsrZGgyY__text_hLGgdx {
  padding-inline-start: 20px;
padding-inline-end: 20px;
}

#shopify-section-template--17532833464423__section_gNWfDG .background-image-container img {
  width: 90% !important;
  border-radius: 15px!important;
}

#shopify-section-template--17532833464423__section_gNWfDG .section {
    min-height: auto !important;
    height: auto !important;
    padding: 20px 0 !important; /* Add space so it doesn't hit the bottom */
  }}

  @media (max-width: 980px) {
.facets-drawer__title {
font-size: 1rem !important;
font-weight: 700 !important;
}
.facets-drawer__close {
  right: 10px !important;
}

}

/* =============================================================
   MOBILE FILTER BUTTONS: SLIM 50/50 SPLIT
   ============================================================= */

@media screen and (max-width: 749px) {
  /* 1. Slim down the outer container */
  .facets__actions.facets__actions--active {
    display: flex !important;
    flex-direction: row !important;
    gap: 8px !important;            /* Slightly tighter gap */
    padding: 10px 15px !important;  /* Reduced top/bottom padding from 15px to 10px */
    width: 100% !important;
    box-sizing: border-box !important;
  }

  /* 2. 50/50 Width Split */
  .facets__actions--active facet-remove-component,
  .facets__actions--active .facets__see-results {
    flex: 1 1 50% !important;
    width: 50% !important;
  }

  /* 3. Slim Button Styling */
  .facets__actions--active .button {
    height: 36px !important;         /* Fixed height for a slimmer look */
    min-height: 36px !important;
    padding: 0 5px !important;       /* Minimal padding */
    width: 100% !important;
    white-space: nowrap !important;
    font-size: 11px !important;      /* Smaller font for the slimmer button */
    font-weight: 600 !important;
    text-transform: uppercase !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 50px !important;   /* Subtle rounding; change to 50px for pill shape */
  }
}

/* Target only mobile screens */
@media screen and (max-width: 749px) {
  .button--AU24rNkdBc2NnNEx2M__button_AChbYn {
    display: flex !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.85rem !important;
    
    /* Ensures the button doesn't shrink based on theme settings */
    box-sizing: border-box !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

@media screen and (max-width: 767px) {
  #shopify-section-template--17534830870631__section_mPVC8z h4,
  #shopify-section-template--17534613061735__section_mPVC8z h4,
  #shopify-section-template--17534818287719__section_mPVC8z h4 {
    font-size: 1rem !important;
  }
}