/** Shopify CDN: Minification failed

Line 6032:0 Unexpected "{"
Line 6032:1 Expected identifier but found "%"
Line 6034:2 Unexpected "{"
Line 6034:3 Expected identifier but found "%"
Line 6037:41 Unexpected "{"
Line 6037:50 Expected ":"
Line 6037:57 Unexpected "{"
Line 6038:30 Expected identifier but found whitespace
Line 6038:32 Unexpected "{"
Line 6038:41 Expected ":"
... and 209 more hidden warnings

**/
* {
  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);
  --submenu-animation-speed: 360ms;
  --submenu-animation-easing: cubic-bezier(0.25, 0.1, 0.25, 1);
}

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,
textarea:hover {
  background-color: var(--color-input-hover-background);
}

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

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

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

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

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

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

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

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

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

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

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

@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 .predictive-search-results__card:hover {
    transform: translateY(calc(-1 * var(--hover-lift-amount)));
  }

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

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

  .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 .predictive-search-results__card:hover {
    transform: scale(var(--hover-subtle-zoom-amount));
  }

}

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;
  display: flex;
  flex-direction: column;
}

.content-for-layout > .shopify-section:last-child {
  flex-grow: 1;
}

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

  text-align: left;
}

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

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

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

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

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

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

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

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

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

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

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

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

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

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

.relative {
  position: relative;
}

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

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

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

.icon-default {
  fill: currentColor;
}

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

/* Base text and heading styles */
body,
.paragraph:not(.button),
.paragraph > *,
.text-block.paragraph :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h1 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h2 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h3 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h4 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h5 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h6 :is(h1, h2, h3, h4, h5, 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-secondary)),
.rte :is(p, ul, ol, table):not(.h1, .h2, .h3, .h4, .h5, .h6) a:where(:not(.button, .button-secondary)) {
  text-decoration-color: currentcolor;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    footer {
      view-transition-name: footer;
    }

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

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

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

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

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

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

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

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

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

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

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

.text-block {
  width: 100%;
}

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

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

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

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

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

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

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

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

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

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

  &::backdrop {
    opacity: 0;
  }
}

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

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

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

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

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

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

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

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

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

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

  display: grid;
  align-content: center;
  text-decoration: none;
  text-align: var(--text-align);
  color: var(--button-color);
  appearance: none;
  background-color: var(--button-background-color);
  border: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
  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:not([type='checkbox'], [type='radio']) {
  background-color: var(--color-input-background);
  border-color: var(--color-input-border);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

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

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

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

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

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

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

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

/* Collapsible row */

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

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

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

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

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

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

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

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

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

:not(.dialog-zoomed-gallery) > .product-media-container {
  --slide-width: 100%;

  display: flex;
  aspect-ratio: var(--gallery-aspect-ratio, var(--media-preview-ratio));
  max-height: var(--constrained-height);
  width: var(--slide-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;
  }

  @supports (--test: round(up, 100%, 1px)) {
    /* width and overflow forces children to shrink to parent width */
    --slide-width: round(up, 100%, 1px);
  }
}

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

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

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

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

  .media-gallery--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;
  }
}

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

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

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

: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 {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Variant option component */
.variant-option {
  --options-border-radius: var(--variant-picker-button-radius);
  --options-border-width: var(--variant-picker-button-border-width);
  --variant-option-padding-inline: var(--padding-md);
}

.variant-option + .variant-option {
  margin-top: var(--padding-lg);
}

.variant-option--swatches {
  --options-border-radius: var(--variant-picker-swatch-radius);

  width: 100%;

  overflow-list::part(list) {
    padding-block: var(--overflow-list-padding-block, 0);
    padding-inline: var(--overflow-list-padding-inline, 0);
  }
}

.variant-option--swatches > overflow-list {
  justify-content: var(--product-swatches-alignment);

  @media screen and (max-width: 749px) {
    justify-content: var(--product-swatches-alignment-mobile);
  }
}

.variant-option--buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-sm);
  margin: 0;
  padding: 0;
  border: none;
}

.variant-option--buttons legend {
  padding: 0;
  margin-block-end: var(--margin-xs);
}

.variant-option__swatch-value {
  padding-inline-start: var(--padding-xs);
  color: rgb(var(--color-foreground-rgb) / var(--opacity-70));
}

@media (prefers-reduced-motion: no-preference) {
  .variant-option__button-label,
  .variant-option__select-wrapper,
  .variant-option__button-label::before,
  .variant-option__button-label::after,
  .variant-option__button-label:has([data-previous-checked='true'], [data-current-checked='true'])
    .variant-option__button-label__pill,
  .variant-option__button-label:not(.variant-option__button-label--has-swatch) svg line:last-of-type {
    transition-duration: var(--animation-speed);
    transition-timing-function: var(--animation-easing);
  }

  .variant-option__button-label__pill {
    transition-property: transform;
  }

  .variant-option__button-label:not(.variant-option__button-label--has-swatch) svg line:last-of-type {
    transition-property: clip-path;
  }

  .variant-option__button-label:has([data-previous-checked='true'], [data-current-checked='true'])
    .variant-option__button-label__pill {
    transition-property: transform;
  }

  .variant-option__button-label::after {
    transition-property: clip-path;
  }

  .variant-option__button-label::before {
    transition-property: border-color;
  }

  .variant-option__select-wrapper,
  .variant-option__button-label {
    transition-property: background-color, border-color, color;
  }
}

.variant-option__button-label {
  --variant-picker-stroke-color: var(--color-variant-border);

  cursor: pointer;
  display: flex;
  flex: 0 0 3.25em;
  align-items: center;
  position: relative;
  padding-block: var(--padding-sm);
  padding-inline: var(--padding-lg);
  border: var(--options-border-width) solid var(--color-variant-border);
  border-radius: var(--options-border-radius);
  overflow: clip;
  justify-content: center;
  min-height: 3.25em;
  min-width: fit-content;
  white-space: nowrap;
  background-color: var(--color-variant-background);
  color: var(--color-variant-text);
  gap: 0;

  &:hover,
  &:hover:has([aria-disabled='true']):has([data-option-available='false']) {
    background-color: var(--color-variant-hover-background);
    border-color: var(--color-variant-hover-border);
    color: var(--color-variant-hover-text);
  }

  /* we need something like overflow-clip-margin to use the pseudoelement but it doesn't work in Safari */

  /* so instead use the layered background image trick */
  &:not(.variant-option__button-label--has-swatch):has([data-option-available='false']) {
    border-width: 0;
  }

  /* ::after/::before act as a fake border for the button style variant */

  /* ::after is the unavailable variant border that clips in */
  &:not(.variant-option__button-label--has-swatch)::before,
  &:has([data-option-available='false']):not(.variant-option__button-label--has-swatch)::after {
    content: '';
    position: absolute;
    inset: 0;
    border: var(--options-border-width) solid var(--color-selected-variant-border);
    border-radius: inherit;
    pointer-events: none;
    z-index: 2;
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(var(--clip, 0 0 0 0));
  }

  &:has([data-option-available='false']):not(.variant-option__button-label--has-swatch)::before {
    inset: 0;
  }

  &:not(.variant-option__button-label--has-swatch)::before {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(0 0 0 0);
    border-color: var(--color-variant-border);
    inset: calc(var(--options-border-width) * -1);
  }

  &:has(:checked):not(.variant-option__button-label--has-swatch, :has([data-option-available='false']))::before {
    border-color: var(--color-selected-variant-border);
  }

  /* setting left/right accounts for variant buttons of different widths */
  &:not(:has(:checked)):has(~ label > :checked),
  &:has(:checked):has(~ label > [data-previous-checked='true']) {
    .variant-option__button-label__pill {
      right: 0;
      left: unset;
    }
  }

  &:has([data-previous-checked='true']) ~ label:has([data-current-checked='true']),
  &:has(:checked) ~ label {
    .variant-option__button-label__pill {
      left: 0;
      right: unset;
    }
  }

  &:not(:has(:checked)):has(~ label > :checked) {
    --pill-offset: calc(100% + 1px);
  }

  &:has(:checked) ~ label {
    --pill-offset: calc(-100% - 1px);
  }

  &:has([data-current-checked='true']):first-of-type
    ~ label:last-of-type:not(.variant-option__button-label--has-swatch),
  &:not(:has(:checked)):has(~ label > :checked):not(.variant-option__button-label--has-swatch) {
    --clip: 0 0 0 100%;
  }

  &:not(:has([data-current-checked='true'])):first-of-type:has(~ label:last-of-type > :checked):not(
      .variant-option__button-label--has-swatch
    ),
  &:has(:checked) ~ label:not(.variant-option__button-label--has-swatch) {
    --clip: 0 100% 0 0;
  }

  &:has([data-previous-checked='true'], [data-current-checked='true']) .variant-option__button-label__pill {
    width: max(var(--pill-width-current, 100%), var(--pill-width-previous, 100%));
  }

  @media screen and (min-width: 750px) {
    padding: var(--padding-xs) var(--variant-option-padding-inline);
  }
}

/* wrap around only for 3 or more variants in a row */

/* the more complex selector rules here produce the wrap around effect for first/last variants */
.variant-option--buttons:has(:nth-of-type(3)) {
  .variant-option__button-label:has([data-current-checked='true']):first-of-type ~ label:last-of-type {
    --pill-offset: calc(100% + 1px);
  }

  .variant-option__button-label:not(:has([data-current-checked='true'])):first-of-type:has(
      ~ label:last-of-type > :checked
    ) {
    --pill-offset: calc(-100% - 1px);
  }
}

.variant-option__button-label__pill {
  background: var(--color-selected-variant-background);
  position: absolute;
  top: calc(var(--options-border-width) * -1);
  bottom: calc(var(--options-border-width) * -1);
  border-radius: inherit;
  pointer-events: none;
  width: 100%;
  transform: translateX(var(--pill-offset, 0));
}

.variant-option__button-label__text {
  pointer-events: none;
  text-align: start;
  text-wrap: auto;
  z-index: 2;
}

.variant-option--equal-width-buttons {
  --variant-min-width: clamp(44px, calc(var(--variant-option-padding-inline) * 2 + var(--variant-ch)), 100%);

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--variant-min-width), 1fr));

  .variant-option__button-label {
    min-width: var(--variant-min-width);
  }

  .variant-option__button-label__text {
    text-align: center;
    text-wrap: balance;
  }
}

.variant-option__button-label:has(:focus-visible) {
  --variant-picker-stroke-color: var(--color-foreground);

  border-color: var(--color-foreground);
  outline: var(--focus-outline-width) solid var(--color-foreground);
  outline-offset: var(--focus-outline-offset);
}

