/** Shopify CDN: Minification failed

Line 6337:1 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;
}

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@media screen and (min-width: 1025px) {
  .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: 1025px) {
    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: 1024px) {
  .hidden--mobile,
  .mobile\:hidden {
    /* stylelint-disable-next-line declaration-no-important */
    display: none !important;
  }
}

@media screen and (min-width: 1025px) {
  .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: 1024px) {
  .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: 1025px) {
  .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;
}

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

body:has(.header[transparent]) #header-group > *:not(.header-section) {
  z-index: 1;
}

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

/* 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: 1025px) {
    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: 1025px) {
  .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: 1024px) {
    grid-template-columns: 1fr;
  }
}

.product-grid__card .group-block > * {
  @media screen and (max-width: 1024px) {
    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: 1025px) {
    border-radius: var(--style-border-radius-popover);
    max-width: var(--normal-content-width);
  }

  @media screen and (max-width: 1024px) {
    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);
  text-transform: var(--button-text-case-primary);
  border-radius: var(--style-border-radius-buttons-primary);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

.show-more__button:hover {
  @media screen and (min-width: 1025px) {
    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: 1024px) {
    grid-area: unset;
  }
}

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

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

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

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

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

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

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

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

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

@media screen and (min-width: 1025px) {
  .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: #fff;
  opacity: 0;
  transition: opacity var(--animation-speed) var(--animation-easing);
  scrollbar-width: none;

  &[open] {
    opacity: 1;
  }

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

  &::backdrop {
    background: transparent;
  }
}

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

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

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

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

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

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

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

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

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

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

@media screen and (min-width: 1025px) {
  .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: 1024px) {
  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: 1025px) {
  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: 1025px) {
    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: 1025px) {
    /* 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: 1025px) {
  .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: 1025px) {
  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: 1025px) {
    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: 1024px) {
  .mobile-column {
    flex-flow: column nowrap;
    align-items: var(--horizontal-alignment);
    justify-content: var(--vertical-alignment-mobile);
  }

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

    > .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: 1025px) {
  .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: 1025px) {
    --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: flex;
  line-height: normal;
  align-items: center;
  justify-content: center;
  color: var(--color-primary-button-text);
  padding-inline: var(--cart-padding);
}

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

.cart-bubble__text {
  font-size: var(--font-size--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: 1024px) {
    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: 1024px) {
    padding-inline-start: var(--padding-sm);
  }
}

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

.pills__pill--desktop-small {
  @media screen and (min-width: 1025px) {
    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: 1025px) {
  .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: 1025px) {
  .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: 1025px) {
    &[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: 1024px) {
    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: 1024px) {
  /* 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: 1024px) {
    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: 1025px) {
    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: 1024px) {
    --resource-list-mobile-gap-max: 12px;
  }

  @container resource-list (max-width: 1024px) {
    --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: 1025px) {
    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: 1024px) {
    --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: 1025px) {
    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: 1024px) {
  .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: 1025px) {
  .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: 1024px) {
    cursor: auto;
  }
}

accordion-custom[data-disable-on-desktop='true'] summary {
  @media screen and (min-width: 1025px) {
    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: 1024px) {
  :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%);
  }
}

/* ----------------------------------------------------------------------------
   CUSTOM CHANGES
   ---------------------------------------------------------------------------- */


/* Featured Collection Product Cards - Custom Styling */
.ui-test-product-list .card-gallery {
  position: relative;
}

.ui-test-product-list .spacing-style.text-block {
  position: absolute !important;
  bottom: 37px !important;
  left: 0 !important;
  right: 0 !important;
  background: transparent !important;
  padding: 0 16px !important;
  margin: 0 !important;
}

.ui-test-product-list product-price {
  position: absolute !important;
  bottom: 10px !important;
  left: 0 !important;
  right: 0 !important;
  background: transparent !important;
  padding: 0 16px !important;
  margin: 0 !important;
}

.ui-test-product-list .spacing-style.text-block *,
.ui-test-product-list product-price * {
  text-shadow: 0 2px 8px rgba(255, 255, 255, 0.9), 0 0 20px rgba(255, 255, 255, 0.8) !important;
  background: transparent !important;
}

.ui-test-product-list .product-badges {
  display: none !important;
}

/* Hide text by default - slow fade out */
.ui-test-product-list .spacing-style.text-block,
.ui-test-product-list product-price {
  opacity: 0 !important;
  transition: opacity 0.3s ease-in-out !important;
}

/* Show text on hover - fast fade in */
.ui-test-product-list li:hover .spacing-style.text-block,
.ui-test-product-list li:hover product-price,
.ui-test-product-list .product-card:hover .spacing-style.text-block,
.ui-test-product-list .product-card:hover product-price,
.ui-test-product-list product-card-link:hover .spacing-style.text-block,
.ui-test-product-list product-card-link:hover product-price {
  opacity: 1 !important;
  transition: opacity 0.15s ease-in-out !important;
}
/* Remove any default positioning from wishlist */
.ui-test-product-list .swym-wishlist-collections-v2-container {
  position: absolute !important;
  bottom: 0px !important;
  right: 0px !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  margin: 0 !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease-in-out !important;
  z-index: 11 !important;
}

/* Ensure the button inside is also positioned correctly */
.ui-test-product-list .swym-wishlist-collections-v2-container > * {
  position: static !important;
  transform: none !important;
  margin: 0 !important;
}

