/** Shopify CDN: Minification failed

Line 6251:0 Unexpected "<"
Line 6277:0 Unexpected "<"
Line 6338:0 Expected "}" to go with "{"

**/
* {
  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;
}

.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);
  will-change: transform, box-shadow;
  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;
}

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), calc(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;
}

/* 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);
  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);
}

placeholder-image {
  display: block;
  height: 100%;
  aspect-ratio: var(--ratio);
}

placeholder-image[data-type='product'] {
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-15));
  width: 100%;
}

/** Placeholder background for the placeholder image, the dimensions are the same as the product images */
placeholder-image[data-type='product']:not(:has(> img)) {
  aspect-ratio: var(--ratio);
  height: 350px;
}

placeholder-image > img {
  object-fit: cover;
  aspect-ratio: var(--ratio);
  height: 100%;
}

[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;
}

/* 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: slideInLeft;
  --dialog-drawer-closing-animation: slideOutLeft;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: slideInRight;
  --dialog-drawer-closing-animation: slideOutRight;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

.dialog-drawer.dialog-closing {
  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);
  font-weight: var(--button-font-weight-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);
  font-weight: var(--button-font-weight-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);
  font-weight: var(--button-font-weight-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;
  }
}

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;
  }

  .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: transparent;
  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: rgba(0,0,0,0.55);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  }
}

/* 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) / calc(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);
  fill: currentcolor;
  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) + calc(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) + calc(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));
  }

  @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));
  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;
}

@media screen and (min-width: 750px) {
  product-card:focus-within .quick-add__button,
  .card-gallery:hover .quick-add__button {
    display: grid;
    will-change: margin, opacity;
    animation: elementSlideInTop var(--animation-speed) var(--animation-easing);
  }
}

@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) {
    .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;
  }

  &:has(.checkbox__input: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: grid;
  line-height: normal;
  place-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--2xs);
  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 {
  position: fixed;
  width: 40px;
  height: 40px;
  left: 0;
  top: 0;
  border-radius: 50%;
  z-index: calc(infinity);
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  transition: opacity 0.3s ease;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: var(--color-foreground);
  transform: translate(var(--x, 0), var(--y, 0)) scale(var(--scale, 1));
}

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

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

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

/* 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 slideInLeft {
  from {
    transform: translateX(var(--custom-transform-from, 100%));
  }

  to {
    transform: translateX(var(--custom-transform-to, 0));
  }
}

@keyframes slideInLeftViewTransition {
  from {
    transform: translateX(100px);
  }
}

@keyframes slideOutRight {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(var(--custom-transform-to, -100%));
  }
}

@keyframes slideInRight {
  from {
    transform: translateX(-100%);
  }

  to {
    transform: translateX(0);
  }
}

@keyframes slideOutLeft {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(100%);
  }
}

@keyframes slideInTop {
  from {
    transform: translateY(100%);
  }

  to {
    transform: translateY(0);
  }
}

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

@keyframes slideOutBottom {
  from {
    transform: translateY(0);
  }

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

@keyframes slideInBottom {
  from {
    transform: translateY(-100%);
  }

  to {
    transform: translateY(0);
  }
}

@keyframes slideOutTop {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-100%);
  }
}

@keyframes cartBubbleSlideIn {
  from {
    transform: translateY(-1em);
  }

  to {
    transform: translateY(0);
  }
}

@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;

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

.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);

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

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

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

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

  &[size='small'] {
    min-height: 17.5rem;
  }

  &[size='medium'] {
    min-height: 21.25rem;
  }

  &[size='large'] {
    min-height: 25rem;
  }

  @media screen and (min-width: 750px) {
    &[size='small'] {
      min-height: 26.25rem;
    }

    &[size='medium'] {
      min-height: 35rem;
    }

    &[size='large'] {
      min-height: 45rem;
    }
  }
}

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: start;
  width: var(--slide-width, 100%);
  max-height: 100%;
  flex-shrink: 0;
  view-timeline-axis: inline;
  content-visibility: auto;
  contain-intrinsic-size: auto none;

  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;
  }
}

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;
}

/*
 * Slideshow Controls
 */
slideshow-controls {
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  scrollbar-width: none;
  min-height: var(--minimum-touch-target);
  grid-area: controls;

  &[controls-on-media] {
    position: absolute;
    bottom: 0;
  }
}

slideshow-controls::-webkit-scrollbar {
  display: none;
}

slideshow-controls button {
  --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
  --color-active: var(--color-foreground);
  --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));

  display: inline-block;
  height: var(--minimum-touch-target);
  width: var(--minimum-touch-target);
  cursor: pointer;
}

slideshow-controls .icon {
  width: var(--icon-size-sm);
  height: var(--icon-size-xs);
}

slideshow-controls[pagination-position='center'] {
  align-items: center;
  justify-content: center;
}

slideshow-controls[pagination-position='center'][thumbnails] {
  width: 100%;
}

slideshow-controls[pagination-position='center']:not([controls-on-media], [thumbnails], [icons-on-media]) {
  justify-content: space-between;
}

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-controls[thumbnails]:is([pagination-position='right'], [pagination-position='left']) {
  display: flex;
  flex-direction: column;
  height: 0;
  min-height: 100%;

  .slideshow-controls__thumbnails-container {
    overflow: hidden auto;
  }

  &:not([controls-on-media]) {
    .slideshow-controls__thumbnails-container {
      position: sticky;
      top: var(--sticky-header-offset, 0);
    }

    .slideshow-controls__thumbnails {
      padding-block-start: var(--focus-outline-offset);
    }
  }
}

slideshow-controls:not([controls-on-media])[icons-on-media] {
  &[pagination-position='right'] {
    justify-content: flex-end;
  }

  &[pagination-position='left'] {
    justify-content: flex-start;
  }
}

slideshow-controls:not([controls-on-media]):is([pagination-position='left'], [pagination-position='right'])
  .slideshow-controls__thumbnails {
  padding-block: var(--padding-2xs);
}

slideshow-controls:not([controls-on-media]) {
  &:is([pagination-position='right']) {
    .slideshow-controls__thumbnails {
      padding-inline-end: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }

  &:is([pagination-position='left']) {
    .slideshow-controls__thumbnails {
      padding-inline-start: var(--slideshow-thumbnails-padding-inline, var(--focus-outline-offset));
    }
  }
}

slideshow-controls[controls-on-media] {
  z-index: var(--layer-raised);

  &:has(.slideshow-controls__dots, .slideshow-controls__counter) {
    --color-foreground: #fff;
    --color-foreground-rgb: var(--color-white-rgb);
  }

  &[pagination-position='right'] {
    right: 0;
  }

  &[pagination-position='left'] {
    left: 0;
  }

  &[pagination-position='center'] {
    width: 100%;
  }

  &:not([thumbnails])[pagination-position='left'] {
    width: fit-content;
    align-self: flex-start;
  }

  &:not([thumbnails])[pagination-position='right'] {
    width: fit-content;
    align-self: flex-end;
  }
}

slideshow-controls:is([pagination-position='right'], [pagination-position='left']) {
  .slideshow-controls__thumbnails {
    flex-direction: column;
  }
}

.slideshow-controls__arrows {
  display: flex;
  justify-content: space-between;
  height: var(--minimum-touch-target);
  grid-area: arrows;

  button {
    padding: 0 var(--padding-xs);
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  list-style: none;

  button {
    --color: rgb(var(--color-foreground-rgb) / var(--opacity-30));
    --color-active: var(--color-foreground);
    --color-hover: rgb(var(--color-foreground-rgb) / var(--opacity-50));
  }
}

slideshow-controls:has(.slideshow-controls__dots),
slideshow-component[autoplay] slideshow-controls {
  mix-blend-mode: difference;
}

.slideshow-controls__dots {
  gap: 0.6rem;
  padding: var(--padding-sm) var(--padding-lg);
  border-radius: 3rem;
  overflow: hidden;

  button {
    --size: 0.5rem;

    display: flex;
    align-items: center;
    justify-content: center;
    width: calc(var(--size) * 2);
    height: calc(var(--size) * 2);
    margin: calc(var(--size) / -2);
    font-size: 0;
    border-radius: calc(var(--size));

    &::after {
      content: '';
      display: block;
      background-color: var(--color);
      height: var(--size);
      width: var(--size);

      /* This is at --size / 2 to remove a visual regression on subpixel rendering displays */
      border-radius: calc(var(--size) / 2);

      @supports not (view-timeline-axis: inline) {
        &[aria-selected='true'] {
          --color: var(--color-active);
        }
      }

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

    &[aria-selected='true'] {
      --color: var(--color-active);
    }
  }
}

.slideshow-controls__dots,
.slideshow-controls__counter {
  &:only-child {
    margin-inline: auto;
  }
}

.slideshow-controls__counter {
  color: var(--color-foreground);
  background-color: rgb(0 0 0 / 40%);
  width: auto;
  border-radius: 2rem;
  padding: 0.3rem var(--padding-sm);
  margin-inline: var(--margin-sm);
  backdrop-filter: blur(10px);
  font-variant-numeric: tabular-nums;
  font-size: var(--font-size--xs);

  .slash {
    color: rgb(var(--color-foreground-rgb) / var(--opacity-40));
    padding-inline: var(--padding-2xs);
    margin-block-start: -0.1rem;
  }
}

.slideshow-control[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.slideshow-control--large {
  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .icon-caret {
    --icon-stroke-width: 1px;
  }

  .svg-wrapper,
  svg {
    width: var(--slideshow-controls-icon);
    height: var(--slideshow-controls-icon);
  }
}

/* Slideshow control shape styles */
.button-unstyled.slideshow-control.slideshow-control--shape-square,
.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  display: flex;
  align-items: center;
  justify-content: center;
  aspect-ratio: 1 / 1;
  background-color: var(--color-primary-button-background);
  color: var(--color-primary-button-text);
}

.button-unstyled.slideshow-control.slideshow-control--shape-circle {
  border-radius: 50%;
}

.button-unstyled.slideshow-control.slideshow-control--shape-square {
  border-radius: 0;
}

.slideshow-control .icon-caret {
  rotate: -90deg;
}

/* Slideshow Thumbnails */
.slideshow-controls__thumbnails-container {
  display: flex;
  width: 100%;
  max-height: 100%;
  overflow-x: scroll;
  scrollbar-width: none;
}

.slideshow-controls__thumbnails {
  display: inline-flex;
  padding-inline: var(--slideshow-thumbnails-padding-inline, var(--padding-sm));
  padding-block: var(--slideshow-thumbnails-padding-block, var(--padding-sm));
  gap: var(--gap-xs);
  margin-inline: auto;
  height: fit-content;

  .slideshow-control {
    border-radius: var(--media-radius);
    width: clamp(44px, 7vw, var(--thumbnail-width));
    height: auto;
    aspect-ratio: var(--aspect-ratio);

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

    &: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));
    }
  }
}