.variant-option__button-label--has-swatch {
  --focus-outline-radius: var(--variant-picker-swatch-radius);

  padding: 0;
  border: none;
  flex-basis: auto;
  min-height: auto;
}

/* Override global label:has(input) display rule with higher specificity */
.variant-option__button-label--has-swatch:has(input) {
  display: block;
}

.variant-option__button-label:has(:checked) {
  color: var(--color-selected-variant-text);
  border-color: var(--color-selected-variant-border);
}

.variant-option__button-label:has(:checked):hover {
  border-color: var(--color-selected-variant-hover-border);
  color: var(--color-selected-variant-hover-text);

  .variant-option__button-label__pill {
    background-color: var(--color-selected-variant-hover-background);
  }
}

.variant-option__button-label:has([data-option-available='false']) {
  color: rgb(var(--color-variant-text-rgb) / var(--opacity-60));
}

.variant-option__button-label--has-swatch:hover {
  outline: var(--focus-outline-width) solid rgb(var(--color-foreground-rgb) / var(--opacity-35-55));
  outline-offset: var(--focus-outline-offset);
}

.variant-option__button-label--has-swatch:has(:checked) {
  --focus-outline: var(--focus-outline-width) solid var(--color-foreground);

  outline: var(--focus-outline);
  outline-offset: var(--focus-outline-offset);
}

/* 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. **/
  .variant-option__button-label--has-swatch:has(:checked),
  .variant-option__button-label:has(:focus-visible) .swatch {
    outline: none;
    position: relative;
    overflow: visible;
  }

  .variant-option__button-label--has-swatch:has(:checked)::after,
  .variant-option__button-label:has(:focus-visible) .swatch::after {
    content: '';
    position: absolute;
    inset: calc(-1 * var(--focus-outline-offset));
    border: var(--focus-outline);
    border-radius: var(--focus-outline-radius, 50%);
    background-color: transparent;
    display: inherit;
  }
}

.variant-option__button-label:has([data-option-available='false']):has(:checked) {
  background-color: inherit;
  color: rgb(var(--color-variant-text-rgb) / var(--opacity-60));
}

.variant-option__button-label input {
  /* remove the checkbox from the page flow */
  position: absolute;

  /* set the dimensions to match those of the label */
  inset: 0;

  /* hide it */
  opacity: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: unset;
  border: none;
  border-radius: 0;
  background: transparent;
  appearance: auto;
  display: block;
  cursor: pointer;
}

.variant-option__button-label svg {
  position: absolute;
  left: var(--options-border-width);
  top: var(--options-border-width);
  height: calc(100% - (var(--options-border-width) * 2));
  width: calc(100% - (var(--options-border-width) * 2));
  cursor: pointer;
  pointer-events: none;
  stroke-width: var(--style-border-width);
  stroke: var(--variant-picker-stroke-color);
}

.variant-option__button-label:not(.variant-option__button-label--has-swatch) svg {
  stroke: var(--color-variant-border);

  line {
    stroke-width: var(--options-border-width);
  }

  line:last-of-type {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(var(--clip, 0 0 0 0));
    stroke: rgb(var(--color-variant-text-rgb) / 1);
  }
}

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

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

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

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

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

.tax-note:empty {
  display: none;
}

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