/* Show wishlist icon on hover - fast fade in */
.ui-test-product-list li:hover .swym-wishlist-collections-v2-container,
.ui-test-product-list .product-card:hover .swym-wishlist-collections-v2-container,
.ui-test-product-list product-card-link:hover .swym-wishlist-collections-v2-container {
  opacity: 1 !important;
  transition: opacity 0.15s ease-in-out !important;
}
/* Hide the existing arrow SVG more aggressively */
.ui-test-product-list slideshow-arrows .slideshow-control svg,
.ui-test-product-list slideshow-arrows .slideshow-control .svg-wrapper,
.ui-test-product-list slideshow-arrows .slideshow-control .icon-arrow {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Create chevron using ::before */
.ui-test-product-list slideshow-arrows .slideshow-control::before {
  content: '' !important;
  display: block !important;
  width: 12px !important;
  height: 12px !important;
}

/* Left chevron - try 135deg */
.ui-test-product-list slideshow-arrows .slideshow-control--previous::before {
  border-bottom: 2px solid white !important;
  border-left: 2px solid white !important;
  transform: rotate(225deg) !important;
}

/* Right chevron - point right */
.ui-test-product-list slideshow-arrows .slideshow-control--next::before {
  border-bottom: 2px solid white !important;
  border-right: 2px solid white !important;
  transform: rotate(-45deg) !important;
}
/* Split showcase - keep image ratio but reduce block padding */
[data-testid="ui-test-section"] .group-block {
  --size-style-height: 100% !important;
  height: auto !important;
}

/* Only apply ratio to image containers and images */
[data-testid="ui-test-section"] .image-block img,
[data-testid="ui-test-section"] .group-block__media-wrapper img {
  aspect-ratio: 1 / 1.4 !important;
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
}

[data-testid="ui-test-section"] .image-block,
[data-testid="ui-test-section"] .group-block__media-wrapper {
  aspect-ratio: 1 / 1.4 !important;
  height: auto !important;
}

/* Keep group-block height auto to fit content */
[data-testid="ui-test-section"] .group-block-content {
  height: auto !important;
}

/* Reduce padding on the group blocks */
[data-testid="ui-test-section"] .group-block.spacing-style {
  padding-block-start: 0 !important;
  padding-block-end: 0 !important;
}

/* Reduce section padding */
[data-testid="ui-test-section"] .section-content-wrapper {
  padding-block: 0 !important;
}
/* HOME PAGE GRID - MAXIMUM SPECIFICITY */
@media screen and (min-width: 1025px) {
  body.page-width-wide main#MainContent.content-for-layout[data-template="index"] {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-auto-rows: auto !important;
    gap: 0 !important;
  }
  
  /* First showcase - left side (1st child) */
  body.page-width-wide main#MainContent.content-for-layout[data-template="index"] > .shopify-section:nth-child(1) {
    grid-column: 1 !important;
    grid-row: 1 !important;
  }
  
  /* Featured collection - SWAP to full width below (2nd child in DOM) */
  body.page-width-wide main#MainContent.content-for-layout[data-template="index"] > .shopify-section:nth-child(2) {
    grid-column: 1 / 3 !important;
    grid-row: 2 !important;
  }
  
  /* Second showcase - SWAP to right side (3rd child in DOM) */
  body.page-width-wide main#MainContent.content-for-layout[data-template="index"] > .shopify-section:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }
}

/* ----------------------------------------------------------------------------
   HEADER - Desktop Only Customizations
   ---------------------------------------------------------------------------- */
/* Desktop: Transparent sticky header with adjustments */
@media screen and (min-width: 1025px) {
  /* Default - let theme handle header */
  .header-section {
    /* Don't force anything - let theme control it */
  }

  /* HOME PAGE ONLY - Force fixed transparent header */
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header-section {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) .header-component,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header {
    position: relative !important;
    opacity: 1 !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) .header[data-sticky-state='idle'],
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header[data-sticky-state='active'],
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header[data-sticky-state='active'][data-animating] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) .header,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header__row,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header-component {
    background: transparent !important;
    background-color: transparent !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) .header::before,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header::after,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header__row::before,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .header__row::after,
  body.page-width-wide:has(main#MainContent[data-template="index"]) .shopify-section-group-header-group::before {
    display: none !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) .header__column {
    position: relative !important;
    z-index: 10 !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="index"]) {
    padding-top: 83px !important;
  }

  /* PRODUCT PAGE ONLY - Force fixed transparent header */
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header-section {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="product"]) .header-component,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header {
    position: relative !important;
    opacity: 1 !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="product"]) .header[data-sticky-state='idle'],
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header[data-sticky-state='active'],
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header[data-sticky-state='active'][data-animating] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="product"]) .header,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header__row,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header-component {
    background: transparent !important;
    background-color: transparent !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="product"]) .header::before,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header::after,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header__row::before,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .header__row::after,
  body.page-width-wide:has(main#MainContent[data-template="product"]) .shopify-section-group-header-group::before {
    display: none !important;
  }

  body.page-width-wide:has(main#MainContent[data-template="product"]) {
    padding-top: 83px !important;
  }

/* COLLECTION PAGE - White background only, let theme handle positioning */
  body.page-width-wide:has(main#MainContent[data-template="collection"]) .header,
  body.page-width-wide:has(main#MainContent[data-template="collection"]) .header__row {
    background: white !important;
    background-color: white !important;
  }
}