.slideshow-controls__thumbnail {
  position: relative;
}

.slideshow-controls__thumbnail-badge {
  position: absolute;
  top: var(--padding-2xs);
  right: var(--padding-2xs);
  width: clamp(16px, 10%, 20px);
  height: clamp(16px, 10%, 20px);
  background-color: var(--color-background);
  border-radius: var(--style-border-radius-xs);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 0 1px rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

.slideshow-controls__thumbnail-badge svg {
  width: 60%;
  height: 60%;
  fill: var(--color-foreground);
  opacity: 0.6;
}

/* 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);
  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);
}

.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);
  }
}

.media-gallery--carousel slideshow-arrows .slideshow-control {
  opacity: 1;
}

: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;
  }
}

.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 {
  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 {
  @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);
    }

    &: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%);
  }
/* ==========================================================================
   SOULTENTIC - PRODUCT GALLERY FIT + ZOOM FIX (properly scoped)
   Paste at VERY END of base.css
   ========================================================================== */

/* ---------------------------
   A) PRODUCT PAGE GALLERY ONLY
   (This prevents giant images WITHOUT clipping tops)
---------------------------- */

/* Scope ONLY to the real product gallery component */
body[data-template*="product"] media-gallery .product-media-container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 100% !important;
  max-height: 80vh !important;     /* tweak 75–85vh */
  overflow: hidden !important;     /* keep layout tidy */
  aspect-ratio: auto !important;
}

/* Make the image respect the container height so it can't get cropped */
body[data-template*="product"] media-gallery .product-media-container img {
  width: auto !important;
  max-width: 100% !important;

  height: auto !important;
  max-height: 100% !important;     /* crucial: prevents “top haircut” */
  object-fit: contain !important;
  object-position: center center !important;
}

/* If your theme flips media-fit to cover, force contain on PDP */
body[data-template*="product"] media-gallery .product-media-container.media-fit img {
  object-fit: contain !important;
}

/* On mobile, don't force 80vh if the theme uses constrain-height */
@media screen and (max-width: 749px) {
  body[data-template*="product"] media-gallery .product-media-container.constrain-height {
    max-height: none !important;
  }
}


/* ---------------------------
   B) ZOOM DIALOG ONLY
   (This fixes cropping in the modal, because it was still inheriting PDP rules)
---------------------------- */

/* Reset any PDP constraints inside the zoom dialog */
zoom-dialog dialog .product-media-container {
  max-height: none !important;
  overflow: visible !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  aspect-ratio: auto !important;
}

/* Ensure the zoomed image fits the viewport */
zoom-dialog dialog .product-media-container img {
  width: auto !important;
  height: auto !important;
  max-width: 92vw !important;
  max-height: 92vh !important;
  object-fit: contain !important;
  object-position: center center !important;
}

/* Keep your zoom dialog styling (transparent panel + blurred backdrop) */
zoom-dialog dialog {
  background: transparent !important;
}