/* Volume pricing note should match unit-price styling (small, grey text) */
product-price .volume-pricing-note,
product-price.text-block:is(.h1, .h2, .h3, .h4, .h5, .h6) .volume-pricing-note {
  display: block;
  font-family: var(--font-body--family);
  font-weight: normal;
  font-size: var(--font-size--xs);
  line-height: normal;
  letter-spacing: normal;
  text-transform: none;
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

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

.price-item__group {
  display: inline-block;
}

.price-item--sale {
  white-space: nowrap;
}

.price__hidden {
  display: none;
}

form.payment-terms {
  padding-top: 0.5em;
  font-size: min(0.85em, var(--font-paragraph--size));
  font-weight: var(--font-paragraph--weight);
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

.installments:not(:has(shopify-payment-terms)) {
  display: none;
}

.card-gallery {
  position: relative;
}

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

/* Hide "Add" button when "Choose" button is shown */
[data-quick-add-button='choose'] add-to-cart-component {
  display: none;
}

/* Hide "Choose" button when "Add" button is shown */
[data-quick-add-button='add'] .quick-add__button--choose {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    > .group-block--height-fill {
      height: calc(var(--section-min-height, auto) - var(--section-height-offset, 0px));
    }
  }
}

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

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

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

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

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

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

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

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

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

  :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-top: 50%;
  --checkbox-left: 1.5px;
  --checkbox-offset: 3px;
  --checkbox-path-opacity: 0;
  --checkbox-cursor: pointer;

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

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

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

.checkbox__input {
  position: absolute;
  opacity: 0;
  margin: 0;
  padding: 0;
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  aspect-ratio: unset;
  border: none;
  border-radius: 0;
  background: transparent;
  appearance: auto;
  display: block;
  cursor: pointer;

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

/* Radio buttons and checkboxes - shared base styles */
:where(input[type='radio']),
:where(input[type='checkbox']) {
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  aspect-ratio: 1;
  margin: 0;
  margin-inline-end: var(--padding-3xs);
  padding: 0;
  border: var(--checkbox-border);
  appearance: none;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
}

/* Radio buttons */
input[type='radio'] {
  border-radius: var(--style-border-radius-50);
  background: transparent;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

:where(input[type='radio']):checked {
  border-color: var(--color-foreground);
  background: var(--color-background);
}

:where(input[type='radio']):checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(var(--checkbox-size) / 2);
  height: calc(var(--checkbox-size) / 2);
  background: var(--color-foreground);
  border-radius: var(--style-border-radius-50);
  transition: background 0.2s ease;
}

:where(input[type='radio']):disabled {
  border-color: var(--input-disabled-border-color);
  background-color: var(--input-disabled-background-color);
  cursor: not-allowed;
}

:where(input[type='radio']):disabled:checked::after {
  background: var(--input-disabled-background-color);
}

:where(input[type='radio']):not(:disabled):hover {
  border-color: rgb(var(--color-foreground-rgb) / var(--opacity-40-60));
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

:where(input[type='radio']):not(:disabled):hover:checked {
  border-color: var(--color-foreground);
  background-color: var(--color-background);
}

:where(input[type='radio']):not(:disabled):hover:checked::after {
  background: rgb(var(--color-foreground-rgb) / var(--opacity-85));
}

/* Checkboxes */
:where(input[type='checkbox']) {
  border-radius: var(--checkbox-border-radius);
  background-color: var(--color-background);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

:where(input[type='checkbox']):checked {
  background-color: var(--color-foreground);
  border-color: var(--color-foreground);
}

:where(input[type='checkbox']):checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  background-color: var(--color-background);
  mask-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.75439 10.7485L7.68601 14.5888C7.79288 14.7288 7.84632 14.7988 7.91174 14.8242C7.96907 14.8466 8.03262 14.8469 8.09022 14.8253C8.15596 14.8007 8.21026 14.7314 8.31886 14.5927L15.2475 5.74658' stroke='black' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}

:where(input[type='checkbox']):not(:disabled):hover {
  border-color: rgb(var(--color-foreground-rgb) / var(--opacity-40-60));
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

:where(input[type='checkbox']):not(:disabled):hover:checked {
  border-color: var(--color-foreground);
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-85));
}

:where(input[type='checkbox']):disabled {
  background-color: var(--input-disabled-background-color);
  border-color: var(--input-disabled-border-color);
  cursor: not-allowed;
}

:where(input[type='checkbox']):disabled:checked::after {
  background-color: var(--input-disabled-text-color);
}

/* Shared styles for radio buttons and checkboxes */
:where(input[type='radio']) + label,
:where(input[type='checkbox']) + label {
  display: inline;
  vertical-align: middle;
  cursor: pointer;
}

:where(input[type='radio']):disabled + label,
:where(input[type='checkbox']):disabled + label {
  color: var(--input-disabled-text-color);
  cursor: not-allowed;
}

/* Flexbox for labels wrapping radio buttons or checkboxes */
label:has(input[type='radio']),
label:has(input[type='checkbox']) {
  display: inline-flex;
  align-items: center;
  gap: var(--padding-2xs);
  cursor: pointer;
}

label:has(input[type='radio']:disabled),
label:has(input[type='checkbox']:disabled) {
  cursor: not-allowed;
}

/* Override for swatch labels to maintain block display */
.variant-option__button-label--has-swatch:has(input[type='radio']) {
  display: block;
}

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

/* Cart items component */
.cart-items-component {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* Cart typography */
.cart-primary-typography {
  font-family: var(--cart-primary-font-family);
  font-style: var(--cart-primary-font-style);
  font-weight: var(--cart-primary-font-weight);
}

.cart-secondary-typography {
  font-family: var(--cart-secondary-font-family);
  font-style: var(--cart-secondary-font-style);
  font-weight: var(--cart-secondary-font-weight);
}

/* 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,
.quick-add-modal .quantity-selector {
  border-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-minus,
.quick-add-modal .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,
.quick-add-modal .quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-buttons-primary);
  border-end-end-radius: var(--style-border-radius-buttons-primary);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  animation-duration: 0.6s;
}

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

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

  animation-duration: 0.8s;
}

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

  5% {
    opacity: 1;
  }

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

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

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

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

/* Collection Wrapper - Shared layout CSS for collection and search pages */

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

.collection-wrapper {
  @media screen and (min-width: 750px) {
    --facets-vertical-col-width: 6;

    grid-template-columns:
      1fr repeat(
        var(--centered-column-number),
        minmax(0, calc((var(--page-width) - var(--page-margin) * 2) / var(--centered-column-number)))
      )
      1fr;
  }

  @media screen and (min-width: 990px) {
    --facets-vertical-col-width: 5;
  }
}

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

.collection-wrapper:has(.facets--vertical) .facets-block-wrapper--vertical:not(.hidden) ~ .main-collection-grid {
  @media screen and (min-width: 750px) {
    grid-column: var(--facets-vertical-col-width) / var(--full-width-column-number);
  }
}

.collection-wrapper:has(.facets-block-wrapper--vertical:not(#filters-drawer)):has(.collection-wrapper--full-width) {
  @media screen and (min-width: 750px) {
    grid-column: 1 / -1;
    grid-template-columns: 0fr repeat(var(--centered-column-number), minmax(0, 1fr)) 0fr;
  }
}

:is(.collection-wrapper--full-width, .collection-wrapper--full-width-on-mobile)
  [product-grid-view='default']
  .product-grid__card {
  @media screen and (max-width: 749px) {
    padding-inline-start: max(var(--padding-xs), var(--padding-inline-start));
    padding-inline-end: max(var(--padding-xs), var(--padding-inline-end));
  }
}

:is(.collection-wrapper--full-width, .collection-wrapper--full-width-on-mobile)
  [product-grid-view='mobile-single']
  .product-grid__card {
  @media screen and (max-width: 749px) {
    padding-inline-start: max(var(--padding-xs), var(--padding-inline-start));
    padding-inline-end: max(var(--padding-xs), var(--padding-inline-end));
  }
}

/* Make product media go edge-to-edge by using negative margins */
:is(.collection-wrapper--full-width) .card-gallery,
:is(.collection-wrapper--full-width-on-mobile) .card-gallery {
  @media screen and (max-width: 749px) {
    margin-inline-start: calc(-1 * max(var(--padding-xs), var(--padding-inline-start)));
    margin-inline-end: calc(-1 * max(var(--padding-xs), var(--padding-inline-end)));
  }
}

.collection-wrapper--full-width .main-collection-grid__title {
  margin-left: var(--page-margin);
}

.collection-wrapper--full-width-on-mobile .main-collection-grid__title {
  @media screen and (max-width: 749px) {
    margin-left: var(--page-margin);
  }
}

.collection-wrapper--grid-full-width .facets--vertical:not(.facets--drawer) {
  @media screen and (min-width: 750px) {
    padding-inline-start: max(var(--padding-sm), var(--padding-inline-start));
  }
}

.collection-wrapper:has(.product-grid-mobile--large) .facets-mobile-wrapper.facets-controls-wrapper {
  @media screen and (max-width: 749px) {
    display: none;
  }
}

.collection-wrapper:has(> .facets--horizontal) .facets__panel[open] {
  @media screen and (min-width: 750px) {
    z-index: var(--facets-open-z-index);
  }
}

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Slideshow Arrow Hover Animation - must stay in base.css for proper CSS cascade */

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

.product-card:hover,
.collection-card:hover,
.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);
}

.predictive-search-results__inner {
  flex-grow: 1;
  overflow-y: auto;
  padding-block: var(--padding-lg);
  container-type: inline-size;
  color: var(--color-foreground);
}

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

.product-recommendations {
  display: block;
}

.product-recommendations__skeleton-item {
  aspect-ratio: 3 / 4;
  background-color: var(--color-foreground);
  opacity: var(--skeleton-opacity);
  border-radius: 4px;
}

@media screen and (max-width: 749px) {
  .product-recommendations__skeleton-item:nth-child(2n + 1) {
    display: none;
  }
}

product-recommendations:has([data-has-recommendations='false']) {
  display: none;
}

.add-to-cart-button {
  --text-speed: 0.26;
  --base-delay: calc(var(--text-speed) * 0.25);
  --tick-speed: 0.1;
  --ring-speed: 0.2;
  --check-speed: 0.2;
  --burst-speed: 0.32;
  --step-delay: 3;
  --speed: 1;

  user-select: none;
  transition-property: color, box-shadow, background-color, scale, translate;
  transition-duration: var(--animation-speed);
  transition-timing-function: var(--ease-out-cubic);

  &:active {
    scale: 0.99;
    translate: 0 1px;
  }
}

.add-to-cart-button .svg-wrapper .checkmark-burst {
  width: 30px;
  height: 30px;
}

.add-to-cart-text {
  --atc-opacity: 0;
  --atc-destination: -1em;

  display: flex;
  gap: var(--gap-2xs);
  align-items: center;
  justify-content: center;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
  animation-fill-mode: forwards;
  transition: width var(--animation-speed) var(--animation-easing),
    opacity var(--animation-speed) var(--animation-easing);
}

.add-to-cart__added {
  --atc-opacity: 1;
  --atc-destination: 0px;

  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}

.add-to-cart__added-icon {
  width: 32px;
  height: 32px;
}

[data-added='true'] .add-to-cart-text,
[data-added='true'] .add-to-cart__added {
  animation-name: atc-slide;
}

.checkmark-burst {
  opacity: 0;
  overflow: visible;

  .burst {
    rotate: 20deg;
  }

  .check {
    opacity: 0.2;
    scale: 0.8;
    filter: blur(2px);
    transform: translateZ(0);
  }

  :is(.ring, .line, .check, .burst, .tick) {
    transform-box: fill-box;
    transform-origin: center;
  }

  :is(.line) {
    stroke-dasharray: 1.5 1.5;
    stroke-dashoffset: -1.5;
    translate: 0 -180%;
  }

  g {
    transform-origin: center;
    rotate: calc(var(--index) * (360 / 8) * 1deg);
  }
}

.add-to-cart-button[data-added='true'] .checkmark-burst {
  opacity: 1;
}

.add-to-cart-button[data-added='true'] {
  .check {
    opacity: 1;
    scale: 1;
    filter: blur(0);
  }

  .tick {
    scale: 1.75;
  }

  .ring {
    opacity: 0;
    scale: 1;
  }

  .line {
    stroke-dashoffset: 1.5;
  }

  .add-to-cart-text {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: circle(0% at 50% 50%);
    filter: blur(2px);
    opacity: 0;
    translate: 0 4px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .add-to-cart-button[data-added='true'] {
    .check {
      transition-property: opacity, scale, filter;
      transition-duration: calc(calc(var(--check-speed) * 1s));
      transition-delay: calc((var(--base-delay) * 1s));
      transition-timing-function: var(--ease-out-quad);
    }

    .tick {
      transition-property: scale;
      transition-duration: calc((calc(var(--tick-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * (var(--step-delay) * 1.1))) * 1s));
      transition-timing-function: ease-out;
    }

    .ring {
      transition-property: opacity, scale;
      transition-duration: calc((calc(var(--ring-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * var(--step-delay))) * 1s));
      transition-timing-function: var(--ease-out-quad);
    }

    .line {
      transition-property: stroke-dashoffset;
      transition-duration: calc((calc(var(--burst-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * var(--step-delay))) * 1s));
      transition-timing-function: var(--ease-out-cubic);
    }
  }

  .add-to-cart-text {
    transition-property: clip-path, opacity, filter, translate;
    transition-duration: calc((var(--text-speed) * 0.6s)), calc((var(--text-speed) * 1s));
    transition-timing-function: ease-out;
  }
}

.add-to-cart-text {
  /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
  clip-path: circle(100% at 50% 50%);
}

@keyframes atc-slide {
  to {
    opacity: var(--atc-opacity, 1);
    translate: 0px var(--atc-destination, 0px);
  }
}
/* ============================================================
   Halea Life — Universal PDP Styles
   Scope prefix: .hl-pdp
   Paste into assets/base.css (or assets/hl-pdp.css)

   Classes:
     .hl-pdp               Outer wrapper (required on every PDP)
     .hl-pdp-lead          Opening paragraph
     .hl-pdp-pullquote     Pull quote block
     .hl-pdp-h2            Section heading
     .hl-pdp-body          Body paragraph
     .hl-pdp-who-grid      Who This Is For grid (2col / 1col mobile)
     .hl-pdp-who-tile      Individual who tile
     .hl-pdp-ingredient-grid  Ingredient cards grid (3col / 1col mobile)
     .hl-pdp-ing-card      Individual ingredient card
     .hl-pdp-ing-card-header  Card header row
     .hl-pdp-ing-badge     Pill badge inside card
     .hl-pdp-ing-dose      Dose line inside card
     .hl-pdp-how-block     Purple How to Use block
     .hl-pdp-diff-strip    What Sets It Apart strip
     .hl-pdp-diff-list     Bullet list inside diff strip
     .hl-pdp-specs-wrap    Scroll wrapper for supplement facts table
     .hl-pdp-specs         Supplement facts table
     .hl-pdp-faq           FAQ accordion wrapper
     .hl-pdp-faq-item      Individual FAQ (uses <details>)
     .hl-pdp-faq-q         FAQ question (uses <summary>)
     .hl-pdp-faq-a         FAQ answer wrapper
     .hl-pdp-disclaimer    FDA disclaimer paragraph
   ============================================================ */

/* ── Reset & Scope ───────────────────────────────────────── */
.hl-pdp * { box-sizing: border-box; margin: 0; padding: 0; }

.hl-pdp {
  font-family: inherit;
  color: #1a1a1a;
  line-height: 1.75;
  width: 100%;
}

/* ── Lead Prose ──────────────────────────────────────────── */
.hl-pdp-lead {
  font-size: clamp(0.85rem, 2.5vw, 0.85rem);
  color: #2a2a2a;
  margin-bottom: 2em;
  line-height: 1.50
}

.hl-pdp-lead strong {
  color: #632C90;
  font-weight: 700;
}

/* ── Pull Quote ──────────────────────────────────────────── */
.hl-pdp-pullquote {
  border-left: 4px solid #632C90;
  background-color: #f9f4ff;
  padding: clamp(16px, 3vw, 28px);
  margin: 2em 0;
  border-radius: 0 8px 8px 0;
}

.hl-pdp-pullquote p {
  font-size: clamp(.80rem, 2.5vw, 1rem);
  font-style: italic;
  color: #3d1a5e;
  line-height: 1.7;
}

.hl-pdp-pullquote cite {
  display: block;
  font-size: 0.8rem;
  font-style: normal;
  color: #888;
  margin-top: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ── Section Headings ────────────────────────────────────── */
.hl-pdp-h2 {
  font-size: clamp(0.9rem, 2vw, 1.1rem);
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin: 2.5em 0 1em;
  padding-bottom: 8px;
  border-bottom: 1px solid #e8d9f7;
}

/* ── Body Text ───────────────────────────────────────────── */
.hl-pdp-body {
  font-size: clamp(0.9rem, 2vw, 1rem);
  color: #333;
  margin-bottom: 1.25em;
  line-height: 1.8;
}

.hl-pdp-body strong { color: #1a1a1a; }

/* ── Who This Is For Tiles ───────────────────────────────── */
.hl-pdp-who-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 2vw, 16px);
  margin: 1.5em 0 2em;
}

@media (max-width: 480px) {
  .hl-pdp-who-grid {
    grid-template-columns: 1fr;
  }
}

.hl-pdp-who-tile {
  background: #ffffff;
  border: 1px solid #e3d0f5;
  border-top: 3px solid #632C90;
  border-radius: 10px;
  padding: clamp(14px, 2.5vw, 20px);
  text-align: left;
}

.hl-pdp-who-tile strong {
  display: block;
  font-size: clamp(0.75rem, 1.8vw, 0.85rem);
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.03em;
  margin-bottom: 6px;
  text-transform: uppercase;
}

.hl-pdp-who-tile p {
  font-size: clamp(0.8rem, 1.8vw, 0.875rem);
  color: #555;
  line-height: 1.6;
}

/* ── Ingredient Grid Cards ───────────────────────────────── */
.hl-pdp-ingredient-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.5vw, 20px);
  margin: 1.5em 0 2em;
}

@media (max-width: 480px) {
  .hl-pdp-ingredient-grid {
    grid-template-columns: 1fr;
  }
}

.hl-pdp-ing-card {
  background: #ffffff;
  border-radius: 12px;
  padding: clamp(16px, 2.5vw, 22px);
  border: 1px solid #e8d9f7;
  box-shadow: 0 2px 8px rgba(99, 44, 144, 0.06);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.hl-pdp-ing-card:hover {
  box-shadow: 0 6px 20px rgba(99, 44, 144, 0.13);
  transform: translateY(-2px);
}

.hl-pdp-ing-card-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.hl-pdp-ing-badge {
  background: #632C90;
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 20px;
  white-space: nowrap;
}

.hl-pdp-ing-card h3 {
  font-size: clamp(0.9rem, 2vw, 1rem);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 4px;
}

.hl-pdp-ing-dose {
  display: block;
  font-size: clamp(0.73rem, 1.6vw, 0.8rem);
  color: #632C90;
  font-weight: 600;
  letter-spacing: 0.02em;
  margin-bottom: 8px;
}

.hl-pdp-ing-card p {
  font-size: clamp(0.8rem, 1.8vw, 0.88rem);
  color: #555;
  line-height: 1.65;
}

/* ── How-to-Use Block ────────────────────────────────────── */
.hl-pdp-how-block {
  background: #632C90;
  color: #ffffff;
  border-radius: 12px;
  padding: clamp(20px, 4vw, 30px) clamp(18px, 4vw, 28px);
  margin: 2em 0;
}

.hl-pdp-how-block h2 {
  font-size: clamp(0.78rem, 1.8vw, 0.70rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #e8d9f7;
  margin-bottom: 14px;
}

.hl-pdp-how-block p {
  font-size: clamp(0.88rem, 2vw, 0.65rem);
  line-height: 1.75;
  color: #f5eeff;
}

.hl-pdp-how-block strong {
  color: #ffffff;
  font-weight: 700;
}

/* ── Differentiator Strip ────────────────────────────────── */
.hl-pdp-diff-strip {
  background: #f9f4ff;
  border-radius: 10px;
  padding: clamp(16px, 3vw, 24px);
  margin: 2em 0;
  border: 1px solid #e3d0f5;
}

.hl-pdp-diff-strip h2 {
  font-size: clamp(0.75rem, 1.8vw, 0.85rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #632C90;
  margin-bottom: 12px;
}

.hl-pdp-diff-list { list-style: none; padding: 0; }

.hl-pdp-diff-list li {
  font-size: clamp(0.85rem, 2vw, 0.92rem);
  color: #333;
  padding: 5px 0 5px 20px;
  position: relative;
  line-height: 1.6;
}

.hl-pdp-diff-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: 8px;
  height: 8px;
  background: #632C90;
  border-radius: 50%;
}

/* ── Specs Table ─────────────────────────────────────────── */
.hl-pdp-specs-wrap {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin: 1em 0 1.75em;
}

.hl-pdp-specs {
  width: 100%;
  min-width: 360px;
  border-collapse: collapse;
  font-size: clamp(0.78rem, 1.8vw, 0.875rem);
}

.hl-pdp-specs th {
  background: #632C90;
  color: #ffffff;
  text-align: left;
  padding: clamp(8px, 1.5vw, 10px) clamp(10px, 2vw, 14px);
  font-weight: 600;
  letter-spacing: 0.04em;
  font-size: clamp(0.7rem, 1.5vw, 0.78rem);
  text-transform: uppercase;
  white-space: nowrap;
}

.hl-pdp-specs td {
  padding: clamp(7px, 1.5vw, 9px) clamp(10px, 2vw, 14px);
  border-bottom: 1px solid #eedff7;
  color: #333;
}

.hl-pdp-specs tr:nth-child(even) td { background: #faf6ff; }

/* ── FAQ ─────────────────────────────────────────────────── */
.hl-pdp-faq {
  margin: 1.5em 0 2em;
}

.hl-pdp-faq-item {
  border-bottom: 1px solid #e8d9f7;
}

.hl-pdp-faq-item:first-child {
  border-top: 1px solid #e8d9f7;
}

.hl-pdp-faq-q {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1em 0;
  font-size: clamp(0.88rem, 2vw, 0.97rem);
  font-weight: 700;
  color: #1a1a1a;
  cursor: pointer;
  list-style: none;
  gap: 16px;
}

.hl-pdp-faq-q::-webkit-details-marker { display: none; }

.hl-pdp-faq-q::after {
  content: '';
  display: block;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-color: #632C90;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M6 2v8M2 6h8' stroke='%23fff' stroke-width='1.8' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
  transition: transform 0.2s ease, background-color 0.2s ease;
}

.hl-pdp-faq-item[open] .hl-pdp-faq-q::after {
  transform: rotate(45deg);
  background-color: #7B3AAD;
}

.hl-pdp-faq-item[open] .hl-pdp-faq-q {
  color: #632C90;
}

.hl-pdp-faq-a {
  padding: 0 0 1.25em;
}

.hl-pdp-faq-a p {
  font-size: clamp(0.85rem, 2vw, 0.93rem);
  color: #444;
  line-height: 1.75;
}

/* ── FDA Disclaimer ──────────────────────────────────────── */
.hl-pdp-disclaimer {
  font-size: clamp(0.72rem, 1.6vw, 0.78rem);
  color: #888;
  border-top: 1px solid #ddd;
  padding-top: 16px;
  margin-top: 2em;
  line-height: 1.6;
}
/* =============================================================
   Halea Life — Collection Page CSS
   Scope: .hl-col and all child classes
   Compatible with: Shopify Horizon theme
   Brand color: #632C90  |  Hover: #7B3AAD
   Note: Uses explicit hex values — no CSS variables — to prevent
   Horizon theme conflicts. Mirror pattern from hl-pdp stylesheet.
   ============================================================= */


/* ── Root Container ── */

.hl-col {
  font-family: inherit;
  color: inherit;
  max-width: 100%;
}


/* ── Eyebrow ── */

.hl-col-eyebrow {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #ffffffb8;
  margin: 0 0 0.6rem;
}


/* ── Headline ── */

.hl-col-heading {
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.2;
  margin: 0 0 1.25rem;
}

.hl-col-heading em {
  font-style: italic;
  color: #ffffffb8;
}

@media (max-width: 640px) {
  .hl-col-heading {
    font-size: 1.5rem;
  }
}


/* ── Lead Prose ── */

.hl-col-lead {
  font-size: 1rem;
  line-height: 1.75;
  margin: 0 0 2rem;
  max-width: 80%;
}


/* ── Body Paragraph (sub-collection intros) ── */

.hl-col-body {
  font-size: 0.95rem;
  line-height: 1.7;
  margin: 0 0 1.25rem;
  color: #ffffffb8;
}


/* ── Section Heading (h2) ── */

.hl-col-h2 {
  font-size: 1.2rem;
  font-weight: 600;
  margin: 2rem 0 0.75rem;
}


/* ── 4-Card Benefit Row ── */

.hl-col-benefit-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);;
  gap: 12px;
  margin: 0 0 2rem;
}

@media (max-width: 900px) {
  .hl-col-benefit-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 480px) {
  .hl-col-benefit-row {
    grid-template-columns: 1fr;
  }
}

.hl-col-benefit-card {
  background: #f9f6fd;
  border: 1px solid #e8dff4;
  border-radius: 10px;
  padding: 1rem 1.1rem;
}

.hl-col-benefit-label {
  display: block;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: #632C90;
  margin: 0 0 0.4rem;
}

.hl-col-benefit-text {
  font-size: 0.85rem;
  line-height: 1.55;
  margin: 0;
}


/* ── Pull Quote ── */

.hl-col-pullquote {
  border-left: 3px solid #632C90;
  padding: 0.6rem 1.25rem;
  margin: 0 0 2rem;
  background: transparent;
}

.hl-col-pullquote p {
  font-size: 1.05rem;
  font-style: italic;
  line-height: 1.6;
  margin: 0 0 0.4rem;
}

.hl-col-pullquote cite {
  font-size: 0.75rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #888;
}


/* ── Who This Collection Is For — Grid ── */

.hl-col-who-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0 0 2rem;
}

@media (max-width: 540px) {
  .hl-col-who-grid {
    grid-template-columns: 1fr;
  }
}

.hl-col-who-tile {
  border: 1px solid #e8dff4;
  border-radius: 10px;
  padding: 1rem 1.1rem;
}

.hl-col-who-tile strong {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0.35rem;
}

.hl-col-who-tile p {
  font-size: 0.85rem;
  line-height: 1.55;
  margin: 0;
}


/* ── Purple Support Strip ── */

.hl-col-what-strip {
  background: #632C90;
  border-radius: 10px;
  padding: 1.1rem 1.4rem;
  margin: 0 0 2rem;
}

.hl-col-what-strip h3 {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin: 0 0 0.65rem;
}

.hl-col-what-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.hl-col-what-list li {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  padding: 4px 13px;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.92);
}


/* ── Differentiator Strip ── */

.hl-col-diff-strip {
  background: #f9f6fd;
  border: 1px solid #e8dff4;
  border-radius: 10px;
  padding: 1.25rem 1.5rem;
  margin: 0 0 1.5rem;
}

.hl-col-diff-strip h2 {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #632C90;
  margin: 0 0 0.75rem;
}

.hl-col-diff-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hl-col-diff-list li {
  font-size: 0.88rem;
  line-height: 1.5;
  padding-left: 1.1rem;
  position: relative;
}

.hl-col-diff-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #632C90;
}