/* Custom font - applies to all screen sizes */
@font-face {
  font-family: 'FuturaPTBook';
  src: url('FuturaPTBook.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

.menu-list,
.menu-list *,
.menu-list__link,
.menu-list__link-title,
.header-menu * {
  font-family: 'FuturaPTBook', sans-serif;
}

/* Menu hover animation - applies to all screen sizes */
.menu-list__link {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.menu-list__link-title {
  position: relative;
  display: inline-block;
}

.menu-list__link-title::after {
  content: '';
  position: absolute;
  bottom: 5px;
  left: 0;
  right: auto;
  width: 0;
  height: 1px;
  background-color: currentColor;
  transition: width 0.25s ease-out;
}

.menu-list__link:hover .menu-list__link-title::after {
  width: 100%;
}

.menu-list__link:not(:hover) .menu-list__link-title::after {
  left: auto;
  right: 0;
  width: 0;
}
@media screen and (min-width: 1025px) {
  /* Lift header content up slightly */
  .header__column {
    margin-top: -0%;
  }
  
  /* Lower just the right side icons */
  .header__column--right > * {
    position: relative;
    top: 2.5%;
  }
}

/* ============================================================================
   HEADER HEIGHT - Desktop and Mobile
   ============================================================================ */
/* Desktop: 83px header */
@media screen and (min-width: 1025px) {
  body:has(> #header-group > header) {
    --header-height: 83px;
  }

  .header,
  .header__row {
    height: 83px;
    min-height: 83px;
  }
}

/* Mobile: 70px header */
@media screen and (max-width: 1024px) {
  body:has(> #header-group > header) {
    --header-height: 70px;
  }

  .header,
  .header__row {
    height: 70px;
    min-height: 70px;
  }
}

/* ============================================================================
   HEADER BEHAVIOR - Desktop: Always visible, Mobile: Scroll-up behavior
   ============================================================================ */
/* Desktop: Keep logo/menu/icons always visible, background scrolls away */
@media screen and (min-width: 1025px) {
  /* Force header section to always stay at top */
  .header-section {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 1000 !important;
  }

  /* Force header component to always be visible */
  .header-component,
  .header {
    position: relative !important;
    opacity: 1 !important;
  }

  /* Override ALL sticky states */
  .header[data-sticky-state='idle'],
  .header[data-sticky-state='active'],
  .header[data-sticky-state='active'][data-animating] {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  /* Make header background transparent */
  .header,
  .header__row,
  .header-component {
    background: transparent !important;
    background-color: transparent !important;
  }

  /* Remove pseudo-element backgrounds */
  .header::before,
  .header::after,
  .header__row::before,
  .header__row::after,
  .shopify-section-group-header-group::before {
    display: none !important;
  }

  /* Ensure content is visible */
  .header__column {
    position: relative !important;
    z-index: 10 !important;
  }

  /* Add padding to body so content doesn't hide under fixed header */
  body {
    padding-top: 83px !important;
  }
}

/* Mobile: Keep scroll-up behavior from theme settings */
@media screen and (max-width: 1024px) {
  /* Keep default white background on mobile */
  .header,
  .header__row {
    background: var(--color-background) !important;
  }
}

/* ============================================================================
   PRODUCT PAGE ONLY - Stack sections and resize gallery
   ============================================================================ */
@media screen and (min-width: 1025px) {
  /* Only apply when product-information exists (product pages only) */
  .content-for-layout:has(.product-information) {
    display: block !important;
  }

  .content-for-layout:has(.product-information) > .shopify-section {
    display: block !important;
    width: 100% !important;
  }

  /* Within product-information section: 60/40 split */
  .product-information__grid {
    display: grid !important;
    grid-template-columns: 60% 40% !important;
    gap: var(--gap-xl) !important;
  }

  /* Image gallery - 60% width */
  .product-information__grid .product-information__media {
    grid-column: 1 !important;
  }

  /* Product details - 40% width */
  .product-information__grid .product-details {
    grid-column: 2 !important;
  }

  /* Recommendations section - full width, stacks below */
  .product-recommendations {
    width: 100% !important;
    display: block !important;
  }
}

/* ============================================================================
   PRODUCT PAGE - Square Color Swatches (No white gap)
   ============================================================================ */
/* Remove ALL styling from both label classes */
.variant-option__button-label,
.variant-option__button-label--has-swatch {
  border-radius: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  outline: none !important;
  display: inline-block !important;
  line-height: 0 !important;
}

/* Make swatches square - 20x20px with border */
.swatch,
.swatch--unscaled {
  border-radius: 0 !important;
  box-shadow: none !important;
  width: 20px !important;
  height: 20px !important;
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  background: var(--swatch-background) !important;
  outline: 1px solid #000 !important;
}

/* Hide the radio input */
input[type="radio"][name*="variant_picker"] {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Selected state - thicker border */
input:checked + label .swatch {
  border: 2px solid #000 !important;
  outline: none !important;
}

/* ============================================================================
   PRODUCT PAGE - Color Swatch Label (Show only selected color in FuturaPT)
   ============================================================================ */

/* Hide the word "Color" from legend */
.variant-option legend {
  font-size: 0 !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  padding: 0 !important;
  margin: 0 0 16px -2px !important;
  line-height: 0 !important;
}

/* Show only the selected color value */
.variant-option__swatch-value {
  font-size: 16px !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  display: inline-block !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: normal !important;
  color: #2E2E2E !important;
}

/* ============================================================================
   VIEW ALL FINISHES BUTTON - On swatch row, aligned right
   ============================================================================ */

/* Make fieldset the positioning context */
fieldset.variant-option--swatches {
  position: relative !important;
}

/* Position button on swatch row, aligned right */
fieldset.variant-option--swatches > .view-all-finishes-btn {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  font-size: 14px !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  color: #2e2e2e !important;
  text-decoration: none !important;
  display: inline-block !important;
  line-height: normal !important;
  z-index: 10 !important;
}

/* Underline animation - starts hidden, sweeps left on hover */
fieldset.variant-option--swatches > .view-all-finishes-btn::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0px !important;
  right: 0 !important;
  left: auto !important;
  width: 0 !important;
  height: 1px !important;
  background-color: #2e2e2e !important;
  transition: width 0.25s ease-out !important;
}

fieldset.variant-option--swatches > .view-all-finishes-btn:hover::after {
  width: 100% !important;
  left: 0 !important;
  right: auto !important;
}

/* ============================================================================
   MOBILE - Hide desktop button, JS creates centered version below swatches
   ============================================================================ */

@media screen and (max-width: 1024px) {
  fieldset.variant-option--swatches > .view-all-finishes-btn {
    display: none !important;
  }
}

/* ============================================================================
   PRODUCT PAGE - Color Swatch Label (Show only selected color in FuturaPT)
   ============================================================================ */
/* Hide the word "Color" from legend */
.variant-option legend {
  font-size: 0 !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  padding: 0 !important;
  margin: 0 0 16px -2px !important;
  line-height: 0 !important;
  min-height: 24px !important; /* Reserve space so layout doesn't shift */
}

/* Show only the selected color value */
.variant-option__swatch-value {
  font-size: 16px !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  display: inline-block !important;
  padding: 0 !important;
  margin: 0 !important;
  line-height: normal !important;
  transition: opacity 0.3s ease, transform 0.3s ease !important;
  min-height: 24px !important;
  color: #2E2E2E !important; /* Your brand color */
}

/* ============================================================================
    CART DRAWER WIDTH - SIMPLE FIX
   ============================================================================ */
/* Just change the drawer width - let theme handle animations */
.cart-drawer__dialog.dialog-drawer {
  width: 42.8% !important;
  max-width: 42.8% !important;
}

/* Mobile stays full width */
@media screen and (max-width: 1024px) {
  .cart-drawer__dialog.dialog-drawer {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* ============================================================================
    CART DRAWER OVERLAY - MAKE LIGHTER
   ============================================================================ */
/* Lighten the background when cart drawer is open */
.cart-drawer__dialog::backdrop {
  background: rgba(255, 255, 255, 0.5) !important; /* White overlay at 50% opacity */
  backdrop-filter: brightness(1.2) !important; /* Brighten the background */
}

/* ============================================================================
    CART DRAWER ANIMATION SPEED - SIMPLE FIX
   ============================================================================ */
/* Just slow down the existing animation */
.cart-drawer__dialog {
  --animation-speed: 0.7s !important; /* Default is probably 0.3s */
}

/* ============================================================================
   ALL PAGES - CUSTOM FONT - FUTURAPT BOOK
   ============================================================================ */
/* 1. First, declare the font face */
@font-face {
  font-family: 'FuturaPTBook';
  src: url('{{ "FuturaPTBook.woff2" | asset_url }}') format('woff2');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* 2. Apply to all text elements globally */
* {
  font-family: 'FuturaPTBook', sans-serif !important;
}

/* 3. Override theme's typography variables */
:root {
  --font-paragraph--family: 'FuturaPTBook', sans-serif !important;
  --font-h1--family: 'FuturaPTBook', sans-serif !important;
  --font-h2--family: 'FuturaPTBook', sans-serif !important;
  --font-h3--family: 'FuturaPTBook', sans-serif !important;
  --font-h4--family: 'FuturaPTBook', sans-serif !important;
  --font-h5--family: 'FuturaPTBook', sans-serif !important;
  --font-h6--family: 'FuturaPTBook', sans-serif !important;
  --button-font-family-primary: 'FuturaPTBook', sans-serif !important;
  --button-font-family-secondary: 'FuturaPTBook', sans-serif !important;
}

/* 4. Ensure buttons and inputs use the font */
button, input, select, textarea {
  font-family: 'FuturaPTBook', sans-serif !important;
}

/* ============================================================================
   PRODUCT PAGE - Remove top spacing
   ============================================================================ */
@media screen and (min-width: 1025px) {
  /* Remove padding from main content */
  main#MainContent[data-template="product"] {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Remove padding from product section */
  .product-information.section {
    padding-top: 0 !important;
    padding-block-start: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Remove section background padding */
  .section-background {
    padding-top: 0 !important;
  }
}

/* ============================================================================
   ALL PAGES - Change Logo Opacity
   ============================================================================ */

/* Product details buttons hover animation */
.product-details-buttons {
  display: flex;
  gap: 24px;
  justify-content: space-between;
}

/* ============================================================================
   PRODUCT PAGE - Button Line Animation
   ============================================================================ */
.product-details-buttons a {
  position: relative;
  display: inline-block;
  text-decoration: none;
}

.product-details-buttons a::after {
  content: '';
  position: absolute;
  bottom: 3px;
  left: 0;
  right: auto;
  width: 0;
  height: 1px;
  background-color: currentColor;
  transition: width 0.25s ease-out;
}

.product-details-buttons a:hover::after {
  width: 100%;
}

.product-details-buttons a:not(:hover)::after {
  left: auto;
  right: 0;
  width: 0;
}

/* ============================================================================
   HOME PAGE - Feature Collection Aspect Ratio
   ============================================================================ */
/* Featured Collection Card Height - 1:1.4 Aspect Ratio */
.ui-test-product-list .card-gallery {
  aspect-ratio: 1 / 1.33 !important;
  height: auto !important;
  overflow: hidden !important;
}

/* Remove any max-height constraints */
.ui-test-product-list .card-gallery *,
.ui-test-product-list slideshow-component,
.ui-test-product-list slideshow-component * {
  max-height: none !important;
  height: 100% !important;
}

/* Force slideshow to fill */
.ui-test-product-list slideshow-component {
  aspect-ratio: 1 / 1.33 !important;
  height: auto !important;
}

/* Force all images to fill */
.ui-test-product-list img {
  aspect-ratio: 1 / 1.35 !important;
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
}

/* ============================================================================
   PRODUCT PAGE - Feature Collection Wishlist Icon Relocation and Resize
   ============================================================================ */
/* Product Page Featured Collection - Wishlist Icon Bottom Right */
.product-recommendations .swym-wishlist-collections-v2-container,
.product-recommendations [class*="swym-wishlist"],
.product-recommendations [class*="swym-button"] {
  position: absolute !important;
  bottom: -3px !important;
  right: 0px !important;
  top: auto !important;
  left: auto !important;
  transform: none !important;
  margin: 0 !important;
  opacity: 1 !important;
  z-index: 11 !important;
  visibility: visible !important;
  display: block !important;
}

.product-recommendations .swym-wishlist-collections-v2-container > *,
.product-recommendations [class*="swym-wishlist"] > *,
.product-recommendations [class*="swym-button"] > * {
  position: static !important;
  transform: none !important;
  margin: 0 !important;
  visibility: visible !important;
  display: block !important;
}

/* Make the icon bigger */
.product-recommendations .swym-wishlist-collections-v2-container button,
.product-recommendations .swym-wishlist-collections-v2-container svg,
.product-recommendations .swym-wishlist-collections-v2-container i,
.product-recommendations [class*="swym-wishlist"] button,
.product-recommendations [class*="swym-wishlist"] svg,
.product-recommendations [class*="swym-wishlist"] i {
  width: 28px !important;
  height: 28px !important;
  font-size: 28px !important;
  visibility: visible !important;
  display: block !important;
}

/* ============================================================================
   PRODUCT PAGE - Featured Collection - Custom Chevrons
   ============================================================================ */
/* Hide the existing arrow SVG */
.product-recommendations slideshow-arrows .slideshow-control svg,
.product-recommendations slideshow-arrows .slideshow-control .svg-wrapper,
.product-recommendations slideshow-arrows .slideshow-control .icon-arrow {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Create chevron using ::before */
.product-recommendations slideshow-arrows .slideshow-control::before {
  content: '' !important;
  display: block !important;
  width: 12px !important;
  height: 12px !important;
}

/* Left chevron */
.product-recommendations slideshow-arrows .slideshow-control--previous::before {
  border-bottom: 2px solid white !important;
  border-left: 2px solid white !important;
  transform: rotate(225deg) !important;
}

/* Right chevron */
.product-recommendations slideshow-arrows .slideshow-control--next::before {
  border-bottom: 2px solid white !important;
  border-right: 2px solid white !important;
  transform: rotate(-45deg) !important;
}

/* ============================================================================
   CUSTOM FONT - FUTURAPT MEDIUM
   ============================================================================ */

@font-face {
  font-family: 'FuturaPTMedium';
  src: url('FuturaPTMedium.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* ============================================================================
   ADD TO CART BUTTON - Smaller text and icons with FuturaPTMedium
   ============================================================================ */

.add-to-cart-button,
.add-to-cart-button * {
  font-family: 'FuturaPTMedium', sans-serif !important;
  font-size: 11.5px !important;
  letter-spacing: 3px !important;
  font-weight: !important; /* Use normal weight since the font itself is medium */
}

.add-to-cart-button .svg-wrapper,
.add-to-cart-button .add-to-cart-icon,
.add-to-cart-button .add-to-cart-icon--added {
  width: 25px !important;
  height: 25px !important;
}

.add-to-cart-button svg {
  width: 25px !important;
  height: 25px !important;
}

@media screen and (max-width: 1024px) {
  
  /* Sticky bar Add to Cart button - specific styling */
  .sticky-atc-bar__button .button.add-to-cart-button,
  .sticky-atc-bar .button.add-to-cart-button {
    padding: 14px 17px !important;
    margin: 0 !important;
  }
  
  .sticky-atc-bar__button .add-to-cart-text__content,
  .sticky-atc-bar .add-to-cart-text__content {
    font-size: 12.5px !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
  }
  
  .sticky-atc-bar__button .add-to-cart-text__price,
  .sticky-atc-bar .add-to-cart-text__price {
    font-size: 12.5px !important;
    font-weight: 500 !important;
    letter-spacing: 1px !important;
    font-family: 'FuturaPTBook', sans-serif !important;
  }

  .sticky-atc-bar__button .svg-wrapper,
  .sticky-atc-bar__button .add-to-cart-icon,
  .sticky-atc-bar .svg-wrapper,
  .sticky-atc-bar .add-to-cart-icon {
    display: none !important;
  }
}

/* ============================================================================
   FEATURED COLLECTION - Smaller Chevrons
   ============================================================================ */

/* Home page featured collection */
.ui-test-product-list slideshow-arrows .slideshow-control::before {
  width: 9px !important; /* Reduced from 12px */
  height: 9px !important;
  border-width: 1px !important; /* Make the lines slightly thinner too */
}

/* Product page featured collection */
.product-recommendations slideshow-arrows .slideshow-control::before {
  width: 9px !important; /* Reduced from 12px */
  height: 9px !important;
  border-width: 1px !important;
}

/* ============================================================================
   PRODUCT PAGE FEATURED COLLECTION - Price 80% Opacity
   ============================================================================ */

.product-recommendations product-price,
.product-recommendations .price,
.product-recommendations product-price *,
.product-recommendations .price * {
  opacity: 0.8 !important;
}

/* ============================================================================
   REMOVE SOLD OUT BADGES - All Pages
   ============================================================================ */

.product-badges,
.badge,
.badge--sold-out,
[class*="sold-out"],
[class*="badge"] {
  display: none !important;
}

/* ============================================================================
   FEATURED COLLECTION - Disable hover effects on mobile
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Keep text hidden on mobile - no hover effects */
  .ui-test-product-list .spacing-style.text-block,
  .ui-test-product-list product-price,
  .ui-test-product-list .swym-wishlist-collections-v2-container {
    opacity: 0 !important;
  }
  
  /* Override all hover states on mobile */
  .ui-test-product-list li:hover .spacing-style.text-block,
  .ui-test-product-list li:hover product-price,
  .ui-test-product-list .product-card:hover .spacing-style.text-block,
  .ui-test-product-list .product-card:hover product-price,
  .ui-test-product-list product-card-link:hover .spacing-style.text-block,
  .ui-test-product-list product-card-link:hover product-price,
  .ui-test-product-list li:hover .swym-wishlist-collections-v2-container,
  .ui-test-product-list .product-card:hover .swym-wishlist-collections-v2-container,
  .ui-test-product-list product-card-link:hover .swym-wishlist-collections-v2-container {
    opacity: 0 !important;
  }
}

/* ============================================================================
   PRODUCT PAGE - Fix first image size on mobile (prevent JS resize)
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Target the slideshow items directly */
  .product-information__media .slideshow__item,
  slideshow-component .slideshow__item {
    width: 100% !important;
    max-width: 100% !important;
  }
  
  /* Force all images to fill container */
  .product-information__media img,
  slideshow-component img,
  .slideshow__item img,
  .media img {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1.4 !important;
    object-fit: cover !important;
  }
  
  /* Force media wrapper to be full size */
  .media,
  .media--transparent {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1.4 !important;
  }
  
  /* Prevent slideshow from setting custom widths */
  slideshow-component[style*="width"],
  .slideshow[style*="width"],
  .slideshow__item[style*="width"] {
    width: 100% !important;
  }
}

/* ============================================================================
   MOBILE - Carousel 80vh with chevrons at bottom
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Remove padding from body so carousel starts at top */
  body {
    padding-top: 0 !important;
  }
  
  /* Make header transparent on mobile */
  .header,
  .header__row,
  .header-component {
    background: transparent !important;
    background-color: transparent !important;
  }
  
  /* Remove header pseudo-element backgrounds */
  .header::before,
  .header::after,
  .header__row::before,
  .header__row::after {
    display: none !important;
  }
  
  /* Remove top padding/margin from product page */
  main#MainContent[data-template="product"] {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Remove section padding */
  .product-information.section {
    padding-top: 0 !important;
    padding-block-start: 0 !important;
    margin-top: 0 !important;
  }
  
  /* Force product grid to have no spacing */
  .product-information__grid {
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
  }
  
/* Carousel fills space above sticky bar */
  .product-information__media,
  .product-information__media slideshow-component,
  .product-information__media slideshow-container,
  .product-information__media slideshow-slides,
  .product-information__media media-gallery {
    margin: 0 !important;
    padding: 0 !important;
    height: calc(100dvh - 134px) !important;
  }
  
  /* Slides should be full height */
  .product-information__media slideshow-slide {
    height: calc(100dvh - 134px) !important;
  }
  
  /* Make images fill the container */
  .product-information__media img,
  .product-information__media .media {
    height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
  }
  
  /* Only hide title and buy buttons */
  .product-details h1,
  .product-details .buy-buttons-block {
    display: none !important;
  }

@media screen and (max-width: 1024px) {
  
  /* Smooth container and image scaling */
  .product-information__media,
  .product-information__media slideshow-component,
  .product-information__media slideshow-container,
  .product-information__media slideshow-slides,
  .product-information__media media-gallery,
  .product-information__media slideshow-slide {
    transition: height 0.3s ease-out !important;
    -webkit-transition: height 0.3s ease-out !important;
  }
  
  .product-information__media img {
    transition: all 0.3s ease-out !important;
    -webkit-transition: all 0.3s ease-out !important;
  }
}

@media screen and (max-width: 1024px) {
  
  /* Hide default pagination dots */
  .product-information__media slideshow-controls,
  .product-information__media .slideshow-pagination,
  .product-information__media [class*="pagination"] {
    display: none !important;
  }
  
  /* Custom progress line container */
  .carousel-progress {
   position: absolute !important;
   bottom: 0 !important;
   left: 0 !important;
   right: 0 !important;
   height: 2px !important;
   background: transparent !important;
   z-index: 50 !important;
  }

/* The sliding black line */
.carousel-progress__line {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  height: 2px !important;
  background: rgba(0, 0, 0, 0.75) !important;
  transition: transform 0.3s ease-out !important;
}

 /* ============================================================================
   MOBILE - Sticky Bar
   ============================================================================ */
   
/* Sticky bar */
  .sticky-atc-bar {
    display: flex !important;
    position: fixed !important;
    top: auto !important;  /* Changed from 80vh */
    bottom: 0 !important;
    bottom: env(safe-area-inset-bottom, 0) !important;
    left: 0 !important;
    right: 0 !important;
    background: white !important;
    background-color: white !important;
    padding: 15px !important;
    padding-bottom: calc(10px + env(safe-area-inset-bottom, 0)) !important;  /* Your padding + safe area */
    margin: 0 !important;
    border-top: 1px solid rgba(0, 0, 0, 0.25) !important;
    z-index: 9999 !important;
    flex-direction: column !important;
    gap: 8px !important;
    height: auto !important;  /* Size to content */
    transform: translateZ(0) !important;
    -webkit-transform: translateZ(0) !important;
  }

  .sticky-atc-bar {
    min-height: 134px !important;  /* Prevents initial shorter state */
  }
  
  .sticky-atc-bar__top {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 8px !important;
  }
  
  .sticky-atc-bar__product-name {
    font-size: 17px !important;
    font-weight: 500 !important;
    margin: 0 !important;
    flex: 1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  
  .sticky-atc-bar__wishlist {
    flex-shrink: 0 !important;
  }
  
  .sticky-atc-bar__button {
    width: 100% !important;
  }
  
  .sticky-atc-bar__button button {
    width: 100% !important;
  }
}

 /* ============================================================================
   MOBILE - Sticky Bar Scroll Behaviour
   ============================================================================ */
   
@media screen and (max-width: 1024px) {
  .custom-mobile-sticky-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 10;
    transition: transform 0.3s ease;
  }
  
  .custom-mobile-sticky-bar.scrolled-past-trigger {
    position: absolute;
    bottom: auto;
    top: var(--trigger-offset, 0px);
  }
}

/* ============================================================================
   MOBILE - Wishlist styling
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Style wishlist container */
  .sticky-atc-bar__wishlist {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }
  
  /* Make sure moved wishlist is visible */
  .sticky-atc-bar__wishlist .swym-wishlist-collections-v2-container {
    position: static !important;
    display: block !important;
  }
}
/* ============================================================================
   MOBILE - Resize wishlist in sticky bar
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Center the container */
  .sticky-atc-bar__wishlist {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  /* Scale down the entire wishlist - this keeps proportions perfect */
  .sticky-atc-bar__wishlist .swym-atw-btn-wrapper-for-img {
    transform: scale(0.8) !important;
    transform-origin: center center !important;
  }
  
  /* Thin stroke */
  .sticky-atc-bar__wishlist svg path {
    stroke-width: 1px !important;
  }
}

/* ============================================================================
   PRODUCT DETAILS DRAWER - Tab Switch Animations (Desktop Only)
   ============================================================================ */

/* Desktop only - smooth content transitions */
@media screen and (min-width: 1025px) {
  .custom-drawer-content {
    opacity: 1;
    transform: translateX(0);
    will-change: opacity, transform;
  }
}

/* ============================================================================
   MOBILE DRAWER - Tab navigation with dynamic height
   ============================================================================ */

/* Desktop: Hide mobile drawer, show buttons */
@media screen and (min-width: 1025px) {
  .mobile-drawer-container {
    display: none !important;
  }
}

/* Mobile: Hide buttons, show tab drawer */
@media screen and (max-width: 1024px) {
  
  /* Hide desktop buttons */
  .product-details-buttons {
    display: none !important;
  }
  
  /* Show mobile drawer */
  .mobile-drawer-container {
    display: block !important;
    width: 100% !important;
    margin: 0px 0 0 0 !important;
    padding: 0 !important;
  }
  
  /* Tab navigation */
  .mobile-drawer__tabs {
    display: flex !important;
    background: white !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.25) !important;
    justify-content: space-between !important;
    padding: 0 !important;
    margin: 0 !important;
    position: relative !important;
  }
  
  .mobile-drawer__tab {
    flex: 0 0 auto !important;
    padding: 16px 0 !important;
    text-align: center !important;
    border: none !important;
    background: transparent !important;
    cursor: pointer !important;
    font-size: 13px !important;
    color: #666 !important;
    transition: color 0.3s ease !important;
    font-family: 'FuturaPTBook', sans-serif !important;
    position: relative !important;
    -webkit-tap-highlight-color: transparent !important;
    -webkit-touch-callout: none !important;
    user-select: none !important;
  }
  
  .mobile-drawer__tab.active {
    color: #000 !important;
    font-weight: 500 !important;
  }
  
  /* Sliding underline - positioned absolutely */
  .mobile-drawer__sliding-underline {
    position: absolute !important;
    bottom: -1px !important;
    height: 1px !important;
    background: #000 !important;
    transition: left 0.3s cubic-bezier(0.4, 0, 0.2, 1), width 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    pointer-events: none !important;
    z-index: 1 !important;
  }
  
  /* First tab - align left, flush with border */
  .mobile-drawer__tab:first-child {
    margin-right: auto !important;
    padding-left: 0 !important;
  }
  
  /* Last tab - align right, flush with border */
  .mobile-drawer__tab:last-child {
    margin-left: auto !important;
    padding-right: 0 !important;
  }
  
  /* Middle tab - stays centered between the two */
  .mobile-drawer__tab:nth-child(2) {
    position: absolute !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
  }
  
  /* Container - DYNAMIC HEIGHT with smooth transition */
  .mobile-drawer__swipe-container {
    display: block !important;
    position: relative !important;
    overflow: hidden !important;
    width: 100% !important;
    background: white !important;
    transition: height 0.3s ease !important;
  }
  
  .mobile-drawer__swipe-wrapper {
    display: flex !important;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    align-items: flex-start !important;
  }
  
  /* Individual panels */
  .mobile-drawer__panel {
    flex-shrink: 0 !important;
    width: 100% !important;
    padding: 24px 20px !important;
    box-sizing: border-box !important;
    text-align: center !important;
  }
  
  .mobile-drawer__panel h3 {
    font-size: 14px !important;
    margin-bottom: 12px !important;
    margin-top: 12px !important;
    font-weight: 600 !important;
    text-align: center !important;
  }
  
  .mobile-drawer__panel p {
    font-size: 14px !important;
    line-height: 1.6 !important;
    color: #666 !important;
    margin-bottom: 12px !important;
    text-align: center !important;
  }
  
  /* HIDE pagination dots */
  .mobile-drawer__indicators {
    display: none !important;
  }
  
  .mobile-drawer__indicator {
    display: none !important;
  }
}

/* ============================================================================
   MOBILE DRAWER - Hide on Desktop
   ============================================================================ */

@media screen and (min-width: 1025px) {
  .mobile-drawer-container {
    display: none !important;
  }
}

/* ============================================================================
   PRODUCT PAGE MOBILE - Layout & Alignment
   ============================================================================ */

@media screen and (max-width: 1024px) {
  
  /* Hide "TABLES" collection text */
  p:has(> a[href*="/collections/"]) {
    display: none !important;
  }
  
  /* Alternative - target by text content if above doesn't work */
  .text-block[style*="text-align: left"] p {
    display: none !important;
  }
  
 /* Center align "6 Person Dining Table" brief text - FORCE IT */
rte-formatter,
.rte-formatter,
rte-formatter *,
.rte-formatter *,
.text-block--AUUxMai9LZ20yL0RxM__text_GHkggi,
.text-block--AUUxMai9LZ20yL0RxM__text_GHkggi * {
  text-align: center !important;
  display: block !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

rte-formatter p,
.rte-formatter p {
  text-align: center !important;
  width: 100% !important;
}
  
  rte-formatter p,
  .rte-formatter p {
    text-align: center !important;
  }
  
  /* Center align variant picker title (Color label) */
  .variant-option legend,
  .variant-picker legend {
    text-align: center !important;
    width: 100% !important;
    display: block !important;
  }
  
  /* Center swatches but keep them close together */
  fieldset.variant-option--swatches {
    display: flex !important;
    justify-content: center !important;
    gap: 12px !important;
  }
  
  .variant-picker__form {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  
  /* Reset swatch spacing to keep them tight */
  .variant-option__button-label {
    margin: 0 !important;
  }
}
@media screen and (max-width: 1024px) {
  
  /* Make all text same size on product page - except sticky bar */
  .product-information *,
  .product-details *,
  .mobile-drawer-container * {
    font-size: 15px !important;
  }
  
  /* Keep sticky bar product name at original size */
  .sticky-atc-bar__product-name {
    font-size: 17px !important; /* Or whatever the original size was */
  }
}

@media screen and (max-width: 1024px) {
  
  /* Hide default pagination dots */
  .product-information__media slideshow-controls,
  .product-information__media .slideshow-pagination,
  .product-information__media [class*="pagination"] {
    display: none !important;
  }
  
  /* Custom progress line container */
  .carousel-progress {
    position: absolute !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    height: 2px !important;
    background: transparent !important;
    z-index: 50 !important;
  }
  
  /* The sliding black line */
  .carousel-progress__line {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    height: 2px !important;
    background: #000 !important;
    transition: transform 0.3s ease-out !important;
  }
}

/* Desktop add to cart button - adjust internal padding */
button.add-to-cart-button {
  padding-left: 32px !important; /* Space from left edge to icon */
  padding-right: 32px !important; /* Space from right edge to price */
}

/* Space between shopping bag icon and "ADD TO CART" text */
button.add-to-cart-button .svg-wrapper {
  margin-right: 16px !important;
}

/* Space between "ADD TO CART" text and price */
button.add-to-cart-button .add-to-cart-text {
  margin-right: 24px !important; /* Space between text and price */
}

/* Ensure button content is properly distributed */
button.add-to-cart-button > grid {
  gap: 16px !important; /* Overall spacing between elements */
}

/* ============================================================================
   COLLECTION PAGE MOBILE - Show Product Titles
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Force product title containers to be visible */
  .product-card .text-block,
  .product-grid__card .text-block,
  [class*="product_title"] {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    height: auto !important;
    min-height: 1px !important;
  }
  
  /* Make sure paragraph titles are visible */
  .product-card .text-block p,
  .product-grid__card .text-block p {
    display: block !important;
    opacity: 1 !important;
    font-size: 13px !important;
    line-height: 1.4 !important;
    margin: 8px 0 !important;
  }
  
  /* Fix truncation for all title types */
  .product-card :is(h4, .h4, p),
  .product-grid__card :is(h4, .h4, p) {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 2 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
}

/* ============================================================================
   COLLECTION PAGE MOBILE - Reduce Gap Between Title and Price
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Reduce gap in product card */
  .product-grid__card {
    gap: 1px !important; /* Reduced from default */
  }
  
  /* Remove extra margins from title */
  .product-card .text-block,
  .product-grid__card .text-block {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
  }
  
  /* Remove extra margins from title paragraph */
  .product-card .text-block p,
  .product-grid__card .text-block p {
    margin: 0 !important;
    margin-bottom: 1px !important; /* Small gap between title and price */
  }
  
  /* Remove extra margins from price */
  .product-card product-price,
  .product-grid__card product-price {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }
}

/* ============================================================================
   COLLECTION PAGE MOBILE - Adjust Padding Around Price
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Reduce space between product image and title */
  .product-card .card-gallery,
  .product-grid__card .card-gallery {
    margin-bottom: 6px !important; /* Adjust this value - smaller = closer */
  }
  
  /* Reduce space between title and price */
  .product-card .text-block p,
  .product-grid__card .text-block p {
    margin-bottom: 2px !important; /* Space between title and price */
  }
  
  /* Add space below the price */
  .product-card product-price,
  .product-grid__card product-price {
    margin-bottom: 16px !important; /* Space below price - adjust as needed */
    padding-bottom: 0 !important;
  }
}

css/* Top and bottom border only option for sections */
.border-style[style*="--border-style: top-bottom"] {
  border-top: var(--border-width) solid var(--border-color) !important;
  border-bottom: var(--border-width) solid var(--border-color) !important;
  border-left: none !important;
  border-right: none !important;
}

/* ============================================================================
   Card Gallery Arrows - Fade out animation
   ============================================================================ */

@keyframes arrowsFadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}

.card-gallery slideshow-arrows.fading-out .slideshow-control {
  animation: arrowsFadeOut 1.0s ease-out forwards !important;
}
}

/* ============================================================================
   MOBILE FULLSCREEN IMAGE DRAWER
   ============================================================================ */

/* Only apply on mobile */
@media screen and (max-width: 1024px) {
  
  /* -------------------------------------------------------------------------
     DRAWER OVERLAY - Full screen container
     ------------------------------------------------------------------------- */
  .mobile-image-drawer {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: white;
    z-index: 99999;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    display: flex;
    flex-direction: column;
  }
  
  .mobile-image-drawer.active {
    opacity: 1;
    visibility: visible;
  }
  
  /* -------------------------------------------------------------------------
     DRAWER HEADER - Logo placement
     ------------------------------------------------------------------------- */
  .mobile-image-drawer__header {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    padding: 0 20px;
    pointer-events: none;
  }
  
  .mobile-image-drawer__logo {
    max-width: 140px;
    max-height: 55px;
    width: auto;
    height: auto;
    object-fit: contain;
    position: relative;
    top: 0px;
    left: 0px;
    opacity: 1;
  }
  
  /* -------------------------------------------------------------------------
     CLOSE BUTTON - White circle with X
     ------------------------------------------------------------------------- */
  .mobile-image-drawer__close {
    position: absolute;
    z-index: 3;
    top: 15px;
    right: 10px;
    width: 40px;
    height: 40px;
    background-color: white;
    border-radius: 50%;
    border: none;
    outline: none;
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
    -webkit-tap-highlight-color: transparent;
  }
  
  .mobile-image-drawer__close:hover,
  .mobile-image-drawer__close:focus {
    background-color: white;
    outline: none;
    box-shadow: none;
  }
  
  .mobile-image-drawer__close-icon {
    width: 14px;
    height: 14px;
    position: relative;
  }
  
  .mobile-image-drawer__close-icon::before,
  .mobile-image-drawer__close-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 12px;
    height: 0.75px;
    background-color: black;
  }
  
  .mobile-image-drawer__close-icon::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }
  
  .mobile-image-drawer__close-icon::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }
  
  /* -------------------------------------------------------------------------
     IMAGE CAROUSEL - FULLSCREEN
     ------------------------------------------------------------------------- */
  .mobile-image-drawer__carousel {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
  }
  
  .mobile-image-drawer__slides {
    display: flex;
    height: 100%;
    width: 100%;
    transition: transform 0.3s ease-out;
    touch-action: pan-x;
  }
  
  .mobile-image-drawer__slide {
    flex: 0 0 100%;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin: 0;
  }
  
  .mobile-image-drawer__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  
  /* -------------------------------------------------------------------------
     PROGRESS LINE - Sliding indicator at bottom
     ------------------------------------------------------------------------- */
  .mobile-image-drawer__progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: transparent;
    z-index: 2;
  }
  
  .mobile-image-drawer__progress-line {
    position: absolute;
    top: 0;
    left: 0;
    height: 2px;
    background: rgba(0, 0, 0, 0.75);
    transition: transform 0.3s ease-out;
  }
}

/* Hide drawer completely on desktop */
@media screen and (min-width: 1025px) {
  .mobile-image-drawer {
    display: none !important;
  }
}

/* ============================================================================
   COLLECTION PAGE - Custom Chevrons (same as home/product pages)
   ============================================================================ */

/* Hide the existing arrow SVG */
.product-grid slideshow-arrows .slideshow-control svg,
.product-grid slideshow-arrows .slideshow-control .svg-wrapper,
.product-grid slideshow-arrows .slideshow-control .icon-arrow {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

/* Create chevron using ::before */
.product-grid slideshow-arrows .slideshow-control::before {
  content: '' !important;
  display: block !important;
  width: 9px !important;
  height: 9px !important;
}

/* Left chevron - FIXED ROTATION */
.product-grid slideshow-arrows .slideshow-control--previous::before {
  border-bottom: 1px solid white !important;
  border-left: 1px solid white !important;
  transform: rotate(225deg) !important;
}

/* Right chevron */
.product-grid slideshow-arrows .slideshow-control--next::before {
  border-bottom: 1px solid white !important;
  border-right: 1px solid white !important;
  transform: rotate(-45deg) !important;
}

/* ============================================================================
   MOBILE - Variant picker centering & View All Finishes repositioning
   ============================================================================ */

@media screen and (max-width: 1024px) {
  /* Center the legend (contains color name) */
  fieldset.variant-option--swatches legend {
    text-align: center !important;
    width: 100% !important;
    display: block !important;
  }
  
  /* Center the color value text */
  .variant-option__swatch-value {
    display: block !important;
    text-align: center !important;
    width: 100% !important;
  }
  
  /* Hide original View All Finishes button in legend */
  fieldset.variant-option--swatches legend .view-all-finishes-btn {
    display: none !important;
  }
  
  /* Center the swatches */
  fieldset.variant-option--swatches {
    justify-content: center !important;
  }

  /* Force underline on mobile View All Finishes button - iOS fix */
  .view-all-finishes-mobile {
   position: relative !important;
   text-decoration: none !important;
  }

/* Variant picker text color - match site color */
.variant-option__swatch-value {
  color: #2e2e2e !important;
}

.view-all-finishes-btn,
.view-all-finishes-mobile {
  color: #2e2e2e !important;
}

.view-all-finishes-mobile::after {
  background-color: #2e2e2e !important;
}

/* ============================================================================
   VIEW ALL FINISHES BUTTON - Pure CSS Solution
   ============================================================================ */

/* Make fieldset the positioning context */
fieldset.variant-option--swatches {
  position: relative !important;
}

/* Position button absolutely within fieldset, aligned to right of swatch row */
fieldset.variant-option--swatches legend .view-all-finishes-btn {
  position: absolute !important;
  top: calc(-14px) !important;  /* Position below legend, on swatch row */
  right: 0 !important;
  left: auto !important;
  display: inline-block !important;
  font-family: 'FuturaPTBook', sans-serif !important;
  font-size: 14px !important;
  line-height: 20px !important;
  color: #2e2e2e !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  z-index: 10 !important;
}

/* Permanent underline */
fieldset.variant-option--swatches legend .view-all-finishes-btn::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0px !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  height: 1px !important;
  background-color: #2e2e2e !important;
}

/* ============================================================================
   MOBILE - Hide in legend, JS creates centered version below swatches
   ============================================================================ */

@media screen and (max-width: 1024px) {
  fieldset.variant-option--swatches legend .view-all-finishes-btn {
    display: none !important;
  }
}

/* ============================================================================
   MOBILE - Change paddting at top of details block on mobile only
   ============================================================================ */
@media screen and (max-width: 1024px) {
  .product-details .group-block {
    --padding-block-start:10px !important;
    padding-block-start: 10px !important;
  }
}