zoom-dialog dialog::backdrop {
  background: rgba(0,0,0,0.55) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
/* ==========================================================================
   SOULTENTIC - STOP “OPEN IMAGE IN NEW TAB” (disable broken zoom)
   Paste at VERY END of base.css
   ========================================================================== */

/* If the theme wraps product media in <a href="...image...">, prevent navigation */
body[data-template*="product"] media-gallery .product-media-container > a {
  pointer-events: none !important;   /* stops clicking the link */
  cursor: default !important;
}

/* Also ensure the image itself doesn't behave like a link */
body[data-template*="product"] media-gallery .product-media-container > a img,
body[data-template*="product"] media-gallery .product-media-container img {
  cursor: default !important;
}

/* Hide the zoom overlay button (prevents “zoom-in” cursor + click trap) */
body[data-template*="product"] media-gallery .product-media-container__zoom-button {
  display: none !important;
}

/* Safety: if any element forces zoom cursor, kill it */
body[data-template*="product"] media-gallery .product-media-container {
  cursor: default !important;
}
/* ==========================================================================
   SOULTENTIC - ZOOM MODAL: FIT IMAGE TO SCREEN (NO CROP)
   Paste at VERY END of base.css
   ========================================================================== */

/* Make the zoom dialog layout center the active media */
.dialog-zoomed-gallery slideshow-slides,
.dialog-zoomed-gallery slideshow-container,
.dialog-zoomed-gallery slideshow-slide {
  height: 100vh !important;
  min-height: 0 !important;
}

/* Center the slide content */
.dialog-zoomed-gallery slideshow-slide {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Let the media wrapper breathe and stop clipping */
.dialog-zoomed-gallery .product-media-container,
.dialog-zoomed-gallery .product-media,
.dialog-zoomed-gallery deferred-media,
.dialog-zoomed-gallery .deferred-media__poster-button {
  width: 100% !important;
  height: 100% !important;
  max-height: 100vh !important;
  overflow: visible !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* The theme is likely forcing cover + height:100% somewhere (deferred-media img).
   Override all images inside the zoom dialog to FIT, not CROP. */
.dialog-zoomed-gallery img {
  width: auto !important;
  height: auto !important;
  max-width: 96vw !important;
  max-height: 96vh !important;
  object-fit: contain !important;
  object-position: center center !important;
}

/* Extra safety: if the theme sets "cover" on the poster image specifically */
.dialog-zoomed-gallery .deferred-media__poster-button img,
.dialog-zoomed-gallery deferred-media img {
  width: auto !important;
  height: auto !important;
  max-width: 96vw !important;
  max-height: 96vh !important;
  object-fit: contain !important;
  object-position: center center !important;
}

/* Keep the backdrop nice (and prevent any random white panel) */
zoom-dialog dialog {
  background: transparent !important;
}
zoom-dialog dialog::backdrop {
  background: rgba(0,0,0,0.55) !important;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}
/* ==========================================================================
   SOULTENTIC - Zoom modal: centered image + thumbnails underneath + pan/zoom
   Paste at VERY END of base.css
   ========================================================================== */

/* Make the zoom dialog a real modal with blur */
zoom-dialog dialog[open]{
  background: transparent !important;
  border: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  max-width: 100% !important;
  max-height: 100% !important;
}

zoom-dialog dialog::backdrop{
  background: rgba(0,0,0,0.55) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

/* Center the active image area */
zoom-dialog dialog .product-media{
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  height: 100vh !important;
  width: 100vw !important;
  padding: 64px 64px 140px 64px !important; /* bottom space for thumbnails */
  box-sizing: border-box !important;
}

/* The image container: allow panning (scroll) in zoom mode */
zoom-dialog dialog .product-media-container{
  width: 100% !important;
  height: 100% !important;
  max-width: 1100px !important;
  max-height: calc(100vh - 220px) !important;
  overflow: hidden !important; /* normal mode: no scroll */
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Default in modal: fit image fully */
zoom-dialog dialog .product-media-container img{
  width: auto !important;
  height: auto !important;
  max-width: 92vw !important;
  max-height: calc(100vh - 220px) !important;
  object-fit: contain !important;
  object-position: center center !important;
  cursor: zoom-in !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}

/* Thumbnails UNDER the image (even on desktop) */
.dialog-thumbnails-list-container{
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 18px !important;
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  z-index: 99999 !important;
  pointer-events: none; /* so only the strip itself handles clicks */
}

.dialog-thumbnails-list{
  pointer-events: auto !important;
  display: inline-flex !important;
  flex-direction: row !important;
  gap: 10px !important;
  padding: 10px 14px !important;
  border-radius: 999px !important;
  background: rgba(0,0,0,0.35) !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  max-width: min(1100px, 92vw) !important;
  overflow-x: auto !important;
  scrollbar-width: none !important;
}

.dialog-thumbnails-list::-webkit-scrollbar{ display:none !important; }

/* Override theme that tries to put thumbnails on the right on desktop */
@media (min-width: 750px){
  .dialog-thumbnails-list{
    position: static !important;
    inset: auto !important;
    max-height: none !important;
    overflow-y: hidden !important;
  }
}

/* Zoomed state (toggled by JS below) */
zoom-dialog dialog.st-zoomed .product-media-container{
  overflow: auto !important;          /* allow pan */
  max-width: 92vw !important;
  max-height: calc(100vh - 220px) !important;
  cursor: grab !important;
}

zoom-dialog dialog.st-zoomed .product-media-container:active{
  cursor: grabbing !important;
}

zoom-dialog dialog.st-zoomed .product-media-container img{
  max-width: none !important;
  max-height: none !important;
  width: auto !important;
  height: auto !important;
  transform: scale(2);               /* zoom level */
  transform-origin: center center;
  cursor: grab !important;
}

/* Make sure close button stays usable */
zoom-dialog dialog .close-button{
  position: fixed !important;
  top: 18px !important;
  right: 18px !important;
  z-index: 100000 !important;
}
/* --- SOULTENTIC: Quick view / media modal layout fix --- */

/* Make modal content use viewport height */
.quick-add-modal__content,
.product-media-modal__content,
.media-modal__content,
.modal__content {
  height: min(90vh, 900px);
}

/* Ensure the media area expands and centers the image */
.quick-add-modal__media,
.product-media-modal__media,
.media-modal__media,
.modal__media {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-height: 0;
}

/* Make the main image actually fill the space above thumbnails */
.quick-add-modal__media img,
.product-media-modal__media img,
.media-modal__media img,
.modal__media img {
  width: 100%;
  height: auto;
  max-height: calc(90vh - 160px); /* leaves room for thumbnails */
  object-fit: contain;
}

/* Thumbnails stay visible and don’t steal space */
.quick-add-modal__thumbnails,
.product-media-modal__thumbnails,
.media-modal__thumbnails,
.modal__thumbnails {
  flex: 0 0 auto;
  margin-top: 12px;
}

/* --- Kill hover-follow zoom if theme uses CSS-based zoom --- */
[data-zoom-on-hover="true"] img,
.zoom-hover img,
.product__media--hover-zoom img {
  transform: none !important;
}
/* --- SOULTENTIC: Quick view / media modal layout fix --- */

/* Make modal content use viewport height */
.quick-add-modal__content,
.product-media-modal__content,
.media-modal__content,
.modal__content {
  height: min(90vh, 900px);
}

/* Ensure the media area expands and centers the image */
.quick-add-modal__media,
.product-media-modal__media,
.media-modal__media,
.modal__media {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-height: 0;
}

/* Make the main image fill the space above thumbnails */
.quick-add-modal__media img,
.product-media-modal__media img,
.media-modal__media img,
.modal__media img {
  width: 100%;
  height: auto;
  max-height: calc(90vh - 160px); /* leaves room for thumbnails */
  object-fit: contain;
}

/* Thumbnails: keep them bottom and visible */
.quick-add-modal__thumbnails,
.product-media-modal__thumbnails,
.media-modal__thumbnails,
.modal__thumbnails {
  flex: 0 0 auto;
  margin-top: 12px;
}

/* Kill hover-follow zoom if theme uses CSS-based zoom */
[data-zoom-on-hover="true"] img,
.zoom-hover img,
.product__media--hover-zoom img,
.product-media--hover-zoom img {
  transform: none !important;
}
/* ================================
   SOULTENTIC: Full-height image modal + clean thumbnails
   Targets Horizon product media (.product-media__image)
   ================================ */

/* When your script adds this class, we apply the layout rules */
body.st-modal-open {
  overflow: hidden;
}

/* Make the popup content act like: [BIG IMAGE] over [THUMBNAILS] */
body.st-modal-open dialog[open],
body.st-modal-open [role="dialog"] {
  height: 92vh !important;
}

/* Big image should fill available height */
body.st-modal-open .product-media__image {
  width: 100% !important;
  height: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
}

/* Force the media viewer area to take all space above thumbnails */
body.st-modal-open .product-media,
body.st-modal-open .product-media__container,
body.st-modal-open .product-media__viewer,
body.st-modal-open .product-media-modal,
body.st-modal-open .product-media-modal__content,
body.st-modal-open .media-modal__content,
body.st-modal-open .modal__content {
  height: 92vh !important;
}

/* Try to convert the modal content into a 2-row layout */
body.st-modal-open .product-media-modal__content,
body.st-modal-open .media-modal__content,
body.st-modal-open .modal__content {
  display: grid !important;
  grid-template-rows: 1fr auto !important;
  align-items: stretch !important;
}

/* Media area: grow and center */
body.st-modal-open .product-media-modal__media,
body.st-modal-open .media-modal__media,
body.st-modal-open .modal__media,
body.st-modal-open .product-media__media,
body.st-modal-open .product-media__main {
  min-height: 0 !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Thumbnails strip sizing consistency */
body.st-modal-open .product-media__thumbnails,
body.st-modal-open .product-media-thumbnails,
body.st-modal-open .thumbnails,
body.st-modal-open [class*="thumbnail"] {
  display: flex !important;
  gap: 10px !important;
  overflow-x: auto !important;
  padding: 12px 16px 18px !important;
  align-items: center !important;
}

/* Force every thumb to be the same size (selected included) */
body.st-modal-open .product-media__thumbnails > *,
body.st-modal-open .product-media-thumbnails > *,
body.st-modal-open .thumbnails > * {
  flex: 0 0 auto !important;
  width: 78px !important;
  height: 78px !important;
  border-radius: 12px !important;
}

body.st-modal-open .product-media__thumbnails img,
body.st-modal-open .product-media-thumbnails img,
body.st-modal-open .thumbnails img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: none !important;
}

/* Stop active/selected thumb scaling effects */
body.st-modal-open .is-active,
body.st-modal-open .is-selected,
body.st-modal-open [aria-current="true"] {
  transform: none !important;
}
/* ================================
   SOULTENTIC: Thumbnail sizing lock
   Prevent active/selected thumb scaling
   ================================ */

body.st-modal-open .product-media__thumbnails,
body.st-modal-open .product-media-thumbnails,
body.st-modal-open .thumbnails {
  display: flex !important;
  gap: 10px !important;
  overflow-x: auto !important;
  padding: 12px 16px 18px !important;
  align-items: center !important;
}

body.st-modal-open .product-media__thumbnails > *,
body.st-modal-open .product-media-thumbnails > *,
body.st-modal-open .thumbnails > *,
body.st-modal-open [class*="thumb"] > * {
  flex: 0 0 auto !important;
  width: 78px !important;
  height: 78px !important;
  max-width: 78px !important;
  max-height: 78px !important;
  transform: none !important;
}

body.st-modal-open .product-media__thumbnails img,
body.st-modal-open .product-media-thumbnails img,
body.st-modal-open .thumbnails img,
body.st-modal-open [class*="thumb"] img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transform: none !important;
}

/* Kill every common "active thumb scales up" pattern */
body.st-modal-open .is-active,
body.st-modal-open .is-selected,
body.st-modal-open [aria-current="true"],
body.st-modal-open .swiper-slide-thumb-active,
body.st-modal-open .splide__slide.is-active {
  transform: none !important;
}

body.st-modal-open .is-active img,
body.st-modal-open .is-selected img,
body.st-modal-open [aria-current="true"] img,
body.st-modal-open .swiper-slide-thumb-active img,
body.st-modal-open .splide__slide.is-active img {
  transform: none !important;
}
/* SOULTENTIC menu icon safety styles */
.header .header__icon--menu::before,
.header button[aria-label="Menu"]::before,
.header button[aria-label="Open menu"]::before,
.header button[aria-controls*="menu"]::before,
.header button[aria-controls*="Menu"]::before {
  width: 24px;
  height: 24px;
}

.header .header__icon--menu,
.header button[aria-label="Menu"],
.header button[aria-label="Open menu"],
.header button[aria-controls*="menu"],
.header button[aria-controls*="Menu"] {
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* If the fingerprint looks slightly off-center on mobile, this fixes it */
@media (max-width: 749px) {
  .header .header__icon--menu::before,
  .header button[aria-label="Menu"]::before,
  .header button[aria-label="Open menu"]::before,
  .header button[aria-controls*="menu"]::before,
  .header button[aria-controls*="Menu"]::before {
    width: 22px;
    height: 22px;
  }
}
/* --- Force footer to bottom of viewport on short pages --- */
html, body {
  height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

#MainContent {
  flex: 1 0 auto;
}

footer, .footer {
  margin-top: auto;
}
/* --- Make sure footer is not overlaying/absolute/fixed --- */
.shopify-section-group-footer-group,
footer,
.footer {
  position: relative !important;
  bottom: auto !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  transform: none !important;
  z-index: 1 !important;
  margin-top: 0 !important;
}

/* --- Stick footer to bottom when content is short (Shopify-safe selectors) --- */
html, body {
  height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* Shopify main content containers (covers most themes) */
#MainContent,
main,
.main-content,
.content-for-layout {
  flex: 1 0 auto;
}

/* Shopify footer group wrapper in OS2.0 themes */
.shopify-section-group-footer-group,
footer,
.footer {
  margin-top: auto;
  flex: 0 0 auto;
}
/* Force footer to bottom when content is short */
.site-body{
  min-height:100vh;
  display:flex;
  flex-direction:column;
}

/* This theme often uses content-for-layout or #MainContent */
#MainContent,
main,
.content-for-layout{
  flex:1 0 auto;
}

.shopify-section-group-footer-group,
footer.section-wrapper{
  margin-top:auto;
}
/* ✅ Stop homepage content (GemPages) from sitting behind the footer */
#MainContent {
  position: relative;
  z-index: 1;
}

/* ✅ Force the footer to be above everything and not transparent/bleeding */
.shopify-section-group-footer-group,
footer.section-wrapper {
  position: relative !important;
  z-index: 999 !important;
  background: #000 !important;
}

/* ✅ Add spacing so the last content doesn't visually collide with footer */
#MainContent > :last-child {
  margin-bottom: 80px;
}
html, body { height: 100%; }

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

#MainContent {
  flex: 1 0 auto;
}
/* ================================
   FIX: Footer overlapping homepage
   (GemPages content showing under footer)
   ================================ */

/* 1) Ensure footer is in normal document flow */
.shopify-section-group-footer-group,
footer.section-wrapper,
.shopify-section-group-footer-group footer.section-wrapper {
  position: static !important;   /* not absolute/fixed */
  transform: none !important;    /* kill translateY tricks */
  margin-top: 0 !important;      /* kill negative margins pulling it up */
  top: auto !important;
  bottom: auto !important;
}

/* 2) Give footer a solid background so nothing "bleeds" through */
.shopify-section-group-footer-group,
footer.section-wrapper {
  background: #000 !important;
  z-index: 10 !important;
}

/* 3) Force space at the end of the page so content cannot sit under footer */
#MainContent {
  padding-bottom: 260px !important; /* adjust if your footer is taller/shorter */
}

/* 4) If the section right above the footer has a negative margin-bottom, neutralize it */
#MainContent > :last-child {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* Optional: slightly smaller space on mobile */
@media (max-width: 749px) {
  #MainContent {
    padding-bottom: 220px !important;
  }
}
/* =========================================================
   HARD FIX: GemPages homepage layer overlapping the footer
   Your homepage section ID: gp_section_603314335191663391
   We force positioned layers inside it back into normal flow.
   ========================================================= */

/* Target the specific GP section reliably (ID and class patterns) */
#gp_section_603314335191663391,
[id*="gp_section_603314335191663391"],
.gp-section-603314335191663391,
[class*="gp-section-603314335191663391"]{
  position: relative !important;
  z-index: 1 !important;
}

/* GemPages sometimes makes text/buttons "float" via absolute/fixed.
   This is what causes "Limited pieces. Numbered." to sit over the footer. */
#gp_section_603314335191663391 * ,
[id*="gp_section_603314335191663391"] * ,
.gp-section-603314335191663391 * ,
[class*="gp-section-603314335191663391"] * {
  z-index: auto !important;
}

/* Kill the real culprits: absolute/fixed positioning inside that GP section */
#gp_section_603314335191663391 *[style*="position:fixed"],
#gp_section_603314335191663391 *[style*="position: fixed"],
#gp_section_603314335191663391 *[style*="position:absolute"],
#gp_section_603314335191663391 *[style*="position: absolute"],
[id*="gp_section_603314335191663391"] *[style*="position:fixed"],
[id*="gp_section_603314335191663391"] *[style*="position:absolute"]{
  position: static !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
}

/* Make footer an isolated stacking context so nothing paints over it */
.shopify-section-group-footer-group,
footer.section-wrapper,
.shopify-section-group-footer-group footer.section-wrapper{
  position: relative !important;
  z-index: 999999 !important;
  background: #000 !important;
  isolation: isolate !important;
}
/* =========================================================
   FORCE FOOTER BACK INTO NORMAL FLOW (kills floating footer)
   ========================================================= */

/* The footer group wrapper (Shopify OS 2.0 section group) */
.shopify-section-group-footer-group {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
  height: auto !important;
  min-height: 0 !important;
}

/* The inner wrapper is often what gets position:fixed / sticky */
.shopify-section-group-footer-group footer,
.shopify-section-group-footer-group .section-wrapper,
.shopify-section-group-footer-group .section,
.shopify-section-group-footer-group [class*="footer"] {
  position: static !important;
  inset: auto !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
  height: auto !important;
  min-height: 0 !important;
  width: 100% !important;
}

/* If the theme uses sticky/fixed behavior via these */
.shopify-section-group-footer-group * {
  scroll-margin: 0 !important;
}

/* Make sure nothing is forcing it to float with z-index games */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group footer,
.shopify-section-group-footer-group .section-wrapper {
  z-index: auto !important;
}
/* =========================================
   FOOTER CLEANUP: spacing + visibility
   ========================================= */

/* Tighten excessive footer padding */
.shopify-section-group-footer-group footer.section-wrapper .section-content-wrapper {
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

/* Make footer text readable */
.shopify-section-group-footer-group footer.section-wrapper,
.shopify-section-group-footer-group footer.section-wrapper * {
  color: #fff !important;
}

/* Reduce that "Terms and Policies" line spacing */
.shopify-section-group-footer-group .footer-utilities,
.shopify-section-group-footer-group .footer-utilities * {
  line-height: 1.4 !important;
}

/* Center payment icons area nicely */
.shopify-section-group-footer-group .payment-icons {
  justify-content: center !important;
}
/* TEMP: hide unexpected blank block above footer on homepage only */
body.template-index #MainContent > div:empty,
body.template-index #MainContent section:empty {
  display: none !important;
}
/* =========================================================
   Hide GemPages "footer-like" strip if it appears at the TOP
   (payment icons row showing as a header)
   ========================================================= */

/* GemPages wrappers */
.gempages, .gem-page, .gp-page {
  position: relative;
}

/* If a GemPages payment-icons block is near the top, hide it */
.gempages .payment-icons,
.gem-page .payment-icons,
.gp-page .payment-icons {
  display: none !important;
}

/* Keep the real Shopify footer payment icons visible */
.shopify-section-group-footer-group .payment-icons {
  display: flex !important;
}
/* =========================================================
   SOULTENTIC - SAFE FIXES (no layout nuking)
   Header: force visible white icons/links
   Footer: force readable text + centered layout
   ========================================================= */

/* Keep page background black (safe) */
html, body { background: #000; margin: 0; padding: 0; }

/* ---------- HEADER: make menu + icons visible ---------- */
.shopify-section-group-header-group,
.shopify-section-group-header-group header,
.shopify-section-group-header-group .header {
  background: transparent !important;
}

/* Menu links */
.shopify-section-group-header-group a,
.shopify-section-group-header-group nav a {
  color: #fff !important;
}

/* Icons (SVG) */
.shopify-section-group-header-group svg,
.shopify-section-group-header-group svg * {
  fill: #fff !important;
  stroke: #fff !important;
}

/* If theme uses buttons for icons */
.shopify-section-group-header-group button,
.shopify-section-group-header-group .icon,
.shopify-section-group-header-group .header__icon {
  color: #fff !important;
}

/* Prevent “selected item becomes invisible” weirdness */
.shopify-section-group-header-group * {
  mix-blend-mode: normal !important;
}

/* ---------- REMOVE THE WHITE LINE / GAP AT TOP ---------- */
#MainContent { margin-top: 0 !important; padding-top: 0 !important; }
#MainContent > .shopify-section:first-child { margin-top: 0 !important; }

/* ---------- FOOTER: readable text WITHOUT breaking font ---------- */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group footer {
  background: #000 !important;
  color: #fff !important;
}

/* Only set color. Do NOT touch font family/size here. */
.shopify-section-group-footer-group a,
.shopify-section-group-footer-group p,
.shopify-section-group-footer-group li,
.shopify-section-group-footer-group small,
.shopify-section-group-footer-group span {
  color: #fff !important;
}

/* Center the common footer areas */
.shopify-section-group-footer-group footer,
.shopify-section-group-footer-group .section-wrapper {
  text-align: center !important;
}

/* Center lists (policy links / social links often render as UL) */
.shopify-section-group-footer-group ul {
  list-style: none;
  padding-left: 0;
  margin-left: 0;
}

/* If links are displayed inline or flex, center them */
.shopify-section-group-footer-group ul,
.shopify-section-group-footer-group .list-social,
.shopify-section-group-footer-group .policies,
.shopify-section-group-footer-group .footer__policies,
.shopify-section-group-footer-group .footer__list-social {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Center payment icons */
.shopify-section-group-footer-group .payment-icons,
.shopify-section-group-footer-group .list-payment,
.shopify-section-group-footer-group [class*="payment"] {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

/* Softer dividers */
.shopify-section-group-footer-group hr,
.shopify-section-group-footer-group .divider,
.shopify-section-group-footer-group [class*="divider"] {
  border-color: rgba(255,255,255,0.25) !important;
}
/* --- SOULTENTIC: header rescue patch (desktop) --- */
@media screen and (min-width: 990px) {
  /* Dawn/Horizon-like header containers */
  .header,
  header .header,
  .section-header .header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
  }

  /* Stop desktop menu stacking vertically */
  .header__inline-menu,
  nav.header__inline-menu,
  .header .menu {
    display: flex !important;
    align-items: center !important;
  }

  .header__inline-menu ul,
  .header .menu ul,
  .header nav ul {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .header__inline-menu li,
  .header .menu li,
  .header nav li {
    margin: 0 !important;
  }

  /* Make sure the icons area exists + aligns right */
  .header__icons,
  .header .header__icons,
  .header .icons,
  .header__icon {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
  }

  /* Prevent “drawer menu” styles from leaking into desktop nav */
  .menu-drawer,
  .menu-drawer__menu,
  .menu-drawer__navigation {
    display: none;
  }
}/* ==============================
   FIX: Restore theme utility classes used by header markup
   (mobile:hidden, desktop:hidden)
   ============================== */

/* Mobile = up to 749px */
@media screen and (max-width: 749px) {
  .mobile\:hidden { display: none !important; }
  .desktop\:hidden { display: initial !important; }
}

/* Desktop = 750px and up */
@media screen and (min-width: 750px) {
  .desktop\:hidden { display: none !important; }
  .mobile\:hidden { display: initial !important; }
}
/* --- Utility visibility classes (required by this theme) --- */
@media screen and (max-width: 749px) {
  .mobile\:hidden { display: none !important; }
  .desktop\:hidden { display: initial !important; }
}
@media screen and (min-width: 750px) {
  .desktop\:hidden { display: none !important; }
  .mobile\:hidden { display: initial !important; }
}
/* --- SOULTENTIC: Desktop inline menu, Mobile drawer toggle --- */

/* Desktop: hide any menu toggle buttons (hamburger/fingerprint) */
@media screen and (min-width: 750px) {
  .header__icon--menu,
  button.header__icon--menu,
  .menu-drawer__toggle,
  button[aria-controls='menu-drawer'],
  button[aria-controls*='menu-drawer'],
  button[aria-controls*='header-menu'] {
    display: none !important;
  }

  /* Ensure inline menu stays horizontal */
  header-menu,
  header-menu .menu-list,
  header-menu .menu-list__list,
  header-menu nav,
  header-menu ul {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 16px !important;
  }

  header-menu li {
    margin: 0 !important;
  }
}

/* Mobile: show toggle, hide inline menu list */
@media screen and (max-width: 749px) {
  /* Ensure the toggle exists and is clickable */
  .header__icon--menu,
  button.header__icon--menu,
  .menu-drawer__toggle,
  button[aria-controls='menu-drawer'],
  button[aria-controls*='menu-drawer'],
  button[aria-controls*='header-menu'] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* Hide inline menu items so you don't get stacked links */
  header-menu .menu-list,
  header-menu .menu-list__list,
  header-menu nav,
  header-menu ul {
    display: none !important;
  }
}
/* Center "Terms and Policies" / policy links in footer */
footer .footer-utilities,
footer .footer__utilities,
footer .footer-utilities__inner,
footer .footer__utilities__inner {
  justify-content: center !important;
}

footer .policy-links,
footer .footer__policy,
footer .footer__policy-links,
footer .footer__policies,
footer .footer__menu--policies,
footer nav[aria-label*="policy"],
footer nav[aria-label*="Policy"],
footer a[href*="/policies/"] {
  text-align: center !important;
}

/* If they’re in a list, center the list items too */
footer ul:has(a[href*="/policies/"]),
footer .policy-links ul,
footer .footer__policy-links ul {
  display: flex !important;
  justify-content: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  padding-left: 0 !important;
  margin: 0 auto !important;
  list-style: none !important;
}
/* ===== FORCE-CENTER: "Terms and Policies" (Policy links block) ===== */

/* 1) Make footer utility areas center their content */
#shopify-section-footer footer,
#shopify-section-footer,
.shopify-section--footer footer,
.shopify-section--footer {
  text-align: center;
}

#shopify-section-footer :is(.footer, .footer__content, .footer__blocks, .footer__utilities, .footer-utilities, .footer__bottom, .footer-bottom) {
  justify-content: center !important;
}

/* 2) Target the POLICY LINKS block by what it contains: /policies/ URLs */
#shopify-section-footer :is(div, nav, section, ul):has(a[href*="/policies/"]) {
  width: 100% !important;
  text-align: center !important;
  justify-self: center !important;   /* grid layouts */
  align-self: center !important;
}

/* 3) Center the actual list of policy links if it’s a list */
#shopify-section-footer ul:has(a[href*="/policies/"]) {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin: 0 auto !important;
  padding: 0 !important;
  list-style: none !important;
}

/* 4) Center the heading/title inside that same block ("Terms and Policies") */
#shopify-section-footer :is(h1,h2,h3,h4,p,span,div):has(+ * a[href*="/policies/"]),
#shopify-section-footer :is(h1,h2,h3,h4,.footer__heading,.footer-block__heading):has(~ * a[href*="/policies/"]) {
  text-align: center !important;
  width: 100% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 5) If the theme uses grid, force the policy block to span full width */