/* ── FDA Disclaimer ── */

.hl-col-disclaimer {
  font-size: 0.78rem;
  line-height: 1.55;
  color: #888;
  border-top: 1px solid #e8dff4;
  padding-top: 1.25rem;
  margin-top: 1rem;
}
/* =============================================================
   Halea Life — Blog CSS
      Note: Uses explicit hex values — no CSS variables — to prevent
   Horizon theme conflicts. Mirror pattern from hl-pdp stylesheet.
   ============================================================= */
.hlob2-blog { font-family: inherit; color: inherit; }
  .hlob2-blog * { box-sizing: border-box; }

  .hlob2-hero {
    background: #632C90; color: #fff;
    padding: 64px 24px 56px; text-align: center; margin-bottom: 48px;
  }
  .hlob2-hero-eyebrow {
    font-size: 11px; font-weight: 500; letter-spacing: .16em;
    text-transform: uppercase; color: rgba(255,255,255,.55); margin-bottom: 16px;
  }
  .hlob2-hero h1 {
    font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 400; line-height: 1.2;
    max-width: 100%; margin: 0 auto 20px; color: #fff;
  }
  .hlob2-hero-sub {
    font-size: 16px; color: rgba(255,255,255,.72);
    max-width: 540px; margin: 0 auto 32px; line-height: 1.6;
  }
  .hlob2-hero-meta {
    font-size: 12px; color: rgba(255,255,255,.45);
    display: flex; justify-content: center; gap: 24px; flex-wrap: wrap;
  }

  .hlob2-section { max-width: 90%; margin: 0 auto 48px; padding: 0 8px; }
  .hlob2-eyebrow {
    font-size: 11px; font-weight: 500; letter-spacing: .15em;
    text-transform: uppercase; color: #632C90; margin-bottom: 10px;
  }
  .hlob2-section h2 {
    font-size: clamp(1.4rem, 2.5vw, 1.9rem); font-weight: 600;
    line-height: 1.25; margin-bottom: 16px;
  }
  .hlob2-section h3 {
    font-size: 1.1rem; font-weight: 600; line-height: 1.3;
    margin-bottom: 12px; margin-top: 28px; color: #1C1C1C;
  }
  .hlob2-section p { line-height: 1.75; margin-bottom: 16px; }
  .hlob2-section p:last-child { margin-bottom: 0; }

  .hlob2-rule { border: none; border-top: 1px solid #DDD6C8; max-width: 100%; margin: 48px auto; }

  .hlob2-pullquote {
    background: #F5F0FB; border-left: 3px solid #632C90;
    padding: 24px 28px; max-width: 100%; margin: 40px auto;
  }
  .hlob2-pullquote p { font-size: 1.15rem; font-style: italic; line-height: 1.55; margin: 0; }

  .hlob2-stat {
    background: #F5F0FB; border-left: 3px solid #632C90;
    padding: 14px 18px; margin: 20px 0; font-size: 14px; color: #444; line-height: 1.6;
  }
  .hlob2-stat strong { color: #632C90; }

  /* images */
  .hlob2-img-full { max-width: 100%; margin: 0 auto 48px; padding: 0 8px; }
  .hlob2-img-full img { width: 100%; height: auto; display: block; }
  .hlob2-img-caption { font-size: 12px; color: #999; margin-top: 10px; text-align: center; font-style: italic; }

  .hlob2-split {
    max-width: 100%; margin: 0 auto 48px; padding: 0 8px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: center;
  }
  .hlob2-split img { width: 100%; height: auto; display: block; }
  .hlob2-split-text p { font-size: 15px; line-height: 1.75; color: #555; margin-bottom: 14px; }
  .hlob2-split-text p:last-child { margin-bottom: 0; }

  .hlob2-img-grid-2 {
    max-width: 100%; margin: 0 auto 48px; padding: 0 8px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  }
  .hlob2-img-grid-2 img { width: 100%; height: 210px; object-fit: cover; display: block; }

  /* digestive layer diagram */
  .hlob2-layers {
    max-width: 100%; margin: 0 auto 48px;
    background: #F5F0FB; border-left: 3px solid #632C90; padding: 28px 32px;
  }
  .hlob2-layers-label {
    font-size: 10px; font-weight: 600; letter-spacing: .14em;
    text-transform: uppercase; color: #632C90; margin-bottom: 16px;
  }
  .hlob2-layer-rows { display: flex; flex-direction: column; gap: 10px; }
  .hlob2-layer-row {
    display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
  }
  .hlob2-layer-tag {
    background: #fff; border: 1px solid #DDD6C8;
    padding: 8px 14px; font-size: 12px; font-weight: 600;
    color: #1C1C1C; white-space: nowrap; min-width: 140px;
  }
  .hlob2-layer-tag-active { background: #632C90; color: #fff; border-color: #632C90; }
  .hlob2-layer-desc { font-size: 13px; color: #555; line-height: 1.5; }

  /* ingredient grid */
  .hlob2-ing-grid {
    max-width: 100%; margin: 0 auto 48px; padding: 0 8px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  }
  .hlob2-ing { background: #FAFAF8; border: 1px solid #DDD6C8; padding: 20px 22px; }
  .hlob2-ing-num { font-size: 2.5rem; font-weight: 300; color: #E8DDF5; line-height: 1; margin-bottom: 6px; }
  .hlob2-ing-name { font-size: 13px; font-weight: 600; color: #632C90; margin-bottom: 3px; }
  .hlob2-ing-dose { font-size: 11px; font-weight: 600; color: #B8924A; margin-bottom: 4px; }
  .hlob2-ing-role {
    font-size: 11px; font-weight: 500; letter-spacing: .07em;
    text-transform: uppercase; color: #999; margin-bottom: 8px;
  }
  .hlob2-ing-desc { font-size: 13px; line-height: 1.6; color: #555; }

  /* comparison table */
  .hlob2-table-wrap { max-width: 100%; margin: 0 auto 48px; padding: 0 8px; overflow-x: auto; }
  .hlob2-table { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 600px; }
  .hlob2-table th {
    background: #632C90; color: #fff; padding: 11px 14px;
    text-align: left; font-size: 11px; font-weight: 600;
    letter-spacing: .07em; text-transform: uppercase;
  }
  .hlob2-table th:first-child { width: 26%; }
  .hlob2-table td {
    padding: 11px 14px; border-bottom: 1px solid #DDD6C8;
    vertical-align: top; line-height: 1.55; color: #444;
  }
  .hlob2-table tr:nth-child(even) td { background: #FAFAF8; }
  .hlob2-table tr:last-child td { border-bottom: none; }
  .hlob2-table td:first-child { font-weight: 600; color: #1C1C1C; font-size: 12px; }
  .hlob2-check { color: #632C90; font-weight: 700; }
  .hlob2-dash { color: #ccc; }
  .hlob2-partial { color: #B8924A; font-weight: 600; }

  /* product card */
  .hlob2-card-wrap { max-width: 100%; margin: 0 auto 48px; padding: 0 8px; }
  .hlob2-card {
    border: 1px solid #DDD6C8; background: #FAFAF8; overflow: hidden;
    display: grid; grid-template-columns: 210px 1fr;
  }
  .hlob2-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .hlob2-card-body { padding: 24px 26px; }
  .hlob2-card-label {
    font-size: 10px; font-weight: 500; letter-spacing: .14em;
    text-transform: uppercase; color: #632C90; margin-bottom: 6px;
  }
  .hlob2-card h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 10px; line-height: 1.3; }
  .hlob2-card-desc { font-size: 14px; line-height: 1.65; color: #555; margin-bottom: 14px; }
  .hlob2-card-badges { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px; }
  .hlob2-badge {
    font-size: 11px; font-weight: 500; padding: 3px 10px;
    border: 1px solid #DDD6C8; color: #666;
  }
  .hlob2-card-footer {
    display: flex; justify-content: space-between; align-items: center;
    border-top: 1px solid #DDD6C8; padding-top: 14px;
  }
  .hlob2-price { font-size: 1.1rem; font-weight: 600; color: #632C90; }
  .hlob2-btn {
    display: inline-block; background: #632C90; color: #fff !important;
    padding: 9px 20px; font-size: 11px; font-weight: 500;
    letter-spacing: .09em; text-transform: uppercase;
    text-decoration: none !important; white-space: nowrap;
  }
  .hlob2-btn:hover { background: #7B3AAD; }

  /* who it's for */
  .hlob2-for-grid {
    max-width: 100%; margin: 0 auto 48px; padding: 0 8px;
    display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  }
  .hlob2-for-item { background: #F5F0FB; padding: 20px 22px; border-left: 3px solid #632C90; }
  .hlob2-for-title { font-size: 13px; font-weight: 600; margin-bottom: 6px; color: #1C1C1C; }
  .hlob2-for-desc { font-size: 14px; line-height: 1.6; color: #555; }

  /* how to use block */
  .hlob2-howto {
    background: #632C90; color: #fff; padding: 56px 24px; margin: 56px 0;
  }
  .hlob2-howto-inner { max-width: 100%; margin: 0 auto; }
  .hlob2-howto .hlob2-eyebrow { color: rgba(255,255,255,.5); }
  .hlob2-howto h2 {
    font-size: clamp(1.4rem, 2.5vw, 1.9rem); font-weight: 400; margin-bottom: 36px; color: #fff;
  }
  .hlob2-steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 24px; }
  .hlob2-step-num { font-size: 2rem; font-weight: 300; color: rgba(255,255,255,.15); line-height: 1; margin-bottom: 8px; }
  .hlob2-step-title { font-size: 14px; font-weight: 500; color: #fff; margin-bottom: 6px; }
  .hlob2-step-desc { font-size: 13px; color: rgba(255,255,255,.65); line-height: 1.6; }

  /* references */
  .hlob2-refs { max-width: 100%; margin: 0 auto 48px; padding: 0 8px; }
  .hlob2-refs h2 { font-size: clamp(1.2rem,2vw,1.4rem); font-weight: 600; margin-bottom: 18px; }
  .hlob2-ref-list { display: flex; flex-direction: column; gap: 9px; }
  .hlob2-ref-item {
    font-size: 13px; color: #666; line-height: 1.6;
    padding-left: 20px; position: relative;
  }
  .hlob2-ref-item::before {
    content: ''; position: absolute; left: 0; top: 9px; width: 8px; height: 1px; background: #DDD6C8;
  }
  .hlob2-ref-item em { font-style: italic; }

  /* FAQ */
  .hlob2-faq { max-width: 100%; margin: 0 auto 48px; padding: 0 8px; }
  .hlob2-faq h2 { font-size: clamp(1.4rem,2.5vw,1.9rem); font-weight: 600; margin-bottom: 24px; }
  .hlob2-faq-item { border-bottom: 1px solid #DDD6C8; padding: 18px 0; }
  .hlob2-faq-item:first-of-type { border-top: 1px solid #DDD6C8; }
  .hlob2-faq-q { font-size: 15px; font-weight: 600; color: #1C1C1C; margin-bottom: 8px; }
  .hlob2-faq-a { font-size: 14px; line-height: 1.7; color: #555; }

  /* cta */
  .hlob2-cta { text-align: center; padding: 64px 24px; max-width: 560px; margin: 0 auto; }
  .hlob2-cta h2 { font-size: clamp(1.4rem,2.5vw,1.9rem); font-weight: 600; margin-bottom: 12px; }
  .hlob2-cta p { line-height: 1.65; margin-bottom: 28px; color: #555; }
  .hlob2-cta-btn {
    display: inline-block; background: #632C90; color: #fff !important;
    padding: 13px 32px; font-size: 12px; font-weight: 500;
    letter-spacing: .1em; text-transform: uppercase; text-decoration: none !important;
  }
  .hlob2-cta-btn:hover { background: #7B3AAD; }

  .hlob2-disclaimer {
    max-width: 100%; margin: 0 auto 32px; padding: 24px 8px 0;
    font-size: 12px; color: #999; line-height: 1.6; border-top: 1px solid #DDD6C8;
  }
/* =============================================================
   Halea Life -- Skincare PDP Styles
   ADD THIS BLOCK after the existing .hlob2-blog block
   Scope prefix: .hlsk-pdp
   ============================================================= */

/* =============================================================
   Halea Life -- Skincare PDP Styles
   Scope prefix: .hlsk-pdp
   Paste into: assets/base.css (after existing .hl-pdp rules)

   Brand color: #632C90  |  Hover: #7B3AAD
   Tint light:  #f9f4ff  |  Border: #e8d9f7  |  Deep: #3d1a5e

   Convention: explicit hex values throughout -- no CSS variables
   -- prevents Horizon theme from overriding scoped styles.
   Mirrors .hl-pdp pattern exactly; only the prefix changes.

   Classes:
     .hlsk-pdp                Outer wrapper (required on every skincare PDP)
     .hlsk-pdp-lead           Opening paragraph
     .hlsk-pdp-pullquote      Pull quote block
     .hlsk-pdp-h2             Section heading
     .hlsk-pdp-body           Body paragraph
     .hlsk-pdp-who-grid       Who This Is For grid
     .hlsk-pdp-who-tile       Individual who tile
     .hlsk-pdp-ingredient-grid   Ingredient cards grid
     .hlsk-pdp-ing-card       Individual ingredient card
     .hlsk-pdp-ing-card-header   Card header row
     .hlsk-pdp-ing-role       Role/function label inside card
     .hlsk-pdp-timeline-grid  What You May Notice grid
     .hlsk-pdp-timeline-tile  Individual timeline tile
     .hlsk-pdp-timeline-marker   Phase label (Immediately / 2-4 weeks / etc.)
     .hlsk-pdp-routine-block  Routine placement wrapper
     .hlsk-pdp-routine-steps  Step list container
     .hlsk-pdp-routine-step   Individual step row
     .hlsk-pdp-step-num       Step number circle
     .hlsk-pdp-routine-note   Pairing/compatibility note
     .hlsk-pdp-diff-strip     No List / What This Formula Leaves Out strip
     .hlsk-pdp-diff-list      Bullet list inside diff strip
     .hlsk-pdp-inci-block     Full ingredient list wrapper
     .hlsk-pdp-inci-list      INCI string paragraph
     .hlsk-pdp-inci-glossary  Glossary rows wrapper
     .hlsk-pdp-inci-row       Individual glossary row
     .hlsk-pdp-inci-name      Ingredient name cell
     .hlsk-pdp-inci-def       Ingredient definition cell
     .hlsk-pdp-faq            FAQ accordion wrapper
     .hlsk-pdp-faq-item       Individual FAQ (uses <details>)
     .hlsk-pdp-faq-q          FAQ question (uses <summary>)
     .hlsk-pdp-faq-a          FAQ answer wrapper
     .hlsk-pdp-disclaimer     Cosmetic disclaimer paragraph
   ============================================================= */


/* ── Reset & Scope ─────────────────────────────────────────── */

.hlsk-pdp *,
.hlsk-pdp *::before,
.hlsk-pdp *::after {
  box-sizing: border-box;
}

.hlsk-pdp {
  font-family: inherit;
  color: #1a1a1a;
  line-height: 1.75;
  width: 100%;
}


/* ── Lead Prose ─────────────────────────────────────────────── */

.hlsk-pdp-lead {
  font-size: clamp(0.95rem, 2.5vw, 1.125rem);
  color: #2a2a2a;
  line-height: 1.85;
  margin-bottom: 2em;
}

.hlsk-pdp-lead strong {
  color: #632C90;
  font-weight: 700;
}


/* ── Pull Quote ─────────────────────────────────────────────── */

.hlsk-pdp-pullquote {
  border-left: 4px solid #632C90;
  background-color: #f9f4ff;
  padding: clamp(16px, 3vw, 28px);
  margin: 0 0 2em;
  border-radius: 0 8px 8px 0;
}

.hlsk-pdp-pullquote p {
  font-size: clamp(1rem, 2.5vw, 1.15rem);
  font-style: italic;
  color: #3d1a5e;
  line-height: 1.7;
  margin: 0 0 0.5em;
}

.hlsk-pdp-pullquote cite {
  display: block;
  font-size: 0.78rem;
  font-style: normal;
  color: #999;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}


/* ── Section Headings ───────────────────────────────────────── */

.hlsk-pdp-h2 {
  font-size: clamp(0.78rem, 1.8vw, 0.9rem);
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 2.5em 0 1em;
  padding-bottom: 8px;
  border-bottom: 1px solid #e8d9f7;
}


/* ── Body Paragraph ─────────────────────────────────────────── */

.hlsk-pdp-body {
  font-size: clamp(0.88rem, 2vw, 1rem);
  color: #333;
  line-height: 1.8;
  margin-bottom: 1.25em;
}

.hlsk-pdp-body strong {
  color: #1a1a1a;
}


/* ── Who This Is For Grid ───────────────────────────────────── */

.hlsk-pdp-who-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 2vw, 16px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-who-tile {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(14px, 2.5vw, 20px);
}

.hlsk-pdp-who-tile strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 0.5em;
}

.hlsk-pdp-who-tile p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.7;
  margin: 0;
}

@media (max-width: 540px) {
  .hlsk-pdp-who-grid {
    grid-template-columns: 1fr;
  }
}


/* ── Ingredient Cards Grid ──────────────────────────────────── */

.hlsk-pdp-ingredient-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 260px), 1fr));
  gap: clamp(12px, 2vw, 18px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-ing-card {
  background: #fff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(16px, 2.5vw, 22px);
}

.hlsk-pdp-ing-card-header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 0.75em;
  padding-bottom: 0.75em;
  border-bottom: 1px solid #f0e6fa;
}

.hlsk-pdp-ing-card-header h3 {
  font-size: clamp(0.88rem, 2vw, 1rem);
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 0.2em;
  line-height: 1.3;
}

.hlsk-pdp-ing-role {
  display: block;
  font-size: 0.75rem;
  font-weight: 500;
  color: #632C90;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.hlsk-pdp-ing-card p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.75;
  margin: 0;
}

@media (max-width: 480px) {
  .hlsk-pdp-ingredient-grid {
    grid-template-columns: 1fr;
  }
}


/* ── Timeline Grid ──────────────────────────────────────────── */

.hlsk-pdp-timeline-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 2vw, 16px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-timeline-tile {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(14px, 2.5vw, 20px);
}

.hlsk-pdp-timeline-marker {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.5em;
}

.hlsk-pdp-timeline-tile strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 0.5em;
  line-height: 1.3;
}

.hlsk-pdp-timeline-tile p {
  font-size: 0.85rem;
  color: #555;
  line-height: 1.7;
  margin: 0;
}

@media (max-width: 640px) {
  .hlsk-pdp-timeline-grid {
    grid-template-columns: 1fr;
  }
}


/* ── Routine Block ──────────────────────────────────────────── */

.hlsk-pdp-routine-block {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(18px, 3vw, 28px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-routine-block > .hlsk-pdp-body {
  margin-bottom: 1.25em;
}

.hlsk-pdp-routine-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 1.5em;
}

.hlsk-pdp-routine-step {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}

.hlsk-pdp-step-num {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  background: #632C90;
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}

.hlsk-pdp-routine-step > div {
  flex: 1;
}

.hlsk-pdp-routine-step strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 0.25em;
}

.hlsk-pdp-routine-step p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.7;
  margin: 0;
}

.hlsk-pdp-routine-note {
  font-size: 0.84rem;
  color: #555;
  line-height: 1.7;
  border-top: 1px solid #e8d9f7;
  padding-top: 1em;
  margin: 0;
}

.hlsk-pdp-routine-note strong {
  color: #1a1a1a;
}


/* ── No List / Differentiator Strip ────────────────────────── */

.hlsk-pdp-diff-strip {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(16px, 3vw, 24px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-diff-strip h2 {
  font-size: 0.72rem;
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 0.9em;
  padding: 0;
  border: none;
}

.hlsk-pdp-diff-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.hlsk-pdp-diff-list li {
  font-size: 0.88rem;
  line-height: 1.55;
  color: #333;
  padding-left: 1.1rem;
  position: relative;
}

.hlsk-pdp-diff-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.52em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #632C90;
}


/* ── Full Ingredient List (INCI) ────────────────────────────── */

.hlsk-pdp-inci-block {
  background: #fff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(16px, 2.5vw, 22px);
  margin: 0 0 2.5em;
}

.hlsk-pdp-inci-list {
  font-size: 0.82rem;
  color: #555;
  line-height: 1.6;
  margin: 0 0 1.25em;
  padding-bottom: 1.25em;
  border-bottom: 1px solid #f0e6fa;
}

.hlsk-pdp-inci-glossary {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.hlsk-pdp-inci-row {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 12px;
  padding: 9px 0;
  border-bottom: 1px solid #f5f0fa;
  align-items: baseline;
}

.hlsk-pdp-inci-row:last-child {
  border-bottom: none;
}

.hlsk-pdp-inci-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.4;
}

.hlsk-pdp-inci-def {
  font-size: 0.82rem;
  color: #555;
  line-height: 1.6;
}

@media (max-width: 540px) {
  .hlsk-pdp-inci-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }

  .hlsk-pdp-inci-name {
    color: #632C90;
  }
}


/* ── FAQ Accordion ──────────────────────────────────────────── */

.hlsk-pdp-faq {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0 0 2em;
}

.hlsk-pdp-faq-item {
  border: 1px solid #e8d9f7;
  border-radius: 6px;
  overflow: hidden;
}

.hlsk-pdp-faq-item[open] {
  border-color: #632C90;
}

.hlsk-pdp-faq-q {
  font-size: clamp(0.88rem, 2vw, 0.95rem);
  font-weight: 600;
  color: #1a1a1a;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  line-height: 1.4;
}

.hlsk-pdp-faq-q::-webkit-details-marker {
  display: none;
}

.hlsk-pdp-faq-q::after {
  content: "+";
  font-size: 1.2rem;
  font-weight: 300;
  color: #632C90;
  flex-shrink: 0;
  margin-left: 12px;
  transition: transform 0.2s ease;
}

.hlsk-pdp-faq-item[open] .hlsk-pdp-faq-q::after {
  transform: rotate(45deg);
}

.hlsk-pdp-faq-a {
  padding: 0 16px 14px;
  background: #fff;
}

.hlsk-pdp-faq-a p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.75;
  margin: 0;
}


/* ── Cosmetic Disclaimer ────────────────────────────────────── */

.hlsk-pdp-disclaimer {
  font-size: 0.78rem;
  line-height: 1.6;
  color: #888;
  border-top: 1px solid #e8d9f7;
  padding-top: 1.25em;
  margin-top: 1em;
}
/* =============================================================
   Halea Life -- Collection Page Styles
   Scope prefix: .hl-col
   Paste into: assets/base.css (after existing .hlsk-pdp rules)

   Brand color: #632C90  |  Hover: #7B3AAD
   Tint light:  #f9f4ff  |  Border: #e8d9f7  |  Deep: #3d1a5e

   Convention: explicit hex values throughout -- no CSS variables
   -- prevents Horizon theme from overriding scoped styles.
   Mirrors .hlsk-pdp pattern exactly; only the prefix changes.

   Classes:
     .hl-col                  Outer wrapper (required on every collection page)
     .hl-col-eyebrow          Small uppercase label above the headline
     .hl-col-headline         H1 page headline
     .hl-col-lead             Opening prose paragraph
     .hl-col-benefit-row      Four-card benefit grid
     .hl-col-benefit-card     Individual benefit card
     .hl-col-pullquote        Pull quote block
     .hl-col-who              Who This Is For section wrapper
     .hl-col-who-grid         Who This Is For card grid
     .hl-col-who-tile         Individual who tile
     .hl-col-diff-strip       Differentiator / Why Halea Life strip
     .hl-col-diff-list        Bullet list inside diff strip
     .hl-col-faq              FAQ accordion wrapper
     .hl-col-faq-item         Individual FAQ (uses <details>)
     .hl-col-faq-q            FAQ question (uses <summary>)
     .hl-col-faq-a            FAQ answer wrapper
     .hl-col-disclaimer       FDA disclaimer paragraph
   ============================================================= */


/* ── Reset & Scope ─────────────────────────────────────────── */

.hl-col *,
.hl-col *::before,
.hl-col *::after {
  box-sizing: border-box;
}

.hl-col {
  font-family: inherit;
  color: #1a1a1a;
  line-height: 1.75;
  width: 100%;
}


/* ── Eyebrow Label ──────────────────────────────────────────── */

.hl-col-eyebrow {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 0.6em;
}
.hl-col-eyebrow-g {
  display: block;
  font-size: 0.72rem;
  font-weight: 700;
  color: #f7cf83;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 0.6em;
}

/* ── Headline ───────────────────────────────────────────────── */

.hl-col-headline {
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
  margin: 0 0 1.5em;
}


/* ── Lead Prose ─────────────────────────────────────────────── */

.hl-col-lead {
  font-size: clamp(0.95rem, 2.5vw, 1.125rem);
  color: #2a2a2a;
  line-height: 1.85;
  margin-bottom: 2em;
}

.hl-col-lead strong {
  color: #632C90;
  font-weight: 700;
}


/* ── Benefit Row (4-card grid) ──────────────────────────────── */

.hl-col-benefit-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(10px, 2vw, 16px);
  margin: 0 0 2.5em;
}

.hl-col-benefit-card {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(14px, 2.5vw, 20px);
}

.hl-col-benefit-card h3 {
  font-size: 0.88rem;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 0.5em;
  line-height: 1.3;
}

.hl-col-benefit-card p {
  font-size: 0.85rem;
  color: #444;
  line-height: 1.7;
  margin: 0;
}

@media (max-width: 768px) {
  .hl-col-benefit-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .hl-col-benefit-row {
    grid-template-columns: 1fr;
  }
}


/* ── Pull Quote ─────────────────────────────────────────────── */

.hl-col-pullquote {
  border-left: 4px solid #632C90;
  background-color: #f9f4ff;
  padding: clamp(16px, 3vw, 28px);
  margin: 0 0 2.5em;
  border-radius: 0 8px 8px 0;
}

.hl-col-pullquote p {
  font-size: clamp(1rem, 2.5vw, 1.15rem);
  font-style: italic;
  color: #3d1a5e;
  line-height: 1.7;
  margin: 0;
}


/* ── Who This Is For ────────────────────────────────────────── */

.hl-col-who {
  margin: 0 0 2.5em;
}

.hl-col-who > h2 {
  font-size: clamp(0.78rem, 1.8vw, 0.9rem);
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 1em;
  padding-bottom: 8px;
  border-bottom: 1px solid #e8d9f7;
}

.hl-col-who-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 2vw, 16px);
}

.hl-col-who-tile {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(14px, 2.5vw, 20px);
}

.hl-col-who-tile strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 0.5em;
}

.hl-col-who-tile p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.7;
  margin: 0;
}

@media (max-width: 540px) {
  .hl-col-who-grid {
    grid-template-columns: 1fr;
  }
}


/* ── Differentiator Strip ───────────────────────────────────── */

.hl-col-diff-strip {
  background: #f9f4ff;
  border: 1px solid #e8d9f7;
  border-radius: 8px;
  padding: clamp(18px, 3vw, 28px);
  margin: 0 0 2.5em;
}

.hl-col-diff-strip > h2 {
  font-size: 0.72rem;
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin: 0 0 0.9em;
  padding: 0;
  border: none;
}

.hl-col-diff-strip > p {
  font-size: clamp(0.88rem, 2vw, 1rem);
  color: #333;
  line-height: 1.8;
  margin: 0 0 1em;
}

.hl-col-diff-strip > p:last-child {
  margin-bottom: 0;
}

.hl-col-diff-strip > p strong {
  color: #1a1a1a;
}

.hl-col-diff-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.hl-col-diff-list li {
  font-size: 0.88rem;
  line-height: 1.55;
  color: #333;
  padding-left: 1.1rem;
  position: relative;
}

.hl-col-diff-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.52em;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #632C90;
}


/* ── FAQ Accordion ──────────────────────────────────────────── */

.hl-col-faq {
  margin: 0 0 2.5em;
}

.hl-col-faq > h2 {
  font-size: clamp(0.78rem, 1.8vw, 0.9rem);
  font-weight: 700;
  color: #632C90;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 0 0 1em;
  padding-bottom: 8px;
  border-bottom: 1px solid #e8d9f7;
}

.hl-col-faq-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.hl-col-faq-item {
  border: 1px solid #e8d9f7;
  border-radius: 6px;
  overflow: hidden;
}

.hl-col-faq-item[open] {
  border-color: #632C90;
}

.hl-col-faq-q {
  font-size: clamp(0.88rem, 2vw, 0.95rem);
  font-weight: 600;
  color: #1a1a1a;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  line-height: 1.4;
}

.hl-col-faq-q::-webkit-details-marker {
  display: none;
}

.hl-col-faq-q::after {
  content: "+";
  font-size: 1.2rem;
  font-weight: 300;
  color: #632C90;
  flex-shrink: 0;
  margin-left: 12px;
  transition: transform 0.2s ease;
}

.hl-col-faq-item[open] .hl-col-faq-q::after {
  transform: rotate(45deg);
}

.hl-col-faq-a {
  padding: 0 16px 14px;
  background: #fff;
}

.hl-col-faq-a p {
  font-size: 0.88rem;
  color: #444;
  line-height: 1.75;
  margin: 0;
}


/* ── FDA Disclaimer ─────────────────────────────────────────── */

.hl-col-disclaimer {
  font-size: 0.78rem;
  line-height: 1.6;
  color: #888;
  border-top: 1px solid #e8d9f7;
  padding-top: 1.25em;
  margin-top: 1em;
}

{%- unless template == 'index' or template == 'cart' or template == 'list-collections' or template == '404'or template == 'page.endless-summer-sale' or template == 'page.supplement-facts' -%}
  
  {%- style -%}
    
    /* Settings Variables */
    .owc_breadcrumbs-section#ed_section-{{ section.id }} {
      --breadcrumbs-alignment: {{ section.settings.breadcrumbs_alignment }};
      --breadcrumbs-text-color: {{ section.settings.text_color }};
      --breadcrumbs-bg-color: {{ section.settings.background_color }};
      --breadcrumbs-font-size: {{ section.settings.font_size }}px;
      --breadcrumbs-font-case: {{ section.settings.font_case }};
      --breadcrumbs-font-weight: {{ section.settings.font_weight }};
      --padding-left: {{ section.settings.padding_left }}px;
      --padding-right: {{ section.settings.padding_right }}px;
      --padding-top: {{ section.settings.padding_top }}px;
      --padding-bottom: {{ section.settings.padding_bottom }}px;
      --padding-left-mobile: {{ section.settings.padding_left_mobile }}px;
      --padding-right-mobile: {{ section.settings.padding_right_mobile }}px;
      --padding-top-mobile: {{ section.settings.padding_top_mobile }}px;
      --padding-bottom-mobile: {{ section.settings.padding_bottom_mobile }}px;
      --max-width: none;
      {% if section.settings.max_width > 0 %}
        --max-width: {{ section.settings.max_width }}px;
      {% endif %}
    }

    /* Section */
    .owc_breadcrumbs-section {
      padding-top: var(--padding-top);
      padding-bottom: var(--padding-bottom);
      padding-left: var(--padding-left);
      padding-right: var(--padding-right);
      color: var(--breadcrumbs-text-color);
      background-color: var(--breadcrumbs-bg-color);
      
    }
    .owc_breadcrumbs-section * {
      color: var(--breadcrumbs-text-color);
      
    }

    @media (max-width: 767px) {
      .owc_breadcrumbs-section {
        padding-left: var(--padding-left-mobile);
        padding-right: var(--padding-right-mobile);
        padding-top: var(--padding-top-mobile);
        padding-bottom: var(--padding-bottom-mobile);
      }
    }
    /* Hide on tablets and mobile devices */
    @media (max-width: 1024px) {
      .owc_breadcrumbs-section {
        display: none;
      }
    }

    /* Nav */
    nav.owc_breadcrumbs {
      margin: 0 auto;
      max-width: var(--max-width);
      text-align: var(--breadcrumbs-alignment);
    }

    /* List items */
    .owc_breadcrumbs-list {
      list-style-type: none;
      margin: 0;
      padding: 0;
    }
    .owc_breadcrumbs-list li {
      display: inline-flex;
      align-items: center;
    }

    /* Arrows */
    .owc_breadcrumbs-list.arrows li:not(:last-child):after {
      border-style: solid;
      border-width: .10em .10em 0 0;
      content: '';
      display: inline-block;
      height: .4em;
      width: .4em;
      margin: 0 .4em;
      position: relative;
      transform: rotate(45deg);
      vertical-align: middle;
      font-size: calc(var(--breadcrumbs-font-size) + 2px);
      /* top: -0.1em; */
    }

    .owc_breadcrumbs-list.slashes li:not(:last-child):after {
      content: '/';
      margin: 0 .4em;
      font-size: var(--breadcrumbs-font-size);
    }

    /* Links */
    .owc_breadcrumbs-list a {
      color: inherit;
      text-decoration: none;
      font-size: var(--breadcrumbs-font-size);
      font-weight: var(--breadcrumbs-font-weight);
      text-transform: var(--breadcrumbs-font-case);
    }
    .owc_breadcrumbs-list a:hover,
    .owc_breadcrumbs-list a:focus {
      text-decoration: underline;
    }
    


  {%- endstyle -%}

  <div class="owc_breadcrumbs-section {{ section.settings.custom_class }}" id="ed_section-{{ section.id }}">
      
    <nav class="owc_breadcrumbs" role="navigation" aria-label="breadcrumbs">
      <ol class="owc_breadcrumbs-list {{ section.settings.separator_class }}">

        <li>
          <a href="/">Home</a>
        </li>

        {%- assign t = template | split: '.' | first -%}
        {%- case t -%}
          
          {%- when 'page' -%}
            <li>
              <a href="{{ page.url }}" aria-current="page">{{ page.title }}</a>
            </li>
          
          {%- when 'product' and product.handle -%}
            {% for parentCollection in product.metafields.custom.breadcrumbs.value %}
              <li>
                <a href="{{ parentCollection.url }}">{{ parentCollection.title }}</a>
              </li>
            {% endfor %}
            <li>
              <a href="{{ product.url }}" aria-current="page">{{ product.title }}</a>
            </li>
        
          {%- when 'collection' and collection.handle -%}
            {% for parentCollection in collection.metafields.custom.breadcrumbs.value %}
              <li>
                <a href="{{ parentCollection.url }}">{{ parentCollection.title }}</a>
              </li>
            {% endfor %}
            <li>
              <a href="{{ collection.url }}" aria-current="page">{{ collection.title }}</a>
            </li>
        
          {%- when 'blog' -%}
            <li>
              <a href="{{ blog.url }}" aria-current="page">{{ blog.title }}</a>
            </li>
        
          {%- when 'article' -%}
            <li>
              {{ blog.title | link_to: blog.url }}
            </li>
            <li>
              <a href="{{ article.url }}" aria-current="page">{{ article.title }}</a>
            </li>
          
          {%- else -%}
            <li>
              <a href="{{ request.path }}" aria-current="page">{{ page_title }}</a>
            </li>
        {%- endcase -%}

      </ol>
    </nav>

  </div>

  {% assign t = template | split: '.' | first %}
  {% case t %}
    {% when 'page' %}
      {% capture schemaList %}
        {
          "@type": "ListItem",
          "position": 2,
          "name": "{{ page.title }}",
          "item": "{{ shop.url }}{{ page.url }}"
        }
      {% endcapture %}
    {% when 'product' and product.handle %}
      {% capture schemaList %}
        {% assign position = 0 %}
        {% for parentCollection in product.metafields.custom.breadcrumbs.value %}
          {% assign position = forloop.index %}
          {
            "@type": "ListItem",
            "position": {{ forloop.index | plus: 1 }},
            "name": "{{ parentCollection.title }}",
            "item": "{{ shop.url }}{{ parentCollection.url }}"
          },
        {% endfor %}
        {
          "@type": "ListItem",
          "position": {{ position | plus: 2 }},
          "name": "{{ product.title }}",
          "item": "{{ shop.url }}{{ product.url }}"
        }
      {% endcapture %}
    {% when 'collection' and collection.handle %}
      {% capture schemaList %}
        {% assign position = 0 %}
        {% for parentCollection in collection.metafields.custom.breadcrumbs.value %}
          {% assign position = forloop.index %}
          {
            "@type": "ListItem",
            "position": {{ forloop.index | plus: 1 }},
            "name": "{{ parentCollection.title }}",
            "item": "{{ shop.url }}{{ parentCollection.url }}"
          },
        {% endfor %}
        {
          "@type": "ListItem",
          "position": {{ position | plus: 2 }},
          "name": "{{ collection.title }}",
          "item": "{{ shop.url }}{{ collection.url }}"
        }
      {% endcapture %}
    {% when 'blog' %}
      {% capture schemaList %}
        {
          "@type": "ListItem",
          "position": 2,
          "name": "{{ blog.title }}",
          "item": "{{ shop.url }}{{ blog.url }}"
        }
      {% endcapture %}
    {% when 'article' %}
      {% capture schemaList %}
        {
          "@type": "ListItem",
          "position": 2,
          "name": "{{ blog.title }}",
          "item": "{{ shop.url }}{{ blog.url }}"
        },
        {
          "@type": "ListItem",
          "position": 3,
          "name": "{{ article.title }}",
          "item": "{{ shop.url }}{{ article.url }}"
        }
      {% endcapture %}
    {% else %}
      {% capture schemaList %}
        {
          "@type": "ListItem",
          "position": 2,
          "name": "{{ page_title }}",
          "item": "{{ shop.url }}{{ request.path }}"
        }
      {% endcapture %}
  {% endcase %}
    
  
  <script type="application/ld+json">
  {
    "@context": "https://schema.org",
    "@type": "BreadcrumbList",
    "itemListElement": [{
      "@type": "ListItem",
      "position": 1,
      "name": "Home",
      "item": "{{ shop.url }}"
    }
    {%- if schemaList -%}
      ,{{ schemaList }}
    {%- endif -%}
    ]
  }
  </script>

{%- endunless -%}

{% schema %}
  {
    "name": "OWC Breadcrumbs",
    "settings": [
      {
        "type": "header",
        "content": "OWC Amazon Type Breadcrumbs",
        "info": "www.owc1.com"
      },
      {
        "type": "text",
        "id": "custom_class",
        "label": "Custom Classes",
        "info": "Add 'page-width' (without quotes) if you are using Dawn or other free themes. This will line up the section with other sections. Also add 52px side paddings."
      },
      {
        "type": "header",
        "content": "Separator"
      },
      {
        "type": "select",
        "id": "separator_class",
        "label": "Breadcrumbs items separator",
        "default": "arrows",
        "options": [
          {
            "value": "arrows",
            "label": "Arrows"
          },
          {
            "value": "slashes",
            "label": "Slashes"
          }
        ]
      },
      {
        "type": "header",
        "content": "Alignment"
      },
      {
        "type": "select",
        "id": "breadcrumbs_alignment",
        "label": "Breadcrumbs Alignment",
        "default": "left",
        "options": [
          {
            "value": "left",
            "label": "Left"
          },
          {
            "value": "center",
            "label": "Center"
          },
          {
            "value": "right",
            "label": "Right"
          }
        ]
      },
      {
        "type": "header",
        "content": "Colors"
      },
      {
        "type": "color",
        "id": "text_color",
        "label": "Text Color",
        "default": "#000000"
      },
      {
        "type": "color",
        "id": "background_color",
        "label": "Background Color",
        "default": "#ffffff"
      },
      {
        "type": "header",
        "content": "Typography"
      },
      {
        "type": "select",
        "id": "font_weight",
        "label": "Font Weight",
        "default": "normal",
        "options": [
          {
            "value": "normal",
            "label": "Normal"
          },
          {
            "value": "bold",
            "label": "Bold"
          }
        ]
      },
      {
        "type": "select",
        "id": "font_case",
        "label": "Font Case",
        "default": "default",
        "options": [
          {
            "value": "default",
            "label": "Default"
          },
          {
            "value": "uppercase",
            "label": "Uppercase"
          }
        ]
      },
      {
        "type": "range",
        "id": "font_size",
        "label": "Font Size",
        "default": 16,
        "min": 12,
        "max": 24
      },
      {
        "type": "header",
        "content": "Desktop spacing"
      },
      {
        "type": "number",
        "id": "max_width",
        "label": "Max width",
        "info": "To line up the section with the rest of your theme, it's best to use the custom class field above (if possible). But if not, you can set an exact pixel width here. Leave at 0 for full width."
      },
      {
        "type": "range",
        "id": "padding_left",
        "min": 0,
        "max": 100,
        "step": 2,
        "unit": "px",
        "label": "Left padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_right",
        "min": 0,
        "max": 100,
        "step": 2,
        "unit": "px",
        "label": "Right padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_top",
        "min": 0,
        "max": 100,
        "step": 4,
        "unit": "px",
        "label": "Top padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_bottom",
        "min": 0,
        "max": 100,
        "step": 4,
        "unit": "px",
        "label": "Bottom padding",
        "default": 20
      },
      {
        "type": "header",
        "content": "Mobile spacing"
      },
      {
        "type": "range",
        "id": "padding_left_mobile",
        "min": 0,
        "max": 100,
        "step": 2,
        "unit": "px",
        "label": "Left padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_right_mobile",
        "min": 0,
        "max": 100,
        "step": 2,
        "unit": "px",
        "label": "Right padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_top_mobile",
        "min": 0,
        "max": 100,
        "step": 4,
        "unit": "px",
        "label": "Top padding",
        "default": 20
      },
      {
        "type": "range",
        "id": "padding_bottom_mobile",
        "min": 0,
        "max": 100,
        "step": 4,
        "unit": "px",
        "label": "Bottom padding",
        "default": 20
      }
    ],
    "presets": [
      {
        "name": "OWC Breadcrumbs"
      }
    ]
  }
{% endschema %}
