/** Shopify CDN: Minification failed

Line 5088:0 Unexpected "<"
Line 5140:0 Unexpected "<"
Line 5192:0 Unexpected "<"
Line 5196:2 Unexpected "0%"
Line 5197:2 Unexpected "4%"
Line 5198:2 Unexpected "8%"
Line 5199:2 Unexpected "12%"
Line 5200:2 Unexpected "16%"
Line 5201:2 Unexpected "20%"
Line 5202:2 Unexpected "24%"
... and 17 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);
}

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

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

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

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

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

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

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

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

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

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

  text-align: left;
}

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

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

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

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

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

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

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

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

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

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

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

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

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

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

.relative {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

/* Typography presets */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    footer {
      view-transition-name: footer;
    }

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

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

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

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

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

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

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

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

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

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

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

.text-block {
  width: 100%;
}

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

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

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

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

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

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

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

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

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

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

  &::backdrop {
    opacity: 0;
  }
}

/* stylelint-disable value-keyword-case */
.dialog-drawer {
  --dialog-drawer-opening-animation: slideInLeft;
  --dialog-drawer-closing-animation: slideOutLeft;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

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

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

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

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

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

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

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

/* Collapsible row */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[open] {
    opacity: 1;
  }

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

  &::backdrop {
    background: transparent;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.card-gallery {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  .layout-panel-flex--row:not(.mobile-column) {
    .text-block {
      flex: 1 1 var(--max-width--display-tight);
    }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &:has(.checkbox__input:disabled) {
    --checkbox-cursor: not-allowed;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Fly to cart animation */
fly-to-cart {
  position: fixed;
  width: 40px;
  height: 40px;
  left: 0;
  top: 0;
  border-radius: 50%;
  z-index: calc(infinity);
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  transition: opacity 0.3s ease;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: var(--color-foreground);
  transform: translate(var(--x, 0), var(--y, 0)) scale(var(--scale, 1));
}

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

@keyframes slideInLeft {
  from {
    transform: translateX(var(--custom-transform-from, 100%));
  }

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

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

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

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

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

  to {
    transform: translateX(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

/*
 * Slideshow Component
 */
slideshow-component {
  --cursor: grab;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

slideshow-controls[thumbnails]:is([pagination-position='right'], [pagination-position='left']) {
  display: flex;
  flex-direction: column;
  height: 0;
  min-height: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  button {
    --size: 0.5rem;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.slideshow-controls__thumbnail {
  position: relative;
}

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}
/* ===== Fix barra de cuenta regresiva + sin gap superior (mobile) ===== */
@media (max-width: 768px) {
  :root { --promo-bar-h: 54px; } /* Ajustá 44 → 48/52 si tu barra es más alta */

  /* 1) Header siempre desplazado debajo de la barra */
  .shopify-section-header,
  .header-wrapper {
    margin-top: var(--promo-bar-h) !important; /* empuja el logo+carrito */
    position: relative;
    z-index: 30;
  }

  /* 2) Si tu header es sticky, además mantenelo “debajo” de la barra al scrollear */
  .shopify-section-header-sticky {
    top: var(--promo-bar-h) !important;
  }

  /* 3) Asegurarnos de NO agregar espacio extra en el body */
  body {
    padding-top: 0 !important;   /* <- quita la franja blanca */
    margin-top: 0 !important;
  }

  /* 4) Algunas apps insertan un "placeholder/spacer": lo anulamos si aparece */
  [class*="timer"][class*="placeholder"],
  [class*="bar"][class*="spacer"],
  [id*="timer"][class*="placeholder"] {
    height: 0 !important;
    margin: 0 !important;
  }
}
/* ===== SAVIA — Trust Badges Grid refinado ===== */
.savia-trust-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 12px;
}

.savia-trust-badge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #fff;
  border: 1px solid #f1deda;
  border-radius: 14px;
  padding: 12px 8px;
  text-align: center;
  color: #4f403b;
  font-size: 13px;
  line-height: 1.3;
  transition: all 0.2s ease;
}

.savia-trust-badge:hover {
  background: #fff5f3;
  border-color: #eab2a8;
  color: #eab2a8;
}

.savia-trust-badge svg {
  width: 26px;
  height: 26px;
  margin-bottom: 6px;
  color: #eab2a8;
}

.savia-badge-rose {
  background: #fff8f7;
  border-color: #eab2a8;
  font-weight: 600;
}

@media (min-width: 750px) {
  .savia-trust-row {
    gap: 14px;
  }
  .savia-trust-badge svg {
    width: 28px;
    height: 28px;
  }
  .savia-trust-badge {
    font-size: 14px;
    padding: 14px 10px;
  }
}
/* ===== SAVIA — Ajuste espaciado badges / botón ===== */

/* Reduce espacio entre trust badges y el botón */
.savia-trust-row {
  margin-bottom: 6px !important; /* antes era 12–20px */
}

/* También reduce el espacio superior del botón de compra si lo necesitás */
.shopify-section-product .product-form {
  margin-top: 6px !important;
}

/* En caso de que el contenedor del bloque meta padding adicional */
.product__info-container,
.product__info-wrapper {
  padding-bottom: 0 !important;
}

/* Opcional: unifica el bloque visual del área de compra */
.product__info-container {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
/* ===== SAVIA — Corrige espacio entre precio y trust badges ===== */

/* Saca el margen gigante del bloque de precio */
.product__info-wrapper .price,
.product__info-container .price,
.product__price {
  margin-bottom: 8px !important; /* antes ~32px */
}

/* Asegura que el bloque completo quede bien compacto */
.savia-trust-row {
  margin-top: 6px !important;
  margin-bottom: 6px !important;
}

/* Elimina posibles paddings ocultos del contenedor */
.product__info-container {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Ajuste visual extra en mobile */
@media (max-width: 749px) {
  .product__info-wrapper {
    gap: 6px !important;
  }
}
/* ===== SAVIA — Feature chips elegantes ===== */
.savia-feature-chips{
  display:flex; gap:8px; overflow:auto; padding:6px 0;
  scroll-snap-type:x mandatory;
}
.savia-feature-chips .chip{
  display:inline-flex; align-items:center; gap:6px;
  scroll-snap-align:start;
  padding:8px 10px; border:1px solid #f1deda; border-radius:999px;
  background:#fff; color:#4f403b; font-size:13px; white-space:nowrap;
}
.savia-feature-chips .chip svg{
  width:18px; height:18px; color:#eab2a8; flex:0 0 auto;
}
@media (min-width:750px){
  .savia-feature-chips{ gap:10px; }
  .savia-feature-chips .chip{ font-size:13.5px; padding:9px 12px; }
}
/* Wrap con flechas + fades */
.savia-chips-wrap{
  position: relative;
  padding: 2px 34px; /* espacio para flechitas */
}
.chips-nav{
  position:absolute; top:50%; transform:translateY(-50%);
  width:28px; height:28px; border-radius:999px; border:1px solid #f1deda;
  background:#fff; display:flex; align-items:center; justify-content:center;
  color:#a77772; box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.chips-left{ left:0; }
.chips-right{ right:0; }
.chips-nav:disabled{ opacity:.35; pointer-events:none; }

.chips-nav svg{ width:18px; height:18px; }

/* Fades que sugieren overflow */
.chips-fade{
  position:absolute; top:0; bottom:0; width:26px; pointer-events:none;
  background:linear-gradient(to right, rgba(255,255,255,1), rgba(255,255,255,0));
}
.fade-left{ left:34px; transform:scaleX(-1); }
.fade-right{ right:34px; }
.chips-fade.is-off{ opacity:0; }

/* Tus chips existentes */
.savia-feature-chips{ display:flex; gap:8px; overflow:auto; padding:6px 0; scroll-snap-type:x mandatory; }
.savia-feature-chips .chip{ display:inline-flex; align-items:center; gap:6px; scroll-snap-align:start; padding:8px 10px; border:1px solid #f1deda; border-radius:999px; background:#fff; color:#4f403b; font-size:13px; white-space:nowrap; }
.savia-feature-chips .chip svg{ width:18px; height:18px; color:#eab2a8; }
/* ===== SAVIA — Chips en grid 2×2 (sin carrusel) ===== */
.savia-feature-chips.savia-chips-grid{
  display:grid !important;
  grid-template-columns: 1fr 1fr;
  gap:8px;
  overflow:visible;           /* sin scroll horizontal */
  padding:8px 0 4px;
  margin-top:4px;
  margin-bottom:8px;          /* acerca la reseña */
}
.savia-feature-chips.savia-chips-grid .chip{
  justify-content:center;
  padding:9px 10px;
  border:1px solid #f1deda;
  border-radius:999px;
  background:#fff;
  color:#4f403b;
  font-size:13px;
}
.savia-feature-chips.savia-chips-grid .chip svg{
  width:18px; height:18px; color:#eab2a8;
}

@media (min-width: 750px){
  .savia-feature-chips.savia-chips-grid{
    grid-template-columns: repeat(4, auto);
    justify-content:center;
    gap:10px;
  }
}

/* Limpia restos del slider si quedó algo en el DOM */
.savia-chips-wrap, .chips-nav, .chips-fade { display:none !important; }
/* Eyebrow */
.savia-eyebrow{
  margin:10px 0 8px;
  font-size:12px; letter-spacing:.06em; text-transform:uppercase;
  color:#a78984;
}

/* Grid badges */
.savia-trust-row{
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:10px; margin:12px 0 6px;
}
.savia-trust-badge{
  display:flex; flex-direction:column; align-items:center; text-align:center;
  gap:6px; padding:12px 10px; border:1px solid #f1deda; border-radius:14px;
  background:#fff; color:#4f403b; font-size:12.5px; line-height:1.3;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.savia-trust-badge svg{ width:22px; height:22px; color:#eab2a8; }
.savia-badge-rose{ background:#fff7f6; border-color:#eab2a8; font-weight:600; }
.savia-trust-badge:hover{ transform:translateY(-1px); box-shadow:0 4px 10px rgba(0,0,0,.05); border-color:#eab2a8; }

@media (min-width:750px){
  .savia-trust-row{ gap:14px; }
  .savia-trust-badge{ font-size:13px; padding:14px 12px; }
  .savia-trust-badge svg{ width:24px; height:24px; }
}

/* Animación suave (fade-up con escalado leve) */
@keyframes savia-fade-up{
  from { opacity:0; transform:translateY(8px) scale(.98); }
  to   { opacity:1; transform:translateY(0) scale(1); }
}
.savia-anim .savia-trust-badge{
  opacity:0; animation:savia-fade-up .45s ease forwards;
}
.savia-anim .savia-trust-badge:nth-child(1){ animation-delay: .02s; }
.savia-anim .savia-trust-badge:nth-child(2){ animation-delay: .08s; }
.savia-anim .savia-trust-badge:nth-child(3){ animation-delay: .14s; }
.savia-anim .savia-trust-badge:nth-child(4){ animation-delay: .20s; }

/* Respeta usuarios con reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  .savia-anim .savia-trust-badge{ animation:none; opacity:1; }
}
/* ===== SAVIA — Polish de chips (beneficios) ===== */

/* Compacta y suaviza el look */
.savia-feature-chips.savia-chips-grid .chip{
  padding: 7px 12px;                 /* un toque más bajitos */
  font-size: 12.5px;                 /* tipografía más fina */
  border: 1px solid #f1e4e0;         /* borde más suave */
  background: #fff;                  /* fondo limpio */
  border-radius: 999px;
  box-shadow: inset 0 1px 0 rgba(0,0,0,.03); /* micro relieve */
  transition: border-color .18s ease, transform .18s ease, box-shadow .18s ease;
}

/* Ícono más sutil y alineado */
.savia-feature-chips.savia-chips-grid .chip svg{
  width: 15px; height: 15px;
  color: #e0a9a1;        /* menos saturado que #eab2a8 */
  margin-top: -1px;      /* corrige baseline del texto */
  opacity: .9;
  transition: color .18s ease, opacity .18s ease;
}

/* Hover/press elegante (no “grita”) */
.savia-feature-chips.savia-chips-grid .chip:hover{
  border-color: #eab2a8;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
  transform: translateY(-1px);
}
.savia-feature-chips.savia-chips-grid .chip:active{
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

/* Espaciado con el bloque de “Llevate más…” */
.savia-feature-chips.savia-chips-grid{
  margin-bottom: 10px;   /* separa de la línea título siguiente */
}

/* Variante ultra-minimal (por si querés probar sin íconos) */
/* .savia-feature-chips.savia-chips-grid .chip svg{ display:none; }
   .savia-feature-chips.savia-chips-grid .chip{ padding:8px 14px; } */
/* ===== SAVIA · Accordion ===== */
.savia-eyebrow{
  margin: 10px 0 8px; font-size:12px; letter-spacing:.06em;
  text-transform:uppercase; color:#a78984;
}
.savia-accordion{
  display: grid; gap: 10px; margin: 8px 0 14px;
}
.savia-accordion details{
  border:1px solid #f1deda; border-radius:14px; background:#fff;
  overflow:hidden; transition:border-color .2s ease, box-shadow .2s ease;
}
.savia-accordion details:hover{ border-color:#eab2a8; box-shadow:0 2px 10px rgba(0,0,0,.04); }

.savia-accordion summary{
  list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:12px 14px;
  color:#3f3531; font-weight:600;
}
.savia-accordion summary::-webkit-details-marker{ display:none; }

.savia-accordion summary svg{
  width:18px; height:18px; color:#eab2a8; flex:0 0 auto;
  transition: transform .25s ease;
}
.savia-accordion details[open] summary svg{ transform: rotate(180deg); }

.savia-accordion .content{
  padding: 0 14px 12px 14px; color:#4f403b; font-size:14px; line-height:1.5;
  animation: savia-acc-fade .28s ease;
}
.savia-accordion .content .note{ color:#7a6b66; }

.savia-accordion .content ul{ margin:6px 0 0; padding-left:18px; }
.savia-accordion .content li{ margin:6px 0; }

@keyframes savia-acc-fade{
  from{ opacity:0; transform: translateY(4px); }
  to{ opacity:1; transform: translateY(0); }
}

/* Respeta reducción de movimiento */
@media (prefers-reduced-motion: reduce){
  .savia-accordion .content{ animation:none; }
}

/* Desktop: un toque más aire */
@media (min-width:750px){
  .savia-accordion{ gap:12px; }
  .savia-accordion summary{ padding:14px 16px; }
  .savia-accordion .content{ padding: 0 16px 14px 16px; }
}
.savia-cuotas{
  font-size: 14px;
  color:#6b5550;
  margin-top:4px;
  text-align:left;
}
.savia-cuotas strong{
  color:#eab2a8;
  font-weight:600;
}
.savia-cuotas span{
  color:#3b2c2a;
  font-weight:700;
}/* Savia: líneas debajo del precio */
.savia-buy-meta{ margin-top:6px; display:grid; gap:2px; }
.savia-line{ font-size:14px; color:#6b5550; margin:0; }
.savia-line.cuotas strong{ color:#eab2a8; font-weight:700; }
.savia-line.cuotas span#saviaCuotaValor{ color:#3b2c2a; font-weight:800; }
.savia-line.envio .rosa{ color:#eab2a8; font-weight:700; }
/* SAVIA · reseñas reales estilo Amazon */
.savia-real-reviews{margin:24px 0;padding:0 4px;}
.savia-real-reviews .savia-eyebrow{font-size:13px;text-transform:uppercase;letter-spacing:.05em;color:#a78984;margin-bottom:10px;text-align:center;}
.savia-real-reviews .savia-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.rev{background:#fff;border:1px solid #f0dcd9;border-radius:14px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.04);transition:transform .2s ease,box-shadow .2s ease;}
.rev:hover{transform:translateY(-3px);box-shadow:0 6px 14px rgba(0,0,0,.08);}
.rev-photo{width:100%;aspect-ratio:4/3;object-fit:cover;}
.rev-profile{display:flex;align-items:center;gap:8px;padding:8px 10px;}
.rev-profile img{width:34px;height:34px;border-radius:50%;object-fit:cover;}
.rev-noimg{width:34px;height:34px;border-radius:50%;background:#eab2a845;color:#5a4a47;display:flex;align-items:center;justify-content:center;font-weight:600;}
.rev-profile div strong{color:#3b2c2a;font-weight:700;}
.rev-profile div span{color:#8a7a75;font-size:12px;}
.rev-profile p{color:#f6b300;margin:0;font-size:12px;}
.rev-text{font-size:13px;line-height:1.45;color:#3f3531;padding:0 10px 10px;}
/* badge verified */
.rev::after{
  content:"Compradora verificada";
  position:absolute;right:10px;top:10px;
  background:rgba(234,178,168,0.18);
  color:#7a6b68;font-size:10.5px;font-weight:500;
  padding:4px 8px;border-radius:999px;border:1px solid #e7cfc9;
  backdrop-filter:blur(3px);
}
@media(min-width:750px){
  .savia-real-reviews .savia-grid{grid-template-columns:repeat(3,1fr);}
}
/* ===== FIX SAVIA · Reviews encimadas/chicas ===== */

/* 1) Aire y contención del bloque */
.savia-real-reviews{
  margin: 24px 0 36px !important;
  padding: 0 12px;
  clear: both;      /* evita solaparse con la sección anterior */
}

/* 2) Grid más cómodo en mobile */
.savia-real-reviews .savia-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;        /* +espacio entre cards */
}

/* 3) Card: crear contexto para el badge y evitar que "suba" */
.rev{
  position: relative;              /* <- clave para el badge */
  background: #fff;
  border: 1px solid #f0dcd9;
  border-radius: 14px;
  overflow: hidden;                /* badge queda dentro */
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.rev:hover{ transform: translateY(-2px); box-shadow: 0 8px 16px rgba(0,0,0,.08); border-color:#eab2a8; }

/* 4) Foto más grande y prolija */
.rev-photo{
  width: 100%;
  aspect-ratio: 4 / 3;             /* tamaño consistente */
  object-fit: cover;
  display: block;
  background:#fff5f3;
  border-bottom: 1px solid #f4e5e1;
}

/* 5) Perfil + texto más legibles */
.rev-profile{ display:flex; align-items:center; gap:10px; padding:10px 12px 6px; }
.rev-profile img{ width:36px; height:36px; border-radius:50%; object-fit:cover; }
.rev-noimg{ width:36px; height:36px; border-radius:50%; background:#eab2a845; color:#5a4a47; display:flex; align-items:center; justify-content:center; font-weight:700; }
.rev-profile strong{ color:#3b2c2a; font-weight:700; font-size:13.5px; }
.rev-profile span{ color:#8a7a75; font-size:12px; }
.rev-profile p{ color:#f6b300; margin:0; font-size:12px; letter-spacing:.5px; }

.rev-text{ padding:0 12px 12px; font-size:13.5px; line-height:1.45; color:#3f3531; }

/* 6) Badge "Compradora verificada" bien contenido */
.rev::after{
  content:"Compradora verificada";
  position:absolute; right:10px; top:10px;
  z-index: 2;
  background: rgba(234,178,168,0.18);
  color:#7a6b68; font-size:11px; font-weight:600;
  padding:5px 9px; border-radius:999px;
  border:1px solid #e7cfc9;
  backdrop-filter: blur(3px);
}

/* 7) Desktop: 3 por fila y un poco más de aire */
@media (min-width: 750px){
  .savia-real-reviews{ padding: 0; }
  .savia-real-reviews .savia-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .rev-profile strong{ font-size:14px; }
  .rev-text{ font-size:14px; }
}
/* ===== SAVIA · Reviews — FIX final ===== */

/* Contenedor con aire y sin solaparse con secciones anteriores */
.savia-real-reviews{
  position: relative;
  margin: 28px 0 40px !important;
  padding: 0 12px;
  clear: both;
  z-index: 1;
}

/* Título fino */
.savia-real-reviews .savia-eyebrow{
  text-align:center;
  margin: 0 0 12px;
  font-size: 12.5px;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #a78984;
}

/* Grid mobile 2x, desktop 3x */
.savia-real-reviews .savia-grid{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

/* Card contenida (para que el badge no se escape) */
.rev{
  position: relative;
  background: #fff;
  border: 1px solid #f0dcd9;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.rev:hover{ transform: translateY(-2px); box-shadow: 0 8px 16px rgba(0,0,0,.08); border-color:#eab2a8; }

/* Foto consistente y separada */
.review-photo{ position: relative; background:#fff5f3; }
.review-photo img{
  width: 100%; aspect-ratio: 4/3; object-fit: cover; display:block;
  border-bottom: 1px solid #f4e5e1;
}

/* Badge interno (NO pseudo-elemento) */
.verified-badge{
  position: absolute; left: 10px; top: 10px;
  background: rgba(234,178,168,.18);
  border: 1px solid #e7cfc9;
  color: #7a6b68; font-size: 11px; font-weight: 600;
  padding: 5px 9px; border-radius: 999px;
  backdrop-filter: blur(3px);
}

/* Perfil y texto */
.rev-profile{ display:flex; align-items:center; gap:10px; padding:10px 12px 6px; }
.rev-profile img{ width:36px; height:36px; border-radius:50%; object-fit:cover; }
.rev-noimg{ width:36px; height:36px; border-radius:50%; background:#eab2a845; color:#5a4a47; display:flex; align-items:center; justify-content:center; font-weight:700; }
.rev-profile strong{ color:#3b2c2a; font-weight:700; font-size:13.5px; }
.rev-profile span{ color:#8a7a75; font-size:12px; }
.rev-profile p{ color:#f6b300; margin:0; font-size:12px; letter-spacing:.4px; }

.rev-text{ padding:0 12px 12px; font-size:13.5px; line-height:1.45; color:#3f3531; }

/* Elimina cualquier pseudo-badge anterior si quedó */
.rev::after{ content: none !important; }

/* Desktop */
@media (min-width: 750px){
  .savia-real-reviews{ padding: 0; }
  .savia-real-reviews .savia-grid{ grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .rev-profile strong{ font-size:14px; }
  .rev-text{ font-size:14px; }
}
/* ===== SAVIA · Reviews – FIX de espacio y superposición ===== */

/* 0) El bloque anterior (FAQ / newsletter / rich-text) a veces deja mucho aire */
.savia-accordion,
.shopify-section [class*="newsletter"],
.shopify-section [class*="rich-text"] {
  margin-bottom: 10px !important;
  padding-bottom: 0 !important;
}

/* 1) Asegurar que la sección que contiene las reviews NO recorte ni fije altura */
.shopify-section:has(.savia-real-reviews) {
  overflow: visible !important;
  height: auto !important;
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* 2) Nuestro bloque de reviews: en flujo, con aire justo */
.savia-real-reviews {
  position: relative;
  display: block;
  clear: both;                 /* corta cualquier float anterior */
  margin: 12px 0 24px !important;
  padding: 0 12px;
  z-index: 1;
}

/* 3) Grid consistente (2 en mobile, 3 en desktop) */
.savia-real-reviews .savia-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}

@media (min-width: 750px) {
  .savia-real-reviews { padding: 0; margin: 16px 0 32px !important; }
  .savia-real-reviews .savia-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
}

/* 4) Cards contenidas (para que el badge no “salte”) */
.rev {
  position: relative;          /* el badge queda dentro */
  background: #fff;
  border: 1px solid #f0dcd9;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
}
.review-photo { position: relative; }
.review-photo img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.verified-badge {
  position: absolute; left: 10px; top: 10px;
  background: rgba(234,178,168,.18);
  border: 1px solid #e7cfc9;
  color: #7a6b68; font-size: 11px; font-weight: 600;
  padding: 5px 9px; border-radius: 999px;
  backdrop-filter: blur(3px);
}

/* 5) Footer siempre debajo, sin comerse las cards */
#shopify-section-footer,
footer, .footer {
  position: relative;
  clear: both;
  margin-top: 18px !important;
}

/* 6) Por si quedó el pseudo-badge viejo en alguna versión */
.rev::after { content: none !important; }
/* ——— Reviews: foto vertical 3:4 (recorte suave) ——— */
.savia-real-reviews .review-photo{
  position: relative;
  background:#fff5f3;
}
.savia-real-reviews .review-photo img{
  width:100%;
  aspect-ratio: 3 / 4;      /* antes 4/3 */
  object-fit: cover;
  object-position: center;  /* recorta centrado */
  display:block;
  border-bottom:1px solid #f4e5e1;
}

/* un poquito más de aire y “card look” */
.rev{ border:1px solid #f0dcd9; border-radius:16px; box-shadow:0 3px 10px rgba(0,0,0,.06); }
.rev:hover{ transform:translateY(-2px); box-shadow:0 10px 18px rgba(0,0,0,.09); }

/* ——— Badge de red social (moñito) ——— */
.source-badge{
  position:absolute; right:10px; top:10px; z-index:3;
  width:26px; height:26px; border-radius:50%;
  display:grid; place-items:center;
  background:rgba(255,255,255,.82);
  border:1px solid #e7cfc9; box-shadow:0 2px 6px rgba(0,0,0,.08);
  backdrop-filter: blur(2px);
}
.source-badge svg{ width:14px; height:14px; }
.source-badge.tiktok svg{ fill:#000; }
.source-badge.facebook svg{ fill:#1877f2; }
.source-badge.instagram svg{ fill:#d62976; } /* por si querés usar */
/* ===== SAVIA · Reviews (vertical + moñitos) ===== */

.savia-real-reviews{
  position:relative; isolation:isolate;
  margin:24px 0 40px !important; padding:0 12px; clear:both; z-index:1;
}
.savia-real-reviews .savia-eyebrow{
  text-align:center; margin:0 0 12px;
  font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:#a78984;
}

/* grid: 2 en mobile, 3 en desktop */
.savia-real-reviews .savia-grid{
  display:grid !important; grid-template-columns:repeat(2,1fr); gap:12px;
}
@media (min-width:750px){
  .savia-real-reviews{ padding:0; margin:28px 0 44px !important; }
  .savia-real-reviews .savia-grid{ grid-template-columns:repeat(3,1fr); gap:14px; }
}

/* card */
.rev{
  position:relative; background:#fff; border:1px solid #f0dcd9; border-radius:16px;
  overflow:hidden; box-shadow:0 3px 10px rgba(0,0,0,.06);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.rev:hover{ transform:translateY(-2px); box-shadow:0 10px 18px rgba(0,0,0,.09); border-color:#eab2a8; }

/* foto 3:4 vertical */
.review-photo{ position:relative; background:#fff5f3; }
.review-photo img{
  width:100%; aspect-ratio:3/4; object-fit:cover; object-position:center; display:block;
  border-bottom:1px solid #f4e5e1;
}

/* badges */
.verified-badge{
  position:absolute; left:10px; top:10px;
  background:rgba(234,178,168,.18); border:1px solid #e7cfc9;
  color:#7a6b68; font-size:11px; font-weight:600;
  padding:5px 9px; border-radius:999px; backdrop-filter:blur(2px);
}
.source-badge{
  position:absolute; right:10px; top:10px; z-index:3;
  width:26px; height:26px; border-radius:50%;
  display:grid; place-items:center; background:rgba(255,255,255,.85);
  border:1px solid #e7cfc9; box-shadow:0 2px 6px rgba(0,0,0,.08); backdrop-filter:blur(2px);
}
.source-badge svg{ width:14px; height:14px; }
.source-badge.facebook svg{ fill:#1877f2; }
.source-badge.instagram svg{ fill:#d62976; }
.source-badge.tiktok svg{ fill:#000; } /* TikTok limpio */

/* perfil + texto */
.rev-profile{ display:flex; align-items:center; gap:10px; padding:10px 12px 6px; }
.rev-profile img{ width:36px; height:36px; border-radius:50%; object-fit:cover; }
.rev-noimg{ width:36px; height:36px; border-radius:50%; background:#eab2a845; color:#5a4a47; display:flex; align-items:center; justify-content:center; font-weight:700; }
.rev-profile strong{ color:#3b2c2a; font-weight:700; font-size:13.5px; }
.rev-profile span{ color:#8a7a75; font-size:12px; }
.rev-profile p{ color:#f6b300; margin:0; font-size:12px; letter-spacing:.4px; }
.rev-text{ padding:0 12px 12px; font-size:13.5px; line-height:1.45; color:#3f3531; }

/* seguridad extra por si quedó pseudo-badge viejo */
.rev::after{ content:none !important; }

/* aplanar bloques de arriba/abajo para que no se encimen */
.shopify-section [class*="rich-text"], .shopify-section [class*="newsletter"]{
  margin-bottom:12px !important; padding-bottom:0 !important; overflow:visible !important;
}
#shopify-section-footer, footer, .footer{ position:relative; clear:both; margin-top:18px !important; }
/* ===== SAVIA · Reviews (unificadas, foto full-width arriba) ===== */

.savia-real-reviews{ position:relative; isolation:isolate; margin:24px 0 40px!important; padding:0 12px; clear:both; z-index:1; }
.savia-real-reviews .savia-eyebrow{ text-align:center; margin:0 0 12px; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:#a78984; }

.savia-real-reviews .savia-grid{ display:grid!important; grid-template-columns:repeat(2,1fr); gap:12px; }
@media (min-width:750px){ .savia-real-reviews{ padding:0; margin:28px 0 44px!important; } .savia-real-reviews .savia-grid{ grid-template-columns:repeat(3,1fr); gap:14px; } }

.rev{ position:relative; background:#fff; border:1px solid #f0dcd9; border-radius:16px; overflow:hidden; box-shadow:0 3px 10px rgba(0,0,0,.06); transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.rev:hover{ transform:translateY(-2px); box-shadow:0 10px 18px rgba(0,0,0,.09); border-color:#eab2a8; }

/* Foto SIEMPRE arriba y a todo ancho */
.review-photo{ position:relative; background:#fff; order:0; }
.review-photo img{ display:block; width:100%!important; height:auto; aspect-ratio:3/4; object-fit:cover; object-position:center; border-bottom:1px solid #f4e5e1; }

/* Moñitos (sin “Compradora verificada”) */
.verified-badge{ display:none!important; }
.source-badge{ position:absolute; right:6px; top:6px; z-index:3; width:22px; height:22px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.90); border:1px solid #e7cfc9; box-shadow:0 1px 4px rgba(0,0,0,.08); backdrop-filter:blur(2px); }
.source-badge svg{ width:12px; height:12px; }
.source-badge.facebook svg{ fill:#1877f2; } .source-badge.instagram svg{ fill:#d62976; } .source-badge.tiktok svg{ fill:#000; }

/* Perfil + texto */
.rev-profile{ display:flex; align-items:center; gap:10px; padding:10px 12px 6px; }
.rev-profile img{ width:36px; height:36px; border-radius:50%; object-fit:cover; }
.rev-noimg{ width:36px; height:36px; border-radius:50%; background:#eab2a845; color:#5a4a47; font-weight:700; display:flex; align-items:center; justify-content:center; }
.rev-profile strong{ color:#3b2c2a; font-weight:700; font-size:13.5px; }
.rev-profile span{ color:#8a7a75; font-size:12px; }
.rev-profile p{ color:#f6b300; margin:0; font-size:12px; letter-spacing:.4px; }
.rev-text{ padding:0 12px 12px; font-size:13.5px; line-height:1.45; color:#3f3531; }

/* Aplanar bloques vecinos para que no se encimen */
.shopify-section [class*="rich-text"], .shopify-section [class*="newsletter"]{ margin-bottom:12px!important; padding-bottom:0!important; overflow:visible!important; }
#shopify-section-footer, footer, .footer{ position:relative; clear:both; margin-top:18px!important; }
/* ===== SAVIA · Reviews — foto full width sin márgenes ===== */
.savia-real-reviews .rev{ padding:0 !important; }                 /* la card no agrega padding arriba */
.savia-real-reviews .review-photo{ 
  margin:0 !important; padding:0 !important; width:100% !important;
}
.savia-real-reviews .review-photo img{
  display:block !important;
  width:100% !important;            /* fuerza full-width */
  height:auto !important;
  aspect-ratio: 3 / 4;              /* poné 2/3 si la querés aún más alta */
  object-fit: cover !important;
  object-position: center !important;
  border:0; border-bottom:1px solid #f4e5e1;
}
/* por si el theme mete max-width a <img> */
.savia-real-reviews .review-photo img[style*="max-width"],
.savia-real-reviews .review-photo img{ max-width:100% !important; }
/* ====== SAVIA · Comparativa ====== */
.savia-compare{margin:22px 0 10px;padding:0 12px}
.savia-compare__title{font-size:18px;line-height:1.2;margin:0 0 12px;text-align:center;color:#4a3b38}
.savia-compare__title span{color:#e09a90}

.savia-compare__grid{display:grid;gap:12px}
@media(min-width:740px){.savia-compare__grid{grid-template-columns:1fr 1fr;gap:14px}}

.savia-compare__card{position:relative;background:#fff;border:1px solid #f0dcd9;border-radius:16px;box-shadow:0 3px 10px rgba(0,0,0,.06);overflow:hidden}
.savia-compare__card.is-best{border-color:#eab2a8;box-shadow:0 6px 16px rgba(234,178,168,.28)}
.savia-compare__ribbon{position:absolute;right:-44px;top:14px;transform:rotate(35deg);background:#eab2a8;color:#fff;font-weight:700;font-size:11px;padding:6px 52px;letter-spacing:.02em}

.savia-compare__head{padding:14px 14px 8px;border-bottom:1px solid #f4e5e1}
.savia-compare__head h4{margin:0 0 4px;font-size:16px;color:#3c2e2b}
.savia-compare__head p{margin:0;color:#8a7a75;font-size:12.5px}

.savia-compare__list{list-style:none;margin:0;padding:10px 14px;display:grid;gap:8px}
.savia-compare__list li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:#3f3531}
.savia-compare__list .ok,.savia-compare__list .no{
  flex:0 0 18px;height:18px;border-radius:50%;display:inline-block;margin-top:2px;
  background:#bfcba2;mask:var(--icon-ok) no-repeat center/12px; -webkit-mask:var(--icon-ok) no-repeat center/12px;
}
.savia-compare__list .no{background:#e7b5ad;mask:var(--icon-x) no-repeat center/12px;-webkit-mask:var(--icon-x) no-repeat center/12px}
.savia-compare .pink{color:#e09a90}

/* SVGs como mask (no necesitas snippets) */
:root{
  --icon-ok: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M9.2 16.2 5.7 12.7l-1.4 1.4 4.9 4.9L19.7 8.5l-1.4-1.4z"/></svg>');
  --icon-x:  url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path fill="%23000" d="M6.4 5l12.7 12.7-1.4 1.4L5 6.4z"/><path fill="%23000" d="M18.7 5 6 17.7l-1.4-1.4L17.3 3.6z"/></svg>');
}

.savia-compare__cta{padding:8px 14px 14px}
.savia-compare__btn{
  display:block;text-align:center;background:#eab2a8;color:#fff;border-radius:999px;
  padding:10px 14px;font-weight:700
}
.savia-compare__btn:active{transform:translateY(1px)}
.savia-compare__note{display:block;text-align:center;margin-top:6px;color:#8a7a75}
.savia-compare__hint{display:block;text-align:center;color:#8a7a75}
<style>
/* ====== SAVIA · Animaciones suaves ====== */
:root{
  --savia-dur: .6s;            /* duración base */
  --savia-ease: cubic-bezier(.22,.61,.36,1); /* ease elegante */
  --savia-stagger: .12s;       /* escalonado entre hijos */
}

.savia-reveal{
  opacity:0;
  transform: translateY(14px) scale(.985);
  transition:
    opacity var(--savia-dur) var(--savia-ease),
    transform var(--savia-dur) var(--savia-ease);
  will-change: opacity, transform;
}

.savia-reveal.is-inview{
  opacity:1;
  transform: none;
}

/* Stagger: cada hijo puede definir --i: 0,1,2... */
.savia-stagger > *{
  transition-delay: calc(var(--i, 0) * var(--savia-stagger));
}

/* Cards con micro-hover */
.savia-card-float{
  transition: transform .35s var(--savia-ease), box-shadow .35s var(--savia-ease);
}
.savia-card-float:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0,0,0,.07);
}

/* Ticker más suave (puede pisar el existente) */
.savia-ticker .ticker-track{
  animation: savia-scroll 14s linear infinite; /* más smooth */
}
@keyframes savia-scroll{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }
}

/* Accesibilidad: si el usuario prefiere menos movimiento */
@media (prefers-reduced-motion: reduce){
  .savia-reveal,
  .savia-card-float,
  .savia-ticker .ticker-track{ transition: none !important; animation: none !important; }
  .savia-reveal{ opacity:1; transform:none; }
}
</style>

<script>
/* ====== SAVIA · Observer para aparición on-scroll ====== */
(function(){
  const els = document.querySelectorAll('.savia-reveal');
  if(!('IntersectionObserver' in window) || !els.length){ 
    els.forEach(el => el.classList.add('is-inview')); 
    return;
  }
  const io = new IntersectionObserver((entries)=>{
    entries.forEach(entry=>{
      if(entry.isIntersecting){
        entry.target.classList.add('is-inview');
        io.unobserve(entry.target);
      }
    });
  }, { rootMargin: '0px 0px -10% 0px', threshold: .12 });
  els.forEach(el=>io.observe(el));
})();
</script>
<style>
/* ===== SAVIA · Chips overrides: +speed y aura sin corte ===== */

/* por si algún padre recorta la aurora */
.savia-chips-block{ overflow: visible !important; }

/* 1) Más velocidad en el “flotado” y un poquito más de amplitud */
@keyframes chipFloatF {
  0%   { transform: translate3d(0,0,0); }
  25%  { transform: translate3d(1px,-8px,0); }
  50%  { transform: translate3d(0,-5px,0); }
  75%  { transform: translate3d(-1px,-8px,0); }
  100% { transform: translate3d(0,0,0); }
}
.savia-chips-block .chip{
  animation: chipFloatF 4.2s ease-in-out infinite !important; /* antes 5.2s */
}

/* 2) Aurora más grande, más blur y máscara más suave (sin bordes rectos) */
.savia-chips-block .aurora{
  inset: -55% -40% !important;      /* agranda el lienzo invisible */
  filter: blur(56px) !important;     /* difuminado más amplio */
  opacity: .44 !important;
  /* fade de bordes para que no se note el rectángulo */
  mask-image: radial-gradient(70% 65% at 50% 50%, #000 52%, rgba(0,0,0,0) 100%) !important;
  -webkit-mask-image: radial-gradient(70% 65% at 50% 50%, #000 52%, rgba(0,0,0,0) 100%) !important;
}

/* 3) Un pelín más de vida en las capas del aura (pero smooth) */
.savia-chips-block .layer1{ animation: aurora1 18s ease-in-out infinite !important; } /* antes 24s */
.savia-chips-block .layer2{ animation: aurora2 22s ease-in-out infinite !important; } /* antes 30s */
</style>
/* ===== SAVIA · Vibración botón ATC ===== */
@keyframes saviaBuzz {
  /* 0–28% vibra rápido, 28–100% descansa → total 0.85s */
  0%   { transform: translate3d(0,0,0) rotate(0);           box-shadow: 0 6px 18px rgba(234,178,168,.25); }
  4%   { transform: translate3d(1.2px, -0.6px, 0) rotate(0.3deg); }
  8%   { transform: translate3d(-1.4px, 0.8px, 0) rotate(-0.3deg); }
  12%  { transform: translate3d(1.6px, 0.4px, 0) rotate(0.4deg); }
  16%  { transform: translate3d(-1.8px, -0.6px, 0) rotate(-0.4deg); }
  20%  { transform: translate3d(1.4px, 0.6px, 0) rotate(0.3deg); }
  24%  { transform: translate3d(-1.0px, 0, 0) rotate(-0.2deg); }
  28%  { transform: translate3d(0,0,0) rotate(0);             box-shadow: 0 6px 18px rgba(234,178,168,.25); }
  100% { transform: translate3d(0,0,0) rotate(0);             box-shadow: 0 6px 18px rgba(234,178,168,.10); }
}

/* clase que activamos desde JS */
.savia-buzz {
  animation: saviaBuzz .85s ease-in-out infinite;
  transform-origin: center;
  will-change: transform;
}

/* suavidad: si el usuario prefiere menos movimiento, lo apagamos */
@media (prefers-reduced-motion: reduce){
  .savia-buzz { animation: none !important; }
}

/* UX: si el mouse está encima, pausamos para no molestar */
.savia-buzz:hover { animation-play-state: paused; }
<!-- SAVIA · Buzz para botón Agregar al carrito (autocontenido) -->
<style>
  /* Vibración corta + descanso: total 0.85s */
  @keyframes saviaBuzz85 {
    0%   { transform: translate3d(0,0,0) rotate(0);              box-shadow: 0 6px 18px rgba(234,178,168,.25); }
    4%   { transform: translate3d(1.2px,-0.6px,0) rotate(0.3deg); }
    8%   { transform: translate3d(-1.4px,0.8px,0) rotate(-0.3deg);}
    12%  { transform: translate3d(1.6px,0.4px,0) rotate(0.4deg);  }
    16%  { transform: translate3d(-1.8px,-0.6px,0) rotate(-0.4deg);}
    20%  { transform: translate3d(1.4px,0.6px,0) rotate(0.3deg);  }
    24%  { transform: translate3d(-1.0px,0,0) rotate(-0.2deg);    }
    28%  { transform: translate3d(0,0,0) rotate(0);               box-shadow: 0 6px 18px rgba(234,178,168,.25); }
    100% { transform: translate3d(0,0,0) rotate(0);               box-shadow: 0 6px 18px rgba(234,178,168,.10); }
  }
  /* Clase que activa el efecto */
  .savia-buzz {
    animation: saviaBuzz85 .85s ease-in-out infinite !important;
    transform-origin: center;
    will-change: transform;
  }
  /* Si el user prefiere menos animaciones → off */
  @media (prefers-reduced-motion: reduce){
    .savia-buzz { animation: none !important; }
  }
  /* UX: si pasa el mouse, pausamos */
  .savia-buzz:hover { animation-play-state: paused; }

  /* Asegura que el botón permita transform (algunos themes usan overflow) */
  button[name="add"],
  .product-form__submit,
  button[type="submit"][data-add-to-cart],
  #AgregarAlCarrito {
    position: relative;
    will-change: transform, box-shadow;
  }
</style>

<script>
(function(){
  const SELECTORS = [
    'button[name="add"]',
    '.product-form__submit',
    'button[type="submit"][data-add-to-cart]',
    '#AgregarAlCarrito'
  ].join(',');

  function applyBuzz(root=document){
    const btns = root.querySelectorAll(SELECTORS);
    btns.forEach(btn => btn.classList.add('savia-buzz'));
  }

  // 1) Intento inmediato + reintentos (por si el theme lo inyecta tarde)
  applyBuzz();
  let tries = 0;
  const int = setInterval(() => {
    applyBuzz();
    if (++tries > 20) clearInterval(int); // ~2s de reintentos
  }, 100);

  // 2) Si el DOM cambia (cambios de variante / bloques dinámicos), volvemos a aplicar
  const mo = new MutationObserver(() => applyBuzz());
  mo.observe(document.documentElement, { childList: true, subtree: true });

  // 3) Si querés vibrar también el “Comprar ahora” dinámico:
  const dynSel = '.shopify-payment-button__button';
  const intDyn = setInterval(() => {
    const dyn = document.querySelector(dynSel);
    if (dyn) { dyn.classList.add('savia-buzz'); clearInterval(intDyn); }
  }, 200);
})();
</script>
/* --- HORIZON / slideshow: mostrar la imagen completa sin recortes --- */
.slideshow .banner__media img,
.slideshow__slide .media img,
.slideshow__slide img,
.section-slideshow .banner__media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;           /* NO recorta */
  object-position: right center !important; /* foco a la derecha */
  background-color: #F6E7E3 !important;     /* rosa SAVIA para bandas */
}

/* Quitar cualquier overlay/texto del tema en el slide */
.slideshow .banner__content,
.slideshow__text-wrapper,
.slideshow .banner__box {
  display: none !important;
}

/* Anular alturas mínimas que fuerzan recorte */
.slideshow__slide,
.slideshow .banner,
.section-slideshow .banner__media,
.section-slideshow .slideshow__media {
  min-height: unset !important;
  height: auto !important;
  aspect-ratio: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

/* Mobile: también contain + foco a la derecha */
@media (max-width: 749px) {
  .slideshow .banner__media img { 
    object-fit: contain !important;
    object-position: right center !important;
  }
}
/* HORIZON slideshow: mostrar imagen completa y foco a la derecha (sin recortes) */
.section-slideshow .banner__media img,
.slideshow .banner__media img,
.slideshow__slide .media img,
.slideshow__slide img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;           /* evita recortes */
  object-position: right center !important; /* deja libre el área izquierda de tu arte */
  background-color: #F6E7E3 !important;     /* rosa SAVIA para las bandas vacías */
}

/* Quitar alturas mínimas que fuerzan recorte */
.section-slideshow .banner__media,
.section-slideshow .slideshow__media,
.slideshow__slide,
.slideshow .banner {
  min-height: unset !important;
  height: auto !important;
  aspect-ratio: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}

@media (max-width: 749px) {
  .section-slideshow .banner__media img { 
    object-fit: contain !important;
    object-position: center top !important; /* si querés que en mobile se vea más arriba */
  }
}

/* Ocultar textos/overlays del tema dentro del slide */
.slideshow .banner__content,
.slideshow .banner__box,
.slideshow__text-wrapper { display: none !important; }
/* HORIZON slideshow con background-image: sin recortes y foco derecha */
.section-slideshow .banner__media,
.slideshow .banner__media,
.slideshow__slide .banner__media {
  background-size: contain !important;       /* clave para no recortar */
  background-position: right center !important;
  background-repeat: no-repeat !important;
  background-color: #F6E7E3 !important;      /* rosa SAVIA en los márgenes */
  min-height: unset !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}

@media (max-width: 749px) {
  .section-slideshow .banner__media { 
    background-position: center top !important; 
  }
}

/* Ocultar cualquier contenido superpuesto del tema */
.slideshow .banner__content,
.slideshow .banner__box,
.slideshow__text-wrapper { display: none !important; }
/* ===== SAVIA · Fix hero/diapositivas sin recortes ===== */

/* 1) Hacer que la imagen entre completa y se alinee a la derecha */
section[id^="shopify-section"][data-section-type*="slideshow"] .banner__media img,
section[id^="shopify-section"][data-section-type*="slideshow"] .slideshow__slide img,
section[id^="shopify-section"] .slideshow__slide .media img,
.section-slideshow .slideshow__slide img,
.banner--slideshow .media img {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain !important;          /* sin recortes */
  object-position: right center !important;/* aire a la izq para tu texto */
  display: block !important;
}

/* 2) El contenedor no debe meter acolchados raros */
section[id^="shopify-section"][data-section-type*="slideshow"],
section[id^="shopify-section"][data-section-type*="slideshow"] .banner,
section[id^="shopify-section"][data-section-type*="slideshow"] .slideshow__slide,
.section-slideshow, .section-slideshow .banner, .slideshow__slide {
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}

/* 3) Alto consistente en mobile (ajustá valores a gusto) */
@media (max-width: 749px) {
  section[id^="shopify-section"][data-section-type*="slideshow"] .banner__media,
  section[id^="shopify-section"][data-section-type*="slideshow"] .slideshow__slide,
  .section-slideshow .slideshow__slide {
    min-height: 460px !important;
  }
}

/* 4) Si no querés que aparezca el texto/botón por defecto del slide */
section[id^="shopify-section"][data-section-type*="slideshow"] .banner__content,
section[id^="shopify-section"][data-section-type*="slideshow"] .slideshow__controls,
.section-slideshow .banner__content,
.section-slideshow .slideshow__controls {
  display: none !important;
}
/* ===== SAVIA · Slideshow mobile 4:5 (1080x1350) ===== */
@media (max-width: 749px) {
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk.savia-slider {
    position: relative;
    width: 100%;
    height: calc(100vw * 1.25) !important;   /* 4:5 */
    overflow: hidden;
  }

  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-track {
    position: relative;
    width: 100%;
    height: 100%;
  }

  /* Cada slide ocupa todo el alto/alto */
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-slide {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    pointer-events: none;
    transition: opacity .5s ease;
  }
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-slide.is-active {
    opacity: 1;
    pointer-events: auto;
  }

  /* Las imágenes llenan sin deformar */
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk picture,
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk img {
    display: block;
    width: 100%;
    height: 100%;
  }
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk img {
    object-fit: cover !important;
    object-position: center center !important; /* cambiá a 'center 30%' si querés subir un poco el foco */
  }

  /* Puntos (opcional) */
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-dots {
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 2;
  }
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-dots .dot {
    width: 6px; height: 6px; border-radius: 999px;
    background: rgba(255,255,255,.55);
    border: 0;
  }
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk .savia-dots .dot.is-active {
    background: rgba(255,255,255,.95);
  }
}

/* (opcional) en desktop podés reducir la altura para que no sea gigante */
@media (min-width: 750px) {
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk.savia-slider {
    height: 70vh; /* ajustá a gusto o borralo si te da igual desktop */
  }
  #savia-slideshow-template--19806463197333__savia_slideshow_exgALk img {
    object-fit: cover;
  }
}
/* ===== SAVIA · Slideshow full-bleed + mobile 4:5 ===== */

/* Que el slider ignore el contenedor del tema y ocupe todo el ancho de la ventana */
.savia-slider {
  position: relative;
  width: 100vw;
  max-width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);  /* centra el bloque de 100vw dentro del layout */
  overflow: hidden;
  border-radius: 0 !important;
}

/* El tema suele meter rellenos/bordes en wrappers; los anulamos cuando contiene nuestro slider */
section:has(> .savia-slider),
.section:has(.savia-slider),
.section-content-wrapper:has(.savia-slider),
.spacing-style:has(.savia-slider) {
  padding: 0 !important;
  border: 0 !important;
}

/* Mobile: alto fijo 4:5 (1080x1350). Desktop: que cubra igualmente pero sin forzar ratio. */
@media (max-width: 749px) {
  .savia-slider { height: 125vw !important; } /* 4:5 */
  .savia-slider .savia-track,
  .savia-slider .savia-slide,
  .savia-slider picture,
  .savia-slider img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
  .savia-slider img {
    object-fit: cover !important;
    object-position: center center !important; /* cambiá a 'center 30%' si necesitás subir foco */
    border-radius: 0 !important;
  }

  /* Puntos del carrusel (opcional) */
  .savia-slider .savia-dots {
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    display: flex;
    gap: 8px;
    z-index: 2;
  }
  .savia-slider .savia-dots .dot {
    width: 6px; height: 6px; border-radius: 999px;
    background: rgba(255,255,255,.55); border: 0;
  }
  .savia-slider .savia-dots .dot.is-active { background: rgba(255,255,255,.95); }
}

@media (min-width: 750px) {
  .savia-slider img { object-fit: cover; }
  /* Si en desktop lo querés más alto/bajo, podés setear height: 60–80vh aquí */
}
/* ===== SAVIA · Slideshow mobile full-bleed (1080×1350) ===== */
@media (max-width: 749px){
  /* Hace que la sección sangre a 100vw, ignorando el padding del tema */
  .savia-slider{
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
  }

  /* Quita padding, bordes redondeados y sombras que achican el slide */
  .savia-slider .section,
  .savia-slider .banner,
  .savia-slider .slideshow,
  .savia-slider .slideshow__slide,
  .savia-slider .banner__content,
  .savia-slider .banner__media{
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  /* Asegura que la imagen use 100vw y respete 4:5 (1080×1350) sin recortes raros */
  .savia-slider picture,
  .savia-slider img{
    display: block !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: auto !important;
    object-fit: contain !important;     /* no recorta tu composición */
    object-position: center !important;
  }

  /* Ajuste fino por si el tema centra dentro de un contenedor */
  .savia-slider .slideshow__slide,
  .savia-slider .banner__media{
    transform: translateX(0) !important;
  }

  /* Puntos/controles un poco más arriba si quedan pegados al borde */
  .savia-slider .slideshow__controls,
  .savia-slider .slideshow__buttons{
    bottom: 12px !important;
  }
}
/* ===== SAVIA · Slideshow mobile full-bleed (1080×1350) ===== */
@media (max-width: 749px){
  /* Sangrado a 100vw del contenedor del slider */
  .savia-slider{
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    width: 100vw;
  }

  /* Limpieza de padding/bordes/redondeos que achican el slide */
  .savia-slider .section,
  .savia-slider .banner,
  .savia-slider .slideshow,
  .savia-slider .slideshow__slide,
  .savia-slider .banner__content,
  .savia-slider .banner__media{
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  /* Imagen mobile 1080×1350 sin recorte */
  .savia-slider picture,
  .savia-slider img{
    display: block !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: auto !important;
    object-fit: contain !important;      /* NO recorta tu composición */
    object-position: center !important;
  }

  /* Por si el tema mete transforms */
  .savia-slider .slideshow__slide,
  .savia-slider .banner__media{
    transform: translateX(0) !important;
  }

  /* Puntos/controles un poco más arriba */
  .savia-slider .slideshow__controls,
  .savia-slider .slideshow__buttons{
    bottom: 12px !important;
  }
}

/* ===== Fallback si tu sección no tiene la clase .savia-slider ===== */
@media (max-width: 749px){
  .shopify-section:has(.slideshow){
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    width: 100vw !important;
  }
  .shopify-section:has(.slideshow) picture,
  .shopify-section:has(.slideshow) img{
    display:block !important;
    width:100vw !important;
    height:auto !important;
    object-fit: contain !important;
    object-position:center !important;
  }
}
/* Ocultar cualquier icono/enlace de Cuenta en el header */
.header__icon--account,
.header__action--account,
.site-header__account,
a[href*="/account"],
button[aria-label*="Cuenta"],
button[aria-label*="Account"] {
  display: none !important;
}
/* Aumentar tamaño visual y área táctil de menú y búsqueda */
.header__icon--menu,
.header__icon--search,
button[aria-label*="menu"],
button[aria-label*="Menú"],
button[aria-label*="buscar"],
button[aria-label*="Search"] {
  /* área táctil más grande */
  width: 44px !important;
  height: 44px !important;
  padding: 6px !important;
}

/* Escalar el SVG (el dibujito de la hamburguesa y la lupa) */
.header__icon--menu svg,
.header__icon--search svg,
button[aria-label*="menu"] svg,
button[aria-label*="Menú"] svg,
button[aria-label*="buscar"] svg,
button[aria-label*="Search"] svg {
  width: 28px !important;   /* probá 30–32 si querés más grande */
  height: 28px !important;
}

/* Ajustes finos opcionales (separación) */
.header__icon--menu { margin-left: 2px !important; }
.header__icon--search { margin-left: 8px !important; }
/* HEADER: ocultar cualquier variante del ícono/enlace de cuenta */
header .header__icon--account,
header .header__action--account,
header .utility-bar__item--account,
header a[href="/account"],
header a[href="/account/login"],
header a[href*="/account?"],
header a[href*="/account#"],
header [aria-label="Cuenta"],
header [aria-label="Account"],
header .icon-account,
header [data-header-icon="account"] {
  display: none !important;
}
/* Aumentar área táctil y tamaño de los íconos de menú y búsqueda */
header .header__icon--menu,
header button[aria-controls*="menu"],
header .menu-toggle,
header .header__icon--search,
header button[aria-controls*="search"],
header .search-toggle {
  width: 48px !important;
  height: 48px !important;
  padding: 6px !important;      /* más “clickeable” */
}

/* Escalar el SVG (el dibujito) */
header .header__icon--menu svg,
header button[aria-controls*="menu"] svg,
header .menu-toggle svg,
header .header__icon--search svg,
header button[aria-controls*="search"] svg,
header .search-toggle svg {
  width: 28px !important;       /* subí a 30–32 si lo querés aún más grande */
  height: 28px !important;
}
/* Refuerzo: si algún resto de cuenta aparece, desaparecerlo por CSS */
header a[href*="/account"],
header [aria-label="Cuenta"],
header [aria-label="Account"],
header .icon-account { display:none !important; }

/* Agrandar hit-area por CSS (si el JS no pudo) */
header [aria-controls*="menu"],
header .header__icon--menu,
header .menu-toggle,
header [aria-controls*="search"],
header .header__icon--search,
header .search-toggle {
  width:48px !important; height:48px !important; padding:6px !important;
}
header [aria-controls*="menu"] svg,
header .header__icon--menu svg,
header .menu-toggle svg,
header [aria-controls*="search"] svg,
header .header__icon--search svg,
header .search-toggle svg {
  width:28px !important; height:28px !important;
}
/* ===== 1) Ocultar CUALQUIER icono/enlace de CUENTA (header y menú lateral) ===== */
header a[href*="/account"],
header a[href*="account/login"],
header a[href*="account/register"],
header button[aria-label*="Cuenta"],
header button[aria-label*="Account"],
header .icon-account,
header .header__icon--account,
header .header-action--account,
.menu-drawer a[href*="/account"],
.drawer a[href*="/account"] {
  display: none !important;
}

/* Fallback agresivo: si el tema no usa clases claras y el grupo de iconos
   de la derecha tiene [cuenta, carrito], oculta el PRIMERO del grupo derecho */
header .header__icons--right > :first-child { display: none !important; }
/* Otra variante común: */
header .header__icons > a[href*="/account"], 
header .header__icons > button[aria-label*="Cuenta"] { display: none !important; }

/* ===== 2) Agrandar hamburguesa y lupa (área táctil + tamaño del SVG) ===== */
/* Hamburguesa */
header .header__icon--menu,
header .menu-toggle,
header button[aria-label*="Menú"],
header button[aria-label*="Menu"] {
  width: 48px !important;
  height: 48px !important;
  padding: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
header .header__icon--menu svg,
header .menu-toggle svg,
header button[aria-label*="Menú"] svg,
header button[aria-label*="Menu"] svg {
  width: 28px !important;
  height: 28px !important;
}

/* Lupa */
header .header__icon--search,
header .search-toggle,
header button[aria-label*="Buscar"],
header button[aria-label*="Search"] {
  width: 48px !important;
  height: 48px !important;
  padding: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}
header .header__icon--search svg,
header .search-toggle svg,
header button[aria-label*="Buscar"] svg,
header button[aria-label*="Search"] svg {
  width: 28px !important;
  height: 28px !important;
}
/* ==== FIX GLOBAL: cortes, scroll lateral y botón WhatsApp tapando el pie ==== */

/* quita cualquier scroll lateral que quede por secciones full-bleed */
html, body { overflow-x: hidden; }

/* si alguna sección usa 100vw, que nunca se pase del viewport real */
*,
*:before,
*:after { box-sizing: border-box; }

/* Footer SAVIA: asegura ancho correcto y sin desbordes */
.savia-footer,
#shopify-section-footer,
.shopify-section-group-footer-group,
footer,
.footer { 
  max-width: 100%;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  overflow: visible;
}

/* Aire inferior para que el botón flotante (WA) no tape nada */
:root { --savia-chat-bubble: 96px; }              /* tamaño aprox del botón + sombra */
.savia-footer,
#shopify-section-footer,
footer,
.footer { 
  padding-bottom: calc(32px + var(--savia-chat-bubble)) !important;
}

/* En pantallas grandes el botón no molesta: y vuelve el padding normal */
@media (min-width: 1024px){
  :root { --savia-chat-bubble: 0px; }
}

/* Ajuste fino de filas/columns del footer para que no se “rompa” en mobile */
.savia-footer .sf-grid,
.footer .sf-grid,
footer .sf-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
@media (min-width: 740px){
  .savia-footer .sf-grid,
  .footer .sf-grid,
  footer .sf-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (min-width: 1024px){
  .savia-footer .sf-grid,
  .footer .sf-grid,
  footer .sf-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
}

/* Badges IG/TikTok debajo del mail: margen y toque visual */
.savia-footer .social-badges {
  display:flex; flex-wrap:wrap; gap:10px; margin-top:10px;
}
.savia-footer .social-badges a {
  display:inline-grid; grid-auto-flow:column; align-items:center; gap:8px;
  padding:10px 12px; border:1px solid #f0dcd9; border-radius:999px;
  background:#fff; color:#c98f95; text-decoration:none; font-weight:600;
}
.savia-footer .social-badges a:hover { background:#fff3f3; }
.savia-footer .social-badges svg { width:18px; height:18px; }
/* ==== KILL H-OVERFLOW en toda la página (sin romper sombras) ==== */
html, body { width:100%; max-width:100%; overflow-x:hidden; }
.shopify-section, .section, [class*="section"] { overflow-x: clip; }

/* ==== Footer: contenedor saneado (sin márgenes negativos ni 100vw) ==== */
.savia-footer { position:relative; width:100%; overflow-x:hidden; }
.savia-footer * { box-sizing: border-box; }
.savia-footer .wrap { max-width: 1200px; margin-inline:auto; padding-inline:16px; }

/* Separadores y tarjetas del footer: que no empujen nada */
.savia-footer .ft-sep{
  height:1px; background:rgb(0 0 0 / .12); margin:16px 0; border:0;
}
.savia-footer .ft-card{
  border:1px solid rgb(0 0 0 / .10);
  border-radius:14px; background:#fff; padding:12px 14px;
}

/* Grillas del footer 100% seguras */
.savia-footer .ft-grid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media (min-width:768px){ .savia-footer .ft-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (min-width:1024px){ .savia-footer .ft-grid{ grid-template-columns:repeat(3,minmax(0,1fr)); } }

.savia-footer .ft-col{ padding:14px 0; border-top:1px solid rgb(0 0 0 / .06); }
.savia-footer .ft-list{ margin:0; padding:0; list-style:none; display:grid; gap:8px; }

/* Pills (email / IG / TikTok) fluidos y sin desborde */
.savia-footer .ft-contact-row{ display:grid; grid-template-columns:1fr; gap:10px; }
@media (min-width:520px){ .savia-footer .ft-contact-row{ grid-template-columns:1fr 1fr; } }

.savia-footer .pill{
  display:inline-grid; grid-auto-flow:column; align-items:center; gap:8px;
  padding:10px 14px; border-radius:999px; width:100%;
  background:#f6e7e5; border:1px solid rgb(0 0 0 / .10); color:#2b1f1d;
}
.savia-footer .pill svg{ width:18px; height:18px; }
.savia-footer .handle{ text-decoration:underline; text-underline-offset:2px; }
.savia-footer .handle:hover{ opacity:.85; }

/* Newsletter seguro */
.savia-footer .newsletter{ display:grid; grid-template-columns:1fr auto; gap:10px; }
.savia-footer .newsletter input[type="email"]{
  height:44px; border-radius:999px; padding:0 16px;
  background:#f6e7e5; border:1px solid rgb(0 0 0 / .08); width:100%;
}
.savia-footer .newsletter button{
  height:44px; padding:0 18px; border-radius:999px; border:0;
  background:#e2a8a1; color:#fff; font-weight:600;
}

/* Línea legal */
.savia-footer .legal{
  display:flex; flex-wrap:wrap; gap:14px;
  padding:14px 0; border-top:1px solid rgb(0 0 0 / .06);
  color:#756a66; font-size:13px;
}
.savia-footer .legal a{ color:inherit; text-decoration:none; }
.savia-footer .legal a:hover{ text-decoration:underline; }

/* ==== Neutraliza el viejo full-bleed que causa el corte ==== */
/* Si tu hero usa 100vw + márgenes negativos, esto lo vuelve "seguro" */
.savia-ss{
  width:100% !important;
  margin-left:0 !important; margin-right:0 !important;
  left:auto !important; right:auto !important;
}
/* ===== Sticky fixes SAVIA ===== */

/* Altura de header (ajustá si tu header es más alto) */
:root {
  --savia-header-h: 72px;
}

/* 1) Hacer sticky el header (cubre la mayoría de temas Shopify) */
header.header,
.site-header,
.header-wrapper,
#shopify-section-header,
.shopify-section-header {
  position: sticky;
  position: -webkit-sticky; /* iOS Safari */
  top: 0;
  z-index: 9999;
  backface-visibility: hidden;
  will-change: transform;
}

/* 2) Neutralizar los 'sticky breakers' en ancestros */
.shopify-section-header,
.header-wrapper,
#MainContent,
.main-content,
.page-width {
  overflow: visible !important;       /* sticky NO funciona si el padre tiene overflow != visible */
  transform: none !important;         /* cualquier transform en un ancestro rompe sticky */
  contain: paint;                     /* ayuda a Safari a no “despegar” */
}

/* 3) Evitar que el body scrollee dentro de contenedores */
html, body {
  height: auto;       /* evita bugs cuando algún script pone height:100% */
  overflow-x: clip;   /* previene scroll horizontal que afecta el stack de pegado */
}

/* 4) Temporizador/ticker/app contado: fijarlo bajo el header */
.savia-timer,
.countdown,
.countdown-timer,
.app-block-timer,
.savia-ticker {
  position: sticky;
  position: -webkit-sticky;
  top: var(--savia-header-h);
  z-index: 9998;
}

/* 5) Asegurar legibilidad sobre el contenido */
.header-overlay,
.header__shadow {
  pointer-events: none;
}

/* 6) iOS Safari: bug de 'sticky' dentro de contenedores con -webkit-overflow-scrolling */
.scroller,
.scroll-area,
.drawer__inner {
  -webkit-overflow-scrolling: auto !important;
}

/* 7) Evitar que un anuncio superior “empuje” el header fuera de sticky */
.announcement-bar,
#shopify-section-announcement-bar {
  position: sticky;
  position: -webkit-sticky;
  top: 0;
  z-index: 10000; /* por encima del header si la barra va arriba; si no tenés barra, quitá esto */
}
/* ===========================
   SAVIA · Variables de marca
   =========================== */
:root{
  --savia-rose: #EAB2A8;   /* rosa polvo */
  --savia-cream:#EEDDC1;   /* crema */
  --savia-sage: #BFCBA2;   /* salvia */
  --savia-ink:  #555555;   /* texto base */
  --savia-ink-2:#777777;   /* texto secundario */
  --savia-bg:   #fffaf8;   /* fondo cálido */
  --savia-line: #eee;      /* divisores suaves */
  --savia-shadow: 0 1px 0 rgba(0,0,0,.04);
}

/* =========================================
   1) SAVIA · Fit note (talle único ajustable)
   (aplica al HTML existente con .savia-fit-note)
   ========================================= */
.savia-fit-note{
  display:flex; align-items:center; justify-content:center;
  gap:.5rem; padding:.6rem .9rem; margin:.75rem 0 1rem;
  background:var(--savia-bg);
  border:1px solid var(--savia-rose);
  border-radius:999px;
  font-size:.95rem; line-height:1.2; font-weight:600;
  color:var(--savia-ink);
  box-shadow:var(--savia-shadow);
}

.savia-fit-icon{ 
  display:inline-flex; width:18px; height:18px; flex:0 0 18px;
}
.savia-fit-icon svg path[fill] { fill: var(--savia-sage); }
.savia-fit-icon svg path[stroke] { stroke: var(--savia-sage); }

.savia-fit-text{ letter-spacing:.2px; }
.savia-fit-text strong{ color:#333; }

/* Responsive */
@media (min-width:768px){
  .savia-fit-note{ font-size:1rem; padding:.7rem 1rem; }
}

/* Estado opcional (si querés resaltar al tocar) */
.savia-fit-note:active{ transform:translateY(1px); }

/* =========================================
   2) SAVIA · Acordeón de dudas rápidas
   (aplica al HTML existente con .savia-accordion)
   ========================================= */
.savia-accordion{ margin-top:1rem; }
.savia-accordion .savia-eyebrow{
  font-size:.9rem; text-transform:uppercase; letter-spacing:.06em;
  color:#333; margin-bottom:.25rem;
}

/* Cada item */
.savia-accordion details{
  border-bottom:1px solid var(--savia-line);
  padding:.6rem 0;
}

/* Cabecera */
.savia-accordion summary{
  display:flex; justify-content:space-between; align-items:center;
  gap:1rem; list-style:none; cursor:pointer; user-select:none;
  padding:.2rem 0;
  font-weight:600; color:#333;
}
.savia-accordion summary::-webkit-details-marker{ display:none; }

/* Icono flecha */
.savia-accordion summary svg{
  width:20px; height:20px; flex:0 0 20px;
  transition:transform .2s ease;
  color:#333;
}
.savia-accordion details[open] summary svg{
  transform:rotate(180deg);
}

/* Contenido */
.savia-accordion .content{
  padding:.4rem 0 .8rem;
  color:var(--savia-ink);
  font-size:.98rem; line-height:1.5;
}
.savia-accordion .content ul{ padding-left:1.1rem; margin:0; }
.savia-accordion .content li{ margin:.25rem 0; }
.savia-accordion .note{ margin-top:.3rem; color:var(--savia-ink-2); font-size:.92rem; }
.savia-accordion .link{ color:var(--savia-rose); text-decoration:underline; }

/* Hover/Focus accesibles */
.savia-accordion summary:focus-visible{
  outline:2px solid var(--savia-sage);
  outline-offset:2px;
}
.savia-accordion summary:hover{ color:#222; }

/* Espaciado en desktop */
@media (min-width:768px){
  .savia-accordion .content{ font-size:1rem; }
}
/* =========================
   A) ESPACIOS ENTRE BLOQUES
   ========================= */

/* Compacta la banda "TALLE ÚNICO..." */
.savia-fit-note{
  margin: .5rem 0 .6rem !important;   /* antes era más grande */
}

/* Si el siguiente bloque es una píldora/aviso (baja disponibilidad),
   reducimos el margen superior del siguiente elemento */
.savia-fit-note + *{
  margin-top: .6rem !important;
}

/* Si el bloque anterior (beneficios) deja mucho espacio,
   bajamos su margin-bottom sin tocar HTML (clases típicas) */
.feature-grid, .benefits, .savia-benefits, .product__blocks .grid{
  margin-bottom: .75rem !important;
}

/* En pantallas chicas, todo aún más compacto */
@media (max-width: 480px){
  .savia-fit-note{ margin: .45rem 0 .5rem !important; }
  .savia-fit-note + *{ margin-top: .5rem !important; }
}

/* ======================================
   B) ACORDEÓN · TARJETAS CON PADDING REAL
   ====================================== */

/* Contenedor del acordeón un poco más cerca del título/sección */
.savia-accordion{ margin-top: .75rem !important; }
.savia-accordion .savia-eyebrow{ margin-bottom: .5rem !important; }

/* Cada ítem del acordeón = tarjeta con borde redondeado y padding interno */
.savia-accordion details{
  /* quitamos el borde inferior si lo hubiera de estilos anteriores */
  border-bottom: none !important;

  border: 1px solid #F3D8D2;      /* rosa muy suave (combina con SAVIA) */
  border-radius: 14px;
  background: #fff;
  padding: .55rem .9rem;           /* <- PADDING INTERNO REAL */
  margin: .6rem 0;                 /* separa las tarjetas entre sí */
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
}

/* Cabecera del acordeón con buen área clickeable */
.savia-accordion summary{
  padding: .15rem 0;               /* ya hay padding externo del <details> */
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem; cursor: pointer; list-style: none; user-select: none;
}

/* Oculta el marcador por defecto y ajusta flecha */
.savia-accordion summary::-webkit-details-marker{ display: none; }
.savia-accordion summary svg{
  width: 20px; height: 20px; flex: 0 0 20px; transition: transform .2s ease;
}
.savia-accordion details[open] summary svg{ transform: rotate(180deg); }

/* Contenido con aire suficiente */
.savia-accordion .content{
  padding: .4rem 0 .2rem;  /* ya hay padding externo del <details> */
  font-size: .98rem; line-height: 1.5; color: #555;
}
.savia-accordion .content ul{ padding-left: 1.1rem; margin: 0; }
.savia-accordion .content li{ margin: .25rem 0; }

/* Desktop levemente más holgado */
@media (min-width: 768px){
  .savia-accordion details{ padding: .65rem 1rem; margin: .65rem 0; }
  .savia-accordion .content{ font-size: 1rem; }
}