#shopify-section-footer :is(div, nav, section):has(a[href*="/policies/"]) {
  grid-column: 1 / -1 !important;
}
/* ===== FIX: Center "Terms and Policies" in footer utilities ===== */
.footer-utilities.spacing-style {
  justify-content: center !important;
  text-align: center !important;
}

/* If the utilities container uses flex children, center them */
.footer-utilities.spacing-style > * {
  margin-left: auto !important;
  margin-right: auto !important;
}

/* If Terms & Policies is a list/menu, center the list */
.footer-utilities.spacing-style ul,
.footer-utilities.spacing-style nav ul {
  display: flex !important;
  justify-content: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  margin: 0 auto !important;
  padding: 0 !important;
  list-style: none !important;
}

/* Center the text/title itself */
.footer-utilities.spacing-style :is(h1,h2,h3,h4,p,span,a) {
  text-align: center !important;
}
/* ===== HARD FIX: center the footer utilities on mobile/desktop ===== */

/* Your exact container */
.footer-utilities.spacing-style {
  display: flex !important;
  flex-direction: column !important;   /* keep column if theme wants it */
  align-items: center !important;      /* <-- horizontal centering in column layout */
  justify-content: center !important;
  text-align: center !important;
}

/* Stop any child from forcing left alignment */
.footer-utilities.spacing-style > * {
  align-self: center !important;
  text-align: center !important;
}

/* If "Terms and Policies" is a list/menu, center it */
.footer-utilities.spacing-style ul,
.footer-utilities.spacing-style nav ul {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
  padding: 0 !important;
  margin: 0 auto !important;
  list-style: none !important;
}
/* ===== SOULTENTIC: Center "Terms and Policies" on DESKTOP ===== */
@media screen and (min-width: 750px) {
  /* The container you inspected */
  .footer-utilities.spacing-style {
    justify-content: center !important; /* row centering */
    align-items: center !important;
    text-align: center !important;
  }

  /* Center the *policies* block specifically (works whether it's a link, nav, or wrapper) */
  .footer-utilities.spacing-style :is(div, nav, section, ul):has(a[href*="/policies/"]) {
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    justify-self: center !important;   /* grid */
    align-self: center !important;     /* flex */
    text-align: center !important;
  }

  /* If it's a list of policy links, center the list */
  .footer-utilities.spacing-style ul:has(a[href*="/policies/"]) {
    display: flex !important;
    justify-content: center !important;
    gap: 14px !important;
    flex-wrap: wrap !important;
    margin: 0 auto !important;
    padding: 0 !important;
    list-style: none !important;
  }

  /* If it's just a single "Terms and Policies" link/title, center it too */
  .footer-utilities.spacing-style a[href*="/policies/"] {
    display: inline-block !important;
    margin: 0 auto !important;
    text-align: center !important;
  }
}
@media screen and (min-width: 750px) {
  .footer-utilities.spacing-style {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .footer-utilities.spacing-style .policy-list-trigger {
    flex: 0 0 100% !important;   /* puts it on its own centered row */
    text-align: center !important;
    margin: 0 auto !important;
  }
}
/* ===== FORCE: center the Terms & Policies trigger on desktop ===== */
@media screen and (min-width: 750px) {
  /* The actual element you inspected */
  footer button.policy-list-trigger[popovertarget="terms-policies-popover"] {
    width: 100% !important;              /* take the whole row */
    display: flex !important;            /* center via flex */
    justify-content: center !important;
    align-items: center !important;
    text-align: center !important;
    margin: 0 auto !important;
  }

  /* If some wrapper is doing grid/contents nonsense, make sure the container spans full width */
  footer .footer-utilities.spacing-style {
    width: 100% !important;
  }
}
@media screen and (min-width: 750px) {
  footer button.policy-list-trigger[popovertarget="terms-policies-popover"] {
    position: relative !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    width: max-content !important;
    display: inline-block !important;
    text-align: center !important;
  }
}
/* =========================================================
   FORCE STICKY HEADER (DESKTOP + MOBILE)
   ========================================================= */
#shopify-section-header,
.shopify-section-group-header-group,
header.section-header,
header.header,
.header-wrapper,
.header {
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

/* Some themes wrap the header in a sticky container */
.header-sticky,
.header-wrapper--sticky {
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

/* If any parent has overflow set, sticky can fail.
   This safely neutralizes common wrappers without touching the footer. */
html, body {
  overflow-x: clip;
}
/* Make sure header parents don't block sticky */
.shopify-section-group-header-group,
#shopify-section-header {
  overflow: visible !important;
}
/* =========================================================
   SOULTENTIC: FORCE FOOTER VISIBLE ON DESKTOP
   (only helps if footer exists in DOM)
   ========================================================= */
@media screen and (min-width: 750px) {
  .shopify-section-group-footer-group,
  footer.section-wrapper,
  footer.section-wrapper * {
    visibility: visible !important;
    opacity: 1 !important;
  }

  .shopify-section-group-footer-group,
  footer.section-wrapper {
    display: block !important;
    height: auto !important;
    min-height: 1px !important;
  }
}
/* =========================================================
   SOULTENTIC: STOP GEMPAGES DESKTOP FROM TRAPPING SCROLL
   (makes footer reachable on collection/product GP templates)
   ========================================================= */
html, body {
  height: auto !important;
  min-height: 100% !important;
  overflow-y: auto !important;
}

/* Common GemPages wrappers */
.gp-page,
.gp-wrapper,
.gp-container,
.gempages,
.gempages-wrapper,
.gempages-container,
#gempages-container,
[id*="gempages"],
[class*="gempages"],
[class*="gp-"] {
  height: auto !important;
  min-height: 0 !important;
  overflow: visible !important;
}

/* Make sure main content doesn't clip the footer */
main, #MainContent {
  overflow: visible !important;
  height: auto !important;
  min-height: 0 !important;
}

/* If something is positioning the footer strangely */
.shopify-section-group-footer-group,
footer.section-wrapper {
  position: relative !important;
  transform: none !important;
}
/* =========================================================
   SOULTENTIC: GEMPAGES COLLECTION/PRODUCT - FOOTER NOT REACHABLE (DESKTOP)
   Fix scroll traps + clipping wrappers so footer shows
   Paste in Assets -> base.css (BOTTOM)
   ========================================================= */

/* Target pages that are GemPages-built (common body/html markers) */
html[class*="gempages"], body[class*="gempages"],
body[class*="gp-"], html[class*="gp-"] {
  height: auto !important;
  min-height: 100% !important;
  overflow-y: auto !important;
}

/* Kill the classic "100vh + overflow" scroll prison */
.gp-page,
.gp-wrapper,
.gp-container,
.gempages,
.gempages-wrapper,
.gempages-container,
#gempages-container,
[id*="gempages"],
[class*="gempages"],
[class^="gp-"],
[class*=" gp-"] {
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow: visible !important;
}

/* Make sure the main wrappers don't clip the footer */
main,
#MainContent,
.content-for-layout,
.shopify-section,
.shopify-section-group-footer-group {
  overflow: visible !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

/* Ensure footer isn't getting hidden/flattened */
.shopify-section-group-footer-group,
footer.section-wrapper {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  z-index: 2 !important;
}
/* ================================
   GP / OS2: FIX FOOTER NOT REACHABLE / CLIPPED ON DESKTOP
   ================================ */
html, body {
  height: auto !important;
  min-height: 100% !important;
  overflow: visible !important;
}

body {
  position: static !important;
}

/* Kill scroll-trap containers (common in GP and some themes) */
#MainContent,
main,
#PageContainer,
#shopify-section-header,
.shopify-section,
.shopify-section-group-header-group,
.shopify-section-group-footer-group {
  overflow: visible !important;
  height: auto !important;
  min-height: 0 !important;
}

/* If something is clipping via transform, neutralize at the likely wrapper level */
#MainContent,
main {
  transform: none !important;
}

/* Last resort: ensure footer isn't collapsed */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group footer,
footer.section-wrapper {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  z-index: 2 !important;
}
/* =========================================================
   SOULTENTIC: FORCE FOOTER TO EXIST, BE VISIBLE, AND BE REACHABLE
   Fixes cases where GemPages/containers trap scroll or clip the footer.
   ========================================================= */

/* Make the whole page a normal document flow again */
html, body {
  height: auto !important;
  min-height: 100% !important;
  overflow-y: auto !important;
}

/* Kill the classic “100vh + overflow” trap on common wrappers */
#MainContent,
main,
.content-for-layout,
.gp-page,
.gp-wrapper,
.gp-container,
.gempages,
.gempages-wrapper,
.gempages-container,
#gempages-container,
[class*="gp-"],
[class*="gempages"] {
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

/* If something created a stacking context that sits on top of the footer */
#MainContent,
main,
.content-for-layout,
.gp-page,
.gp-wrapper,
.gp-container {
  position: relative !important;
  z-index: 0 !important;
}

/* FORCE the footer group to display and sit in normal flow */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group * {
  visibility: visible !important;
  opacity: 1 !important;
}

.shopify-section-group-footer-group {
  display: block !important;
  position: relative !important;
  height: auto !important;
  min-height: 1px !important;
  overflow: visible !important;
  z-index: 5 !important;
}

/* The actual footer element Shopify outputs for footer-group */
.shopify-section-group-footer-group footer,
footer.section-wrapper {
  display: block !important;
  position: relative !important;
  height: auto !important;
  min-height: 1px !important;
  overflow: visible !important;
  z-index: 5 !important;
}

/* Safety: if anything tries to “stick”/“fixed” the footer weirdly */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group footer,
footer.section-wrapper {
  transform: none !important;
  top: auto !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
}

/* Optional: if you want it black */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group footer,
footer.section-wrapper {
  background: #000 !important;
  color: #fff !important;
}
/* =========================================================
   MENU DRAWER (ROBUST)
   - Drawer: 80% width, solid black, NEVER blurred
   - Background: blurred + dimmed ONLY when drawer is open
   Works across Dawn + many variants
   ========================================================= */

/* Drawer: 80% */
.menu-drawer,
.menu-drawer__inner,
.menu-drawer__content,
.menu-drawer__navigation,
.menu-drawer__inner-container,
.menu-drawer__navigation-container {
  width: 80vw !important;
  max-width: 80vw !important;
  background: #000 !important;
  opacity: 1 !important;
}

/* Drawer always above overlays */
.menu-drawer {
  position: fixed !important;
  z-index: 1002 !important;
}

/* Drawer text */
.menu-drawer a,
.menu-drawer span,
.menu-drawer__menu-item {
  color: #fff !important;
}

/* Never blur inside drawer */
.menu-drawer,
.menu-drawer * {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* ---------- OVERLAY / BLUR LAYER (supports multiple theme structures) ---------- */

/* Base overlay style (OFF by default) */
.menu-drawer-container::before,
.menu-drawer-container > summary::before,
.menu-drawer__overlay {
  content: "" !important;
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.55) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.25s ease !important;
  z-index: 1000 !important; /* BELOW drawer */
}

/* Turn overlay ON when drawer is open */
.menu-drawer-container[open]::before,
.menu-drawer-container[open] > summary::before,
.menu-drawer-container[open] .menu-drawer__overlay {
  opacity: 1 !important;
  pointer-events: auto !important;
}

/* Some themes toggle an "active" class instead of [open] */
.menu-drawer-container.menu-opening::before,
.menu-drawer-container.menu-opening > summary::before,
.menu-drawer-container.menu-opening .menu-drawer__overlay,
.menu-drawer-container.menu-open::before,
.menu-drawer-container.menu-open > summary::before,
.menu-drawer-container.menu-open .menu-drawer__overlay {
  opacity: 1 !important;
  pointer-events: auto !important;
}
/* =========================================================
   CART DRAWER – STEP 1 (AMENDED)
   Force black background ONLY
   No positioning, no transforms, no blur
   ========================================================= */

/* A) Main cart drawer containers (covers variants) */
#CartDrawer,
#CartDrawer-Drawer,
#CartDrawerDrawer,
[id*="CartDrawer"] {
  background-color: #000 !important;
}

/* B) The actual visible cart panel (common theme variants) */
.cart-drawer__inner,
.cart-drawer__content,
.cart-drawer__footer {
  background-color: #000 !important;
}

/* C) Inner cart surfaces inside any CartDrawer id (safe and targeted) */
#CartDrawer .drawer__inner,
#CartDrawer .drawer__content,
#CartDrawer-Drawer .drawer__inner,
#CartDrawer-Drawer .drawer__content,
#CartDrawerDrawer .drawer__inner,
#CartDrawerDrawer .drawer__content,
[id*="CartDrawer"] .drawer__inner,
[id*="CartDrawer"] .drawer__content {
  background-color: #000 !important;
  opacity: 1 !important;
}

/* D) Text inside cart (so it stays readable) */
#CartDrawer a,
#CartDrawer span,
#CartDrawer p,
#CartDrawer-Drawer a,
#CartDrawer-Drawer span,
#CartDrawer-Drawer p,
#CartDrawerDrawer a,
#CartDrawerDrawer span,
#CartDrawerDrawer p,
[id*="CartDrawer"] a,
[id*="CartDrawer"] span,
[id*="CartDrawer"] p,
.cart-drawer__inner a,
.cart-drawer__inner span,
.cart-drawer__inner p,
.cart-drawer__content a,
.cart-drawer__content span,
.cart-drawer__content p {
  color: #fff !important;
}
/* =========================================================
   CART DRAWER – STEP 2 (WORKS ON THE REAL PANEL)
   80% width · right side · full viewport height · fixed
   ========================================================= */

/* The actual visible cart drawer PANEL in many Shopify/Dawn variants */
.cart-drawer__inner,
.cart-drawer__content {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  left: auto !important;

  width: 80vw !important;
  max-width: 80vw !important;

  height: 100vh !important;
  max-height: 100vh !important;

  z-index: 1002 !important; /* above page */
}

/* If your theme uses .drawer__inner inside the cart, force it too */
[id*="CartDrawer"] .drawer__inner,
[id*="CartDrawer"] .drawer__content {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  left: auto !important;

  width: 80vw !important;
  max-width: 80vw !important;

  height: 100vh !important;
  max-height: 100vh !important;

  z-index: 1002 !important;
}

/* Make cart content scroll inside the drawer (drawer stays fixed) */
.cart-drawer__content,
[id*="CartDrawer"] .drawer__content {
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}
/* =========================================================
   CART DRAWER – DESKTOP BLACK FIX
   Force black background on desktop cart panel
   ========================================================= */

/* Desktop cart drawer panels (Dawn & variants) */
@media screen and (min-width: 990px) {
  .cart-drawer__inner,
  .cart-drawer__content,
  .cart-drawer__footer,
  #CartDrawer .drawer__inner,
  #CartDrawer .drawer__content,
  #CartDrawer-Drawer .drawer__inner,
  #CartDrawer-Drawer .drawer__content,
  #CartDrawerDrawer .drawer__inner,
  #CartDrawerDrawer .drawer__content,
  [id*="CartDrawer"] .drawer__inner,
  [id*="CartDrawer"] .drawer__content {
    background-color: #000 !important;
    background: #000 !important;
    opacity: 1 !important;
  }

  /* Desktop cart text */
  .cart-drawer__inner a,
  .cart-drawer__inner span,
  .cart-drawer__inner p,
  #CartDrawer a,
  #CartDrawer span,
  #CartDrawer p,
  [id*="CartDrawer"] a,
  [id*="CartDrawer"] span,
  [id*="CartDrawer"] p {
    color: #fff !important;
  }
}
/* =========================================================
   CART DRAWER – DESKTOP BLACK ONLY (NO SIZE CHANGES)
   ========================================================= */
@media screen and (min-width: 990px) {

  /* Common cart drawer panel containers (no wrapper like cart-drawer) */
  #CartDrawer,
  #CartDrawer-Drawer,
  #CartDrawerDrawer,
  [id*="CartDrawer"],
  dialog[id*="Cart"],
  aside[id*="Cart"],
  .drawer.cart-drawer,
  .drawer--cart,
  .cart-drawer__inner,
  .cart-drawer__content,
  .cart-drawer__footer,
  .cartDrawer,
  .CartDrawer,
  .cart-drawer,
  .cart-drawer-content {
    background: #000 !important;
    background-color: #000 !important;
    opacity: 1 !important;
  }

  /* Inner surfaces inside those panels */
  #CartDrawer .drawer__inner,
  #CartDrawer .drawer__content,
  #CartDrawer-Drawer .drawer__inner,
  #CartDrawer-Drawer .drawer__content,
  #CartDrawerDrawer .drawer__inner,
  #CartDrawerDrawer .drawer__content,
  [id*="CartDrawer"] .drawer__inner,
  [id*="CartDrawer"] .drawer__content,
  dialog[id*="Cart"] .drawer__inner,
  dialog[id*="Cart"] .drawer__content,
  aside[id*="Cart"] .drawer__inner,
  aside[id*="Cart"] .drawer__content {
    background: #000 !important;
    background-color: #000 !important;
    opacity: 1 !important;
  }

  /* Text inside cart drawer */
  #CartDrawer a, #CartDrawer span, #CartDrawer p,
  #CartDrawer-Drawer a, #CartDrawer-Drawer span, #CartDrawer-Drawer p,
  #CartDrawerDrawer a, #CartDrawerDrawer span, #CartDrawerDrawer p,
  [id*="CartDrawer"] a, [id*="CartDrawer"] span, [id*="CartDrawer"] p,
  dialog[id*="Cart"] a, dialog[id*="Cart"] span, dialog[id*="Cart"] p,
  aside[id*="Cart"] a, aside[id*="Cart"] span, aside[id*="Cart"] p {
    color: #fff !important;
  }
}
/* =========================================================
   CART DRAWER – DESKTOP: ACTUALLY BLACK (kills glass/blur layer)
   No size changes here.
   ========================================================= */
@media screen and (min-width: 990px) {

  /* The visible cart panel layers */
  #CartDrawer .drawer__inner,
  #CartDrawer .drawer__content,
  #CartDrawer-Drawer .drawer__inner,
  #CartDrawer-Drawer .drawer__content,
  #CartDrawerDrawer .drawer__inner,
  #CartDrawerDrawer .drawer__content,
  [id*="CartDrawer"] .drawer__inner,
  [id*="CartDrawer"] .drawer__content,
  .cart-drawer__inner,
  .cart-drawer__content,
  .cart-drawer__footer {
    background: #000 !important;
    background-color: #000 !important;
    background-image: none !important;
    opacity: 1 !important;

    /* kill the “frosted glass” effect */
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* If the theme paints the glass on a pseudo-element, nuke it */
  #CartDrawer .drawer__inner::before,
  #CartDrawer .drawer__inner::after,
  #CartDrawer-Drawer .drawer__inner::before,
  #CartDrawer-Drawer .drawer__inner::after,
  #CartDrawerDrawer .drawer__inner::before,
  #CartDrawerDrawer .drawer__inner::after,
  [id*="CartDrawer"] .drawer__inner::before,
  [id*="CartDrawer"] .drawer__inner::after,
  .cart-drawer__inner::before,
  .cart-drawer__inner::after,
  .cart-drawer__content::before,
  .cart-drawer__content::after {
    background: #000 !important;
    background-color: #000 !important;
    background-image: none !important;
    opacity: 1 !important;

    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Keep text readable */
  #CartDrawer a, #CartDrawer span, #CartDrawer p,
  #CartDrawer-Drawer a, #CartDrawer-Drawer span, #CartDrawer-Drawer p,
  #CartDrawerDrawer a, #CartDrawerDrawer span, #CartDrawerDrawer p,
  [id*="CartDrawer"] a, [id*="CartDrawer"] span, [id*="CartDrawer"] p,
  .cart-drawer__inner a, .cart-drawer__inner span, .cart-drawer__inner p,
  .cart-drawer__content a, .cart-drawer__content span, .cart-drawer__content p {
    color: #fff !important;
  }
}
/* =========================================================
   CART DRAWER – DESKTOP BLACK (NO SIZE CHANGES, NO HEADER SIDE EFFECTS)
   Targets any OPEN cart drawer/dialog/panel with cart-ish id/class
   ========================================================= */
@media screen and (min-width: 990px) {

  /* 1) Any open cart container (dialog/drawer/panel) */
  dialog[open][id*="cart" i],
  dialog[open][class*="cart" i],
  [role="dialog"][aria-modal="true"][id*="cart" i],
  [role="dialog"][aria-modal="true"][class*="cart" i],
  [open][id*="cart" i],
  [open][class*="cart" i],
  .active[id*="cart" i],
  .active[class*="cart" i],
  .is-open[id*="cart" i],
  .is-open[class*="cart" i] {
    background: #000 !important;
    background-color: #000 !important;
    background-image: none !important;
    opacity: 1 !important;

    /* kill “glass” effects if they exist */
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* 2) The panel INSIDE the open cart container (common structures) */
  dialog[open][id*="cart" i] *,
  dialog[open][class*="cart" i] *,
  [role="dialog"][aria-modal="true"][id*="cart" i] *,
  [role="dialog"][aria-modal="true"][class*="cart" i] *,
  [open][id*="cart" i] *,
  [open][class*="cart" i] * {
    background-image: none !important;
  }

  /* Force the main inner surfaces to black (where the background usually lives) */
  dialog[open][id*="cart" i] .drawer__inner,
  dialog[open][id*="cart" i] .drawer__content,
  dialog[open][class*="cart" i] .drawer__inner,
  dialog[open][class*="cart" i] .drawer__content,
  [open][id*="cart" i] .drawer__inner,
  [open][id*="cart" i] .drawer__content,
  [open][class*="cart" i] .drawer__inner,
  [open][class*="cart" i] .drawer__content,
  [role="dialog"][aria-modal="true"][id*="cart" i] .drawer__inner,
  [role="dialog"][aria-modal="true"][id*="cart" i] .drawer__content,
  [role="dialog"][aria-modal="true"][class*="cart" i] .drawer__inner,
  [role="dialog"][aria-modal="true"][class*="cart" i] .drawer__content {
    background: #000 !important;
    background-color: #000 !important;
    opacity: 1 !important;

    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* 3) Text readable (only inside those open cart containers) */
  dialog[open][id*="cart" i] a,
  dialog[open][id*="cart" i] span,
  dialog[open][id*="cart" i] p,
  dialog[open][class*="cart" i] a,
  dialog[open][class*="cart" i] span,
  dialog[open][class*="cart" i] p,
  [role="dialog"][aria-modal="true"][id*="cart" i] a,
  [role="dialog"][aria-modal="true"][id*="cart" i] span,
  [role="dialog"][aria-modal="true"][id*="cart" i] p,
  [role="dialog"][aria-modal="true"][class*="cart" i] a,
  [role="dialog"][aria-modal="true"][class*="cart" i] span,
  [role="dialog"][aria-modal="true"][class*="cart" i] p {
    color: #fff !important;
  }

  /* 4) If the theme paints the “glass” via pseudo-elements, nuke those too */
  dialog[open][id*="cart" i]::before,
  dialog[open][id*="cart" i]::after,
  dialog[open][class*="cart" i]::before,
  dialog[open][class*="cart" i]::after,
  [role="dialog"][aria-modal="true"][id*="cart" i]::before,
  [role="dialog"][aria-modal="true"][id*="cart" i]::after,
  [role="dialog"][aria-modal="true"][class*="cart" i]::before,
  [role="dialog"][aria-modal="true"][class*="cart" i]::after {
    background: #000 !important;
    background-color: #000 !important;
    opacity: 1 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
}
<style>
/* =========================================================
   SOULTENTIC: MOBILE CART HEADER (REAL ELEMENT, NOT ::before)
   ========================================================= */
.st-cart-mobile-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 999999 !important;

  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;

  padding: 16px 18px !important;
  background: #fff !important;
  color: #000 !important;
  border-bottom: 1px solid rgba(0,0,0,0.12) !important;

  font-size: 20px !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
}

.st-cart-mobile-header * {
  color: #000 !important;
}
</style>
/* SOULTENTIC: Mobile Cart Header (real markup) */
.st-cart-mobile-header-wrap { display: none; }

@media (max-width: 989px) {
  .st-cart-mobile-header-wrap{
    display:block;
    position: sticky;
    top: 0;
    z-index: 99999;
    background: #fff;
  }

  .st-cart-mobile-header-bar{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:16px 18px;
    border-bottom:1px solid rgba(0,0,0,0.12);
    background:#fff;
    color:#000;
  }

  .st-cart-mobile-title{
    font-size:20px;
    font-weight:600;
    letter-spacing:0.02em;
    color:#000;
  }

  .st-cart-mobile-close{
    background: transparent;
    border: 0;
    padding: 8px;
    font-size: 20px;
    line-height: 1;
    color:#000;
    cursor:pointer;
  }
}
/* SOULTENTIC: Cart drawer header must not overlap items */
.cart-drawer__header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: #fff;
  border-bottom: 1px solid rgba(0,0,0,0.12);
}

/* Ensure the content area actually starts below the header */
.cart-drawer__content{
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.cart-drawer__items{
  min-height: 0;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
