/** Shopify CDN: Minification failed

Line 4402:0 Unexpected "<"
Line 4611:12 Expected identifier but found whitespace
Line 4611:20 Unexpected "!"
Line 5286:1 Expected "}" to go with "{"

**/
* {
  box-sizing: border-box;
}

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

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

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

html[scroll-lock] {
  overflow: hidden;
}
/* --- CONTROL DE ANCHO GLOBAL --- */
:root {
  --overflow-x: hidden;
}

html {
  overflow-x: hidden;
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
}

body {
  overflow-x: hidden;
  width: 100%;
  position: relative; /* Ayuda a contener elementos con position: absolute */
  margin: 0;
  -webkit-overflow-scrolling: touch; /* Suaviza el scroll en iPhone */
}

/* Evita que secciones de Shopify saquen "codos" hacia afuera */
.shopify-section {
  max-width: 100vw !important;
  overflow: hidden;
}
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

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

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

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

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

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

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

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

  text-align: left;
}

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

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

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

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

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

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

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

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

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

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

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

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

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

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

.relative {
  position: relative;
}

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

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

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

.icon-default {
  fill: currentColor;
}

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

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

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

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

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

/* Typography presets */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    footer {
      view-transition-name: footer;
    }

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

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

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

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

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

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

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

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

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

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

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

.text-block {
  width: 100%;
}

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

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

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

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

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

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

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

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

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

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

  &::backdrop {
    opacity: 0;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

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

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

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

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

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

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

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

/* Collapsible row */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[open] {
    opacity: 1;
  }

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

  &::backdrop {
    background: transparent;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.card-gallery {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.cart-bubble__text {
  font-size: var(--font-size--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 {
  --offset-y: 10px;

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

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

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

  animation-duration: 0.6s;
}

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

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

  animation-duration: 0.8s;
}

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

  5% {
    opacity: 1;
  }

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

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

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

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

@keyframes 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;
  --slide-offset: 6px;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

  50% {
    opacity: 1;
  }

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}
/* Solo aplica en pantallas grandes (Desktop) */
@media screen and (min-width: 990px) {
  
  #shopify-section-template--20622534279413__section_DBCig9 {
    /* 1. ESPACIOS ENTRE COLUMNAS Y VERTICALES */
    /* Ajustamos el padding de la sección para que no ocupe tanto alto */
    padding-top: 20px !important;
    padding-bottom: 80px !important;
  }

  #shopify-section-template--20622534279413__section_DBCig9 .grid, 
  #shopify-section-template--20622534279413__section_DBCig9 .flex { 
    /* Si usa CSS Grid o Flex, controlamos el aire entre columnas */
    gap: 16px !important; 
  }

  /* 2. TAMAÑO DE TEXTOS (Títulos y Párrafos) */
  #shopify-section-template--20622534279413__section_DBCig9Í h1, 
  #shopify-section-template--20622534279413__section_DBCig9 .h1,
  #shopify-section-template--20622534279413__section_DBCig9 h2 {
    /* Usamos clamp para que sea fluido pero con un tope máximo */
    font-size: clamp(32px, 30vw, 48px) !important;
    line-height: 1.1 !important;
    margin-bottom: 15px !important;
  }

  #shopify-section-template--20622534279413__section_DBCig9 p, 
  #shopify-section-template--20622534279413__section_DBCig9 .rte {
    font-size: 42px !important; /* Evita el texto gigante de Horizon */
    line-height: 1.6 !important;
    max-width: 800px; /* Evita que las líneas de texto sean infinitas */
    margin-left: auto;
    margin-right: auto;
  }

  /* 3. TAMAÑO DE IMAGEN */
  #shopify-section-template--20622534279413__section_DBCig9 img {
    /* Controlamos que la imagen no se desparrame */
    max-width: 450px !important; /* Ajusta este valor a tu gusto */
    height: auto !important;
    display: block;
    margin: 0 auto; /* Centra la imagen si es necesario */
  }
}
/* Solo aplica en pantallas grandes (Desktop) */
@media screen and (min-width: 990px) {
  
  #shopify-section-template--20622534279413__section_JrDQ4C {
    /* 1. ESPACIOS ENTRE COLUMNAS Y VERTICALES */
    /* Ajustamos el padding de la sección para que no ocupe tanto alto */
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  #shopify-section-template--20622534279413__section_JrDQ4C .grid, 
  #shopify-section-template--20622534279413__section_JrDQ4C .flex { 
    /* Si usa CSS Grid o Flex, controlamos el aire entre columnas */
    gap: 16px !important; 
  }

  /* 2. TAMAÑO DE TEXTOS (Títulos y Párrafos) */
  #shopify-section-template--20622534279413__section_JrDQ4C h1, 
  #shopify-section-template--20622534279413__section_JrDQ4C .h1,
  #shopify-section-template--20622534279413__section_JrDQ4C h2 {
    /* Usamos clamp para que sea fluido pero con un tope máximo */
    font-size: clamp(32px, 30vw, 48px) !important;
    line-height: 1.1 !important;
    margin-bottom: 15px !important;
  }

  #shopify-section-template--20622534279413__section_JrDQ4C p, 
  #shopify-section-template--20622534279413__section_JrDQ4C .rte {
    font-size: 28px !important; /* Evita el texto gigante de Horizon */
    line-height: 1.6 !important;
    max-width: 800px; /* Evita que las líneas de texto sean infinitas */
    margin-left: auto;
    margin-right: auto;
  }

  /* 3. TAMAÑO DE IMAGEN */
  #shopify-section-template--20622534279413__section_JrDQ4C img {
    /* Controlamos que la imagen no se desparrame */
    max-width: 450px !important; /* Ajusta este valor a tu gusto */
    height: auto !important;
    display: block;
    margin: 0 auto; /* Centra la imagen si es necesario */
  }
}
/* Solo aplica en pantallas grandes (Desktop) */
@media screen and (min-width: 990px) {
  
  #shopify-section-template--20622534279413__section_cqXmjw {
    /* 1. ESPACIOS ENTRE COLUMNAS Y VERTICALES */
    /* Ajustamos el padding de la sección para que no ocupe tanto alto */
    padding-top: 40px !important;
    padding-bottom: 0px !important;
  }

  #shopify-section-template--20622534279413__section_cqXmjw .grid, 
  #shopify-section-template--20622534279413__section_cqXmjw .flex { 
    /* Si usa CSS Grid o Flex, controlamos el aire entre columnas */
    gap: 16px !important; 
  }

  /* 2. TAMAÑO DE TEXTOS (Títulos y Párrafos) */
  #shopify-section-template--20622534279413__section_cqXmjw h1, 
  #shopify-section-template--20622534279413__section_cqXmjw .h1,
  #shopify-section-template--20622534279413__section_cqXmjw h2 {
    /* Usamos clamp para que sea fluido pero con un tope máximo */
    font-size: clamp(32px, 30vw, 48px) !important;
    line-height: 1.1 !important;
    margin-bottom: 40px !important;
  }

  #shopify-section-template--20622534279413__section_cqXmjw p, 
  #shopify-section-template--20622534279413__section_cqXmjw .rte {
    font-size: 24px !important; /* Evita el texto gigante de Horizon */
    line-height: 1.6 !important;
    max-width: 800px; /* Evita que las líneas de texto sean infinitas */
    margin-left: auto;
    margin-right: auto;
  }

  /* 3. TAMAÑO DE IMAGEN */
  #shopify-section-template--20622534279413__section_cqXmjw img {
    /* Controlamos que la imagen no se desparrame */
    max-width: 450px !important; /* Ajusta este valor a tu gusto */
    height: auto !important;
    display: block;
    margin: 0 auto; /* Centra la imagen si es necesario */
  }
}
/* Sección Importador Oficial - Estilizado y Grande (Desktop) */
@media screen and (min-width: 990px) {
  
  #shopify-section-template--20622534279413__section_cqXmjw {
    /* 1. ESPACIOS ENTRE COLUMNAS Y VERTICALES */
    /* Ajustamos el padding de la sección para que no ocupe tanto alto */
    padding-top: 40px !important;
    padding-bottom: 0px !important;
  }

  /* 2. EL RECUADRO BLANCO: Más ancho y estilizado */
  #shopify-section-template--20622534279413__section_RdwKex .group-block {
    width: 80% !important; /* Ocupa el 80% del ancho de la sección */
    max-width: 1000px !important;
    background-color: #ffffff !important;
    border-radius: 15px !important; /* Bordes redondeados sutiles */
    box-shadow: 0 10px 30px rgba(0,0,0,0.05) !important; /* Sombra elegante */
    padding: 30px !important; /* Espacio interno para que el texto respire */
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  /* 3. TEXTOS: Más grandes y con mejor lectura */
  /* Título (Importador Oficial) */
  #shopify-section-template--20622534279413__section_RdwKex .text-block--ANUFaclRraUdobmNHL__text_97TU4j p {
    font-size: 2.8rem !important;
    font-weight: 700 !important;
    margin-bottom: 0px !important;
  }

  /* Items (Original, Trazabilidad, etc.) */
  #shopify-section-template--20622534279413__section_RdwKex .text-block p {
    font-size: 1.3rem !important;
    line-height: 1.6 !important;
  }

  /* 4. LOGO ANMAT: Más presencia */
  #shopify-section-template--20622534279413__section_RdwKex .icon-block-ASTVwT0k4S1E2NGdNQ__icon_Wgdy9c {
    width: 140px !important; /* Logo más grande */
    margin-top: 30px !important;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
  }

  /* 5. Limpieza de overlays que opacan la imagen */
  #shopify-section-template--20622534279413__section_RdwKex .overlay {
    display: none !important;
  }
}
/* SOLO DESKTOP: Sección Hero NAD (QtjNea) */
@media screen and (min-width: 990px) {

  /* 1. Forzar altura y posición del contenedor de texto */
  #shopify-section-template--20622534279413__section_QtjNea div.group-block-content {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 500px !important;
    padding: 5% !important;
  }

  /* 2. TÍTULO GIGANTE */
  #shopify-section-template--20622534279413__section_QtjNea .text-block--AUHVZcG1VM2NjQUJRK__text_tgeEf8 p {
    font-size: 3.5rem !important;
    line-height: 1 !important;
    font-weight: 600 !important;
    margin-bottom: 20px !important;
    display: block !important;
  }

  /* 3. SUBTÍTULO (Energía celular...) */
  #shopify-section-template--20622534279413__section_QtjNea .text-block--AVUlrcm45dW1GcTdkZ__text_nUJGbz p {
    font-size: 1.6rem !important;
    font-weight: 500 !important;
    margin-bottom: 20px !important;
  }

  /* 4. TEXTO CIENTÍFICOS NOBEL */
  #shopify-section-template--20622534279413__section_AaUhIL3F2a0hBSkFOV__text_YUY73q p {
    font-size: 2.4rem !important;
    color: #002d5a !important;
    margin-top: 15px !important;
  }

  /* 5. EL TRUCO DE "SEGÚN AMAZON" (Abajo a la derecha) */
  #shopify-section-template--20622534279413__section_QtjNea .text-block--ATm9HMTJNN3kwZStQe__text_PjqeLY {
    position: absolute !important;
    bottom: 10px !important;
    right: 20px !important;
    width: auto !important;
    margin: 0 !important;
    transform: none !important;
    z-index: 5 !important;
  }

  #shopify-section-template--20622534279413__section_QtjNea .text-block--ATm9HMTJNN3kwZStQe__text_PjqeLY p {
    font-size: 0.75rem !important;
    text-align: right !important;
    color: #777 !important;
  }

  /* 6. BOTÓN MÁS GRANDE */
  #shopify-section-template--20622534279413__section_QtjNea a.button {
    font-size: 1.3rem !important;
    padding: 14px 30px !important;
    min-width: 150px !important;
  }
}
/* FONDO PANTALLA COMPLETA - TEXTOS E IMAGEN ORIGINALES */
@media screen and (min-width: 990px) {

  /* 1. Forzamos la altura de la sección al 100% de la pantalla */
  #shopify-section-template--20622534279413__section_QtjNea,
  #shopify-section-template--20622534279413__section_QtjNea .section,
  #shopify-section-template--20622534279413__section_QtjNea .section-background,
  #shopify-section-template--20622534279413__section_QtjNea .custom-section-content {
    height: 100vh !important;
    min-height: 100vh !important;
    display: flex !important;
    align-items: center !important; /* Centra el contenido verticalmente */
    justify-content: center !important; /* Centra el contenido horizontalmente */
    margin: 0 !important;
    padding: 0 !important;
  }

  /* 2. Mantenemos el tamaño de la imagen y el bloque de texto originales */
  #shopify-section-template--20622534279413__section_QtjNea .section-content-wrapper {
    height: auto !important; /* No se estira, se adapta a su contenido */
    max-width: 1200px !important; /* O el ancho que prefieras para que no se pegue a los bordes */
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
  }

  /* 3. Aseguramos que la imagen no crezca */
  #shopify-section-template--20622534279413__section_QtjNea .image-block {
    flex: 0 0 auto !important;
    width: 46% !important; /* Respetamos el 46% que tiene tu código original */
  }

  /* 4. Ajuste del bloque de texto y posición de Amazon */
  #shopify-section-template--20622534279413__section_QtjNea .group-block-content {
    position: relative !important;
    flex: 1 !important;
  }

  /* 5. Posicionamos "Según Amazon" abajo a la derecha de la sección completa */
  #shopify-section-template--20622534279413__section_QtjNea .text-block--ATm9HMTJNN3kwZStQe__text_PjqeLY {
    position: absolute !important;
    bottom: 40px !important;
    right: 40px !important;
    width: auto !important;
  }
}
/* Sección Medios Internacionales - Imagen Ancho Completo */
@media screen and (min-width: 990px) {
  
  /* 1. Eliminamos márgenes de la sección para que sea total */
  #shopify-section-template--20622534279413__section_BVmxiJ .section {
    max-width: 100% !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  /* 2. Texto "Destacado por..." - Lo mantenemos chico y centrado */
  #shopify-section-template--20622534279413__section_BVmxiJ .text-block--Ac3M0akJrajZVSG9CQ__text_AVwMHE {
    padding-top: 20px !important;
    padding-bottom: 10px !important;
  }

  #shopify-section-template--20622534279413__section_BVmxiJ .text-block--Ac3M0akJrajZVSG9CQ__text_AVwMHE p {
    font-size: 0.75rem !important; /* Tamaño pequeño solicitado */
    letter-spacing: 1px;
    opacity: 0.8;
  }

  /* 3. IMAGEN ANCHO COMPLETO */
  #shopify-section-template--20622534279413__section_BVmxiJ .image-block {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
  }

  #shopify-section-template--20622534279413__section_BVmxiJ .image-block img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    object-fit: cover !important; /* Asegura que llene el ancho */
  }

  /* 4. Quitamos espacios innecesarios */
  #shopify-section-template--20622534279413__section_BVmxiJ .section-content-wrapper {
    padding: 0 !important;
    gap: 0 !important;
  }
}
<style>
  /* 1. AJUSTES GENERALES Y MOBILE (Base) */
  #section-template--20622534279413__multies_estadisticas2_iBzg9Q {
    background-color: #ffffff;
    padding-top: 40px;
    padding-bottom: 35px;
    font-family: Assistant, sans-serif;
  }
  
  #section-template--20622534279413__multies_estadisticas2_iBzg9Q .multi-column__heading {
    font-family: Inter, sans-serif;
    font-weight: 500;
    color: #16276f;
    font-size: 19.6px;
    text-align: center; /* Mobile centrado */
    margin-bottom: 10px;
    line-height: 1.2;
    margin-top: 0;
  }

  .grid-template--20622534279413__multies_estadisticas2_iBzg9Q {
    display: flex;
    flex-wrap: wrap;
    justify-content: left !important;
    gap: 15px; 
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
  }

  .item-template--20622534279413__multies_estadisticas2_iBzg9Q {
    flex: 1 1 calc(50% - 15px); /* 2 por fila en mobile */
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: left
    min-height: 80px;
    padding: 15px;
    background-color: #f2f4f8;
    border: 1px solid #eeeeee;
    border-radius: 8px;
    box-sizing: border-box;
  }

  /* 2. AJUSTES EXCLUSIVOS DESKTOP */
  @media screen and (min-width: 990px) {
    /* Alineación a la izquierda del encabezado */
    #section-template--20622534279413__multies_estadisticas2_iBzg9Q .header-wrapper-custom {
      text-align: left !important;
      max-width: 1400px;
      margin: 0 auto 30px auto;
      padding: 0 20px;
    }

    #section-template--20622534279413__multies_estadisticas2_iBzg9Q .multi-column__heading {
      text-align: left !important;
      font-size: 32px;
    }

    #section-template--20622534279413__multies_estadisticas2_iBzg9Q .rte-header {
      text-align: left !important;
    }

    /* Estadísticas ocupando todo el ancho equitativamente */
    .item-template--20622534279413__multies_estadisticas2_iBzg9Q {
      flex: 1 !important; /* Esto hace que todas midan exactamente lo mismo */
      min-height: 120px;
      padding: 25px;
    }
  }

  /* Estilos de texto */
  .num-template--20622534279413__multies_estadisticas2_iBzg9Q {
    font-family: Inter, sans-serif;
    color: #1d3686;
    font-size: 30px;
    font-weight: 600;
    margin: 0 0 5px 0;
    line-height: 1;
  }

  .txt-template--20622534279413__multies_estadisticas2_iBzg9Q {
    color: #333333;
    font-size: 13px;
    line-height: 1.4;
  }
/* ELIMINAR CENTRADO INLINE - SECCIÓN ESTADÍSTICAS */
@media screen and (min-width: 990px) {

  /* 1. Atacamos el div que tiene el estilo "text-align: center" manual */
  #section-template--20622534279413__multies_estadisticas2_iBzg9Q div[style*="text-align: center"] {
    text-align: left !important;
    padding-left: 0 !important;
    margin-left: 3% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  /* 2. Forzamos al subtítulo y su párrafo */
  #section-template--20622534279413__multies_estadisticas2_iBzg9Q .rte-header,
  #section-template--20622534279413__multies_estadisticas2_iBzg9Q .rte-header p {
    text-align: left !important;
    margin-left: 0 !important;
    width: 100% !important;
  }

  /* 3. Aseguramos que el contenedor que creamos (header-wrapper-custom) también mande a la izquierda */
  .header-wrapper-custom {
    text-align: left !important;
    align-items: flex-start !important;
    display: flex !important;
    flex-direction: column !important;
  }
}
/* AJUSTE DE AIRE EN TARJETAS ESTADÍSTICAS - DESKTOP */
@media screen and (min-width: 990px) {

  /* 1. Aumentamos el espacio ENTRE las tarjetas (Gap) */
  .grid-template--20622534279413__multies_estadisticas2_iBzg9Q {
    gap: 30px !important; /* Antes era 10px o 15px */
    padding: 0 40px !important; /* Más aire a los costados de toda la sección */
  }

  /* 2. Aumentamos el aire INTERNO de cada tarjeta (Bordes internos) */
  .item-template--20622534279413__multies_estadisticas2_iBzg9Q {
    padding: 35px 30px !important; /* Más espacio arriba/abajo y a los lados */
    border-radius: 12px !important; /* Bordes un poco más suaves para acompañar el aire */
    flex: 1 !important; /* Mantenemos que todas midan lo mismo */
  }

  /* 3. Un poco más de aire entre el número y el texto */
  .num-template--20622534279413__multies_estadisticas2_iBzg9Q {
    margin-bottom: 15px !important;
  }
}
/* SECCIÓN MARQUEE (LOGOS) - 15% MÁS DE ALTURA EN DESKTOP */
@media screen and (min-width: 990px) {

  /* 1. Forzamos el espacio arriba y abajo del carrusel */
  #shopify-section-template--20622534279413__marquee_F9KV6K marquee-component {
    padding-top: 4vh !important;    /* Mitad del 7% arriba */
    padding-bottom: 4vh !important; /* Mitad del 7% abajo */
    display: flex !important;
    align-items: center !important;
    min-height: auto !important;
  }

  /* 2. Aseguramos que el contenedor interno no limite la altura */
  #shopify-section-template--20622534279413__marquee_F9KV6K .marquee__wrapper {
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
  }

  /* 3. Si quieres que los logos también se vean un poco más grandes con el nuevo aire */
  #shopify-section-template--20622534279413__marquee_F9KV6K .icon-block__media {
    width: 130px !important; /* Ajuste opcional de tamaño de logo */
    max-height: 50px !important;
    object-fit: contain !important;
  }
}
/* SOLUCIÓN DEFINITIVA PARA QUE NO SE FRENE LA MARQUESINA (base.css) */

/* 1. Bloqueamos que la marquesina detecte el mouse */
#shopify-section-template--20622534279413__marquee_F9KV6K marquee-component {
  pointer-events: none !important;
}

/* 2. Forzamos que la animación siga corriendo pase lo que pase */
#shopify-section-template--20622534279413__marquee_F9KV6K .marquee__content,
#shopify-section-template--20622534279413__marquee_F9KV6K .marquee__wrapper {
  animation-play-state: running !important;
  -webkit-animation-play-state: running !important;
}

/* 3. Aseguramos que la altura extra (15%) se mantenga en Desktop */
@media screen and (min-width: 990px) {
  #shopify-section-template--20622534279413__marquee_F9KV6K marquee-component {
    padding-top: 30px !important;    /* Ajuste de altura */
    padding-bottom: 30px !important; /* Ajuste de altura */
    display: block !important;
  }
}
      /* AGRANDAR TEXTO SECCIÓN AMAZON (tBYthG) - DESKTOP */
@media screen and (min-width: 990px) {
  
  /* Atacamos los párrafos de ambos bloques de texto en esta sección */
  #shopify-section-template--20622534279413__section_tBYthG .text-block p {
    font-size: 1.5rem !important; /* Ajusta este valor (1.8rem o 22px) si quieres más tamaño */
    font-weight: 500 !important;   /* Le da un poco más de cuerpo al texto */
    line-height: 1.2 !important;
    margin-top: 5px !important;
  }

  /* Si quieres que la imagen de las estrellas también crezca un poco para acompañar */
  #shopify-section-template--20622534279413__section_tBYthG .image-block {
    --size-style-width: 300px !important; /* Aumenta el ancho de las estrellas */
  }

  /* Ajustamos el contenedor para que el texto grande no se amontone */
  #shopify-section-template--20622534279413__section_tBYthG .group-block-content {
    --gap: 10px !important;
  }
}
/* EVITAR HUÉRFANAS EN TODO EL SITIO */

  
  /* Opción enfocada específicamente en evitar la última palabra suelta */
  text-wrap: pretty !important;
}

/* Ajuste específico para Desktop para asegurar bloques limpios */
@media screen and (min-width: 990px) {
  p, .rte p {
    hyphens: none !important; /* Evita que corte palabras con guiones, lo cual genera huérfanas */
  }
}
/* REDUCIR ALTURA CARRUSEL (kdWYxx) - 25% MENOS EN DESKTOP */
@media screen and (min-width: 990px) {

  /* 1. Reducimos el aire arriba y abajo de la sección */
  #shopify-section-template--20622534279413__carousel_kdWYxx .section-carousel {
    padding-top: 30px !important;
    padding-bottom: 30px !important;
  }

  /* 2. Reducimos el tamaño de las imágenes un 25% */
  #shopify-section-template--20622534279413__carousel_kdWYxx .image-block {
    max-width: 75% !important; /* Aquí aplicamos la reducción directa */
    margin-left: auto !important;
    margin-right: auto !important;
  }

  /* 3. Ajustamos el ratio de la imagen para que no ocupe tanto espacio vertical */
  #shopify-section-template--20622534279413__carousel_kdWYxx .image-block__image {
    max-height: 250px !important; /* Limitamos la altura máxima del icono */
    object-fit: contain !important;
  }

  /* 4. Compactamos los textos para ahorrar espacio vertical */
  #shopify-section-template--20622534279413__carousel_kdWYxx .text-block h5,
  #shopify-section-template--20622534279413__carousel_kdWYxx .h5 p {
    font-size: 1.1rem !important;
    margin-top: 10px !important;
    margin-bottom: 5px !important;
  }

  #shopify-section-template--20622534279413__carousel_kdWYxx rte-formatter p {
    font-size: 0.9rem !important;
    line-height: 1.3 !important;
  }

  /* 5. Reducimos el espacio entre la fila de arriba (título) y el carrusel */
  #shopify-section-template--20622534279413__carousel_kdWYxx .group-block {
    --padding-block-end: 8px !important;
  }
}
/* CENTRADO POR COMPENSACIÓN (iQDd8P) */
@media screen and (min-width: 990px) {
  
  /* Seleccionamos el contenedor que envuelve a los dos bloques */
  #shopify-section-template--20622534279413__section_iQDd8P .section-content-wrapper {
    display: flex !important;
    justify-content: center !important;
    width: 100% !important;
    max-width: 100vw !important;
    /* Ajustamos el margen lateral para equilibrar el peso visual */
    padding-left: 10% !important; 
    padding-right: 5% !important;
    box-sizing: border-box !important;
  }

  /* El truco: forzamos que el conjunto no se pegue a la izquierda */
  #shopify-section-template--20622534279413__section_iQDd8P .group-block:first-child {
    margin-left: auto !important;
  }

  #shopify-section-template--20622534279413__section_iQDd8P .group-block:last-child {
    margin-right: auto !important;
  }
}
/* AGRANDAR TEXTO CABECERA (3PzKFz) EN DESKTOP */
@media screen and (min-width: 990px) {
  
  /* Apuntamos específicamente al bloque de texto de esta sección */
  #shopify-section-template--20622534279413__section_3PzKFz .text-block--ASVdMTzZnZG03TGVOT__text_hgfxh8 {
    --font-size: 1.75rem !important; /* Aumentado de 0.875rem a 1.25rem */
    font-size: 1.25rem !important;
    letter-spacing: 0.02em !important;
  }
/* Ajustamos el margen inferior para que no quede pegado a los logos al crecer */
  #shopify-section-template--20622534279413__section_3PzKFz .text-block--ASVdMTzZnZG03TGVOT__text_hgfxh8 p {
    margin-bottom: 10px !important;
  }
}
/* 1. Forzamos a que todas las cajas ocupen el 100% del ancho disponible */
#shopify-section-template--20622534279413__carousel_DJfgLq .group-block,
#shopify-section-template--20622534279413__carousel_DJfgLq .group-block-content,
#shopify-section-template--20622534279413__carousel_DJfgLq .spacing-style {
  width: 100% !important;
  max-width: 100% !important;
  --size-style-width: 100% !important;
  --size-style-width-mobile: 100% !important;
  --width: 100% !important;
}

/* 2. Forzamos a que el contenido se estire para llenar la altura de la imagen */
#shopify-section-template--20622534279413__carousel_DJfgLq .card__inner {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}

#shopify-section-template--20622534279413__carousel_DJfgLq .group-block-content {
  flex-grow: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important; /* Centra el texto en el alto de la imagen */
  align-items: center !important;
  min-height: 100% !important;
}

/* 3. Evitamos palabras huérfanas en el texto (tu petición guardada) */
#shopify-section-template--20622534279413__carousel_DJfgLq p, 
#shopify-section-template--20622534279413__carousel_DJfgLq .text-block {
  text-wrap: balance !important; /* Distribuye el texto para evitar palabras solas */
  width: 100% !important;
}

/* 4. Aseguramos que la imagen de fondo cubra todo el espacio estirado */
#shopify-section-template--20622534279413__carousel_DJfgLq .background-image-container img {
  object-fit: cover !important;
  height: 100% !important;
  width: 100% !important;
}
/* Reducción y centrado de la sección de logos científicos */
#shopify-section-template--20622534279413__section_3PzKFz {
    display: flex;
    justify-content: center;
    width: 100%;
    overflow: hidden;
}

#shopify-section-template--20622534279413__section_3PzKFz .section-content-wrapper {
    transform: scale(0.7); /* Reduce el tamaño un 30% */
    transform-origin: center center;
    width: 100% !important;
    max-width: 1200px; /* Ajusta según el ancho de tu web */
    margin: 0 auto !important;
}

/* Ajuste para móviles para que no se vea minúsculo */
@media screen and (max-width: 749px) {
    #shopify-section-template--20622534279413__section_3PzKFz .section-content-wrapper {
        transform: scale(0.85); /* En móvil solo reducimos un 15% para que sea legible */
        margin-top: -20px; /* Compensa el espacio que deja el escalado */
        margin-bottom: -20px;
    }
}
/* --- TAREA 1: SECCIÓN LOGOS CIENTÍFICOS (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {
  #shopify-section-template--20622534279413__section_3PzKFz .section-content-wrapper {
    /* Reducción del 30% (Escala 0.7) */
    transform: scale(0.8);
    
    /* Asegura que el centro de la sección sea el punto de referencia */
    transform-origin: center center;
    
    /* Centrado horizontal en la web */
    margin: 0 auto !important;
    width: 100% !important;
    
    /* Forzar que los elementos internos respeten el centro */
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  /* Compensación de espacio para que no quede mucho aire arriba/abajo por el achique */
  #shopify-section-template--20622534279413__section_3PzKFz {
    margin-top: -50px;
    margin-bottom: -50px;
  }
}
/* --- TAREA 2: SECCIÓN AMAZON REVIEWS (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {
  #shopify-section-template--20622534279413__section_tBYthG .section-content-wrapper {
    /* Reducción del 30% */
    transform: scale(0.7);
    
    /* Centrado absoluto */
    transform-origin: center center;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100% !important;
    
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }

  /* Ajuste para que el fondo de la sección no se corte o deje mucho espacio */
  #shopify-section-template--20622534279413__section_tBYthG {
    overflow: hidden;
  }
}
/* --- TAREA 3: SECCIÓN REPORTES USUARIOS (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {
  
  #shopify-section-template--20622534279413__section_iWQ3nL .section-content-wrapper {
    transform: scale(0.7);
    transform-origin: center top;
    margin: 0 auto !important;
    width: 100% !important;
  }
  /* --- CORRECCIÓN DE SOLAPAMIENTO (OVERLAP) --- */
@media screen and (min-width: 990px) {

  /* Sección de Reportes (la que escala) */
  #shopify-section-template--20622534279413__section_iWQ3nL {
    /* Reducimos el margen negativo para que no pise a la siguiente */
    margin-bottom: -300px !important; 
    position: relative;
    z-index: 1; /* La mantenemos en un nivel base */
  }

  /* Sección del Carrusel (la que está siendo tapada) */
  #shopify-section-template--20622534279413__carousel_DJfgLq {
    position: relative;
    z-index: 10; /* Le damos prioridad visual para que nada la tape */
    margin-top: -200 !important;
    padding-top: 50px !important; /* Añadimos un poco de aire superior */
  }
}

  /* Ajuste de los textos de las imágenes para que se lean bien */
  .text-block--AY3ZMVzlpOWljYmFQM__text_UnJxWg p, 
  .text-block--AQ2JJZU9ZT2VIK24vY__text_gXnLRe p, 
  .text-block--AdlBDTEVDak8wUzlNT__text_zJHPNw p {
    font-size: 28px !important;
    line-height: 1.1 !important;
  }

  /* Texto legal compacto */
  #shopify-section-template--20622534279413__section_iWQ3nL .text-block--AQVJRaHp3L3Z2d0NwR__text_X6i6ee p {
    font-size: 20px !important;
    line-height: 1.1 !important;
  }
}
/* --- IGUALAR ALTURA DE TARJETAS EN CARRUSEL --- */

/* Aplicamos al contenedor del medio de cada slide */
#shopify-section-template--20622534279413__carousel_DJfgLq .card__inner > .group-block--height-fill {
    display: flex !important;
    flex-direction: column !important;
    /* Ajustamos la altura mínima: 320px suele ser el estándar para tus textos */
    /* Puedes subir o bajar este número hasta que la tarjeta más larga encaje */
    min-height: 320px !important; 
    height: 320px !important;
}

/* Forzamos que el contenido interno (el texto) se distribuya bien */
#shopify-section-template--20622534279413__carousel_DJfgLq .group-block-content {
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important; /* Centra el texto verticalmente */
    padding-bottom: 20px !important; /* Espacio de seguridad */
}

/* Aseguramos que la imagen de fondo cubra todo el nuevo alto estirado */
#shopify-section-template--20622534279413__carousel_DJfgLq .background-image-container img {
    object-fit: cover !important;
    height: 100% !important;
    width: 100% !important;
}

/* Quitamos márgenes extraños que puedan separar las piezas del sándwich */
#shopify-section-template--20622534279413__carousel_DJfgLq .card__inner {
    gap: 0 !important;
}
/* --- AJUSTE PARA MÓVIL: EVITAR DESBORDE DE IMAGEN --- */
@media screen and (max-width: 989px) {
  #shopify-section-template--20622534279413__carousel_DJfgLq .background-image-container {
    width: 100% !important;
    left: 0 !important;
    overflow: hidden !important;
  }

  #shopify-section-template--20622534279413__carousel_DJfgLq .background-image-container img {
    /* "contain" asegura que la imagen se vea completa sin cortarse a los lados */
    object-fit: fill !important; 
    width: 100% !important;
    height: 100% !important;
  }

  /* Ajustamos la altura de la caja en móvil para que no sea tan gigante como en desktop */
  #shopify-section-template--20622534279413__carousel_DJfgLq .card__inner > .group-block--height-fill {
    min-height: 280px !important; /* Altura un poco menor para pantallas pequeñas */
    height: auto !important;
    max-width: 100vw !important;
  }
}
/* --- AJUSTE CARRUSEL: -30% VISUAL SIN ROMPER FUNCIONALIDAD (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {

  /* 1. Reducimos el ancho del contenedor principal para simular el achique */
  #shopify-section-template--20622534279413__carousel_DJfgLq .section-carousel {
    max-width: 65% !important; /* Aquí está el "30% más chico" */
    margin: 0 auto !important; /* Lo centramos */
  }

  /* 2. Ajustamos las alturas de las cajas de texto (el sándwich) */
  /* Como no hay 'scale', las tipografías mantienen su tamaño original solas */
  #shopify-section-template--20622534279413__carousel_DJfgLq .card__inner > .group-block--height-fill {
    display: flex !important;
    flex-direction: column !important;
    min-height: 380px !important; /* Ajusta según el texto más largo */
    height: 380px !important;
    padding: 0 15px !important; /* Un poco de aire lateral para el texto */
  }

  /* 3. Aseguramos que las imágenes de fondo encajen perfecto */
  #shopify-section-template--20622534279413__carousel_DJfgLq .background-image-container img {
    object-fit: fill !important;
    height: 100% !important;
    width: 100% !important;
  }

  /* 4. Unimos las piezas para que parezca una sola tarjeta */
  #shopify-section-template--20622534279413__carousel_DJfgLq .card__inner {
    gap: 0 !important;
  }

  /* 5. Ajuste opcional para las flechas si quedan fuera de lugar */
  #shopify-section-template--20622534279413__carousel_DJfgLq slideshow-arrows {
    --arrow-offset: -50px; /* Mueve las flechas un poco hacia afuera */
  }
}

/* --- MÓVIL: MANTENER AL 100% --- */
@media screen and (max-width: 989px) {
  #shopify-section-template--20622534279413__carousel_DJfgLq .card__inner > .group-block--height-fill {
    min-height: 280px !important;
    height: auto !important;
  }
}
/* --- AJUSTE DE PADDING EN CARRUSEL (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {

  /* 1. Reducimos el padding de la sección completa */
  #shopify-section-template--20622534279413__carousel_DJfgLq .section {
    --padding-block-start: 5px !important; /* Estaba en 30px o más */
    --padding-block-end: 10px !important;   /* Estaba en 24px */
    padding-top: var(--padding-block-start);
    padding-bottom: var(--padding-block-end);
  }

  /* 2. Si te refieres al espacio interno de las tarjetas (donde está el texto) */
  #shopify-section-template--20622534279413__carousel_DJfgLq .group-block {
    --padding-block-start: 5px !important;
    --padding-block-end: 5px !important;
  }


  /* --- COMPACTAR ALTURA DE TARJETAS (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {

  /* Reducimos la altura de la caja central (donde está el texto) */
  #shopify-section-template--20622534279413__carousel_DJfgLq .card__inner > .group-block--height-fill {
    /* Bajamos de 380px a 290px (ajusta este número según tu texto más largo) */
    min-height: 290px !important; 
    height: 290px !important;
  }

  /* Ajustamos el tamaño de la fuente para que quepa bien en menos espacio */
  #shopify-section-template--20622534279413__carousel_DJfgLq .group-block-content p {
    font-size: 0.95rem !important;
    line-height: 1.1 !important;
  }

  /* Reducimos el padding interno de la caja de texto para ganar espacio */
  #shopify-section-template--20622534279413__carousel_DJfgLq .group-block-content {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    justify-content: center !important;
  }
}
/* --- CORRECCIÓN TAMAÑO TEXTO LEGAL EN CARRUSEL (DESKTOP) --- */
@media screen and (min-width: 990px) {

  /* Seleccionamos específicamente el bloque de la nota al pie por su clase única */
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block--ANEtBOWMzajZ3VzhFa__text_mDTFWp p {
    font-size: 0.65rem !important; /* Tamaño pequeño original */
    line-height: 1.1 !important;
    margin-top: 8px !important;
    transform: none !important; /* Eliminamos cualquier escalado heredado */
  }

  /* Si hay otros bloques similares de "letra chica", podemos usar la clase del sistema de Shopify */
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block.custom-typography p {
    /* Este selector asegura que si el texto es muy largo, no rompa la caja compacta */
    max-width: 90%;
    margin-left: auto;
    margin-right: 15%;
  }
}
/* --- DISEÑO LOGOS: -30% Y CENTRADO EQUIDISTANTE (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {

  /* 1. Contenedor de los logos: limitamos el ancho para achicarlos visualmente */
  #shopify-section-template--20622534279413__section_iqQ6he .group-block-content {
    max-width: 65% !important; /* Achica el conjunto total un 35% aprox */
    margin: 0 auto !important; /* Centra el bloque de logos en la pantalla */
    display: flex !important;
    justify-content: space-between !important; /* Espaciado equidistante perfecto */
    align-items: center !important;
    --gap: 0px !important; /* Dejamos que space-between maneje el espacio */
  }

  /* 2. Reducimos el tamaño individual de cada bloque de imagen */
  #shopify-section-template--20622534279413__section_iqQ6he .image-block {
    max-width: 130px !important; /* Controlamos el tamaño máximo de cada logo */
    flex: 0 1 auto !important;
  }

  /* 3. Ajustamos el margen lateral de la sección para que respire */
  #shopify-section-template--20622534279413__section_iqQ6he .section-content-wrapper {
    padding-left: 10% !important;
    padding-right: 10% !important;
  }

  /* 4. Mantenemos el texto "Destacado por..." en su sitio sin achicarlo */
  #shopify-section-template--20622534279413__section_iqQ6he .text-block--AVi9sdVRvK0FEQ1M2T__text_HnjRXB {
    margin-right: 40px !important;
    flex-shrink: 0 !important;
  }
  /* --- ENSANCHAR CUADRO DE TEXTO (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {
  
  /* 1. Expandimos el contenedor del grupo al 150% (50% más) */
  #shopify-section-template--20622534279413__section_RdwKex .group-block {
    --size-style-width: 150% !important;
    width: 150% !important;
    max-width: 900px !important; /* Límite de seguridad para que no toque los bordes */
    margin: 0 auto !important; /* Centrado */
  }

  /* 2. Forzamos a los bloques de texto internos a aprovechar el nuevo ancho */
  #shopify-section-template--20622534279413__section_RdwKex .text-block {
    --width: 100% !important;
    width: 100% !important;
    --max-width: 100% !important;
  }

  /* 3. Eliminamos los saltos de línea forzados (<br>) para que el texto fluya a lo largo */
  /* Esto ayuda a evitar palabras huérfanas y aprovecha el 50% extra de ancho */
  #shopify-section-template--20622534279413__section_RdwKex p br {
    display: none !important;
  }

  /* 4. Aseguramos que el contenido esté centrado */
  #shopify-section-template--20622534279413__section_RdwKex .group-block-content {
    align-items: center !important;
    text-align: center !important;
  }
  /* --- CENTRADO TOTAL DE PROMOCIÓN (FORZADO) --- */

/* 1. Atacamos la sección completa y sus envoltorios flex */
#shopify-section-template--20622534213877__featured_product_information_3mjgth,
#shopify-section-template--20622534213877__featured_product_information_3mjgth .product-information__grid,
#shopify-section-template--20622534213877__featured_product_information_3mjgth .product-details,
#shopify-section-template--20622534213877__featured_product_information_3mjgth .group-block-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important; /* Centrado horizontal */
    text-align: center !important;   /* Centrado de texto */
    justify-content: center !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 auto !important;
}

/* 2. Forzamos las variables internas que usa el tema Horizon */
#shopify-section-template--20622534213877__featured_product_information_3mjgth .group-block-content {
    --horizontal-alignment: center !important;
    --vertical-alignment: center !important;
}

/* 3. Específicamente el bloque de título y precio (que suelen resistirse) */
#shopify-section-template--20622534213877__featured_product_information_3mjgth .text-block,
#shopify-section-template--20622534213877__featured_product_information_3mjgth .view-product-title,
#shopify-section-template--20622534213877__featured_product_information_3mjgth product-price {
    width: 100% !important;
    display: block !important;
    text-align: center !important;
    --text-align: center !important;
}

/* 4. El formulario y el botón de compra */
#shopify-section-template--20622534213877__featured_product_information_3mjgth .shopify-product-form,
#shopify-section-template--20622534213877__featured_product_information_3mjgth .product-form-buttons {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
}

#shopify-section-template--20622534213877__featured_product_information_3mjgth .add-to-cart-button {
    margin-left: auto !important;
    margin-right: auto !important;
    min-width: 250px !important; /* Evita que el botón sea muy pequeño al centrarse */
}
/* --- RECORTAR FONDO Y CONTENIDO AL 50% (SOLO DESKTOP) --- */
@media screen and (min-width: 990px) {
  

  /* 2. Aplicamos el fondo azul y el ancho del 50% al contenedor de contenido */
  #shopify-section-template--20622534279413__section_mkhkzw .section-content-wrapper {
    max-width: 50% !important;
    margin: 0 auto !important;
    background: linear-gradient(to bottom, #070c38, rgba(7, 12, 56, 0.8)) !important; /* El degradado */
    border-radius: 8px; /* Opcional: para que las esquinas del bloque azul se vean prolijas */
    padding: 40px !important; /* Espacio interno para que el texto no toque los bordes del azul */
  }

  /* 3. Centramos los textos dentro de ese nuevo bloque azul */
  #shopify-section-template--20622534279413__section_mkhkzw .text-block {
    --width: 100% !important;
    width: 100% !important;
    text-align: center !important;
    display: flex !important;
    justify-content: center !important;
  }

  /* 4. Quitamos los saltos de línea para evitar huérfanos */
  #shopify-section-template--20622534279413__section_mkhkzw p br {
    display: none !important;
  }
}
/* --- TAMAÑO LOGO AMAZON (OPTIMIZADO PARA DESKTOP) --- */
@media screen and (min-width: 990px) {
  #shopify-section-template--20622534279413__section_tBYthG .image-block {
    /* Aumentamos el ancho máximo para que luzca bien en pantalla completa */
    max-width: 450px !important; 
    width: 450px !important;
    margin: 0 auto !important;
    display: block !important;
  }
}

/* --- AJUSTE PARA TABLET/VENTANA MEDIANA --- */
@media screen and (min-width: 750px) and (max-width: 989px) {
  #shopify-section-template--20622534279413__section_tBYthG .image-block {
    max-width: 350px !important;
  }
}

/* --- AJUSTE PARA MÓVIL (MANTENER PROPORCIÓN) --- */
@media screen and (max-width: 749px) {
  #shopify-section-template--20622534279413__section_tBYthG .image-block {
    max-width: 280px !important;
    width: 80% !important; /* Como lo tenías originalmente */
  }
}
/* --- AJUSTE FORZADO DE FUENTE CARRUSEL (DESKTOP) --- */
@media screen and (min-width: 990px) {
  
  /* Título principal */
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block--AWkNzQzFDL1hNRWJuT__text_aWfHDw,
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block--AWkNzQzFDL1hNRWJuT__text_aWfHDw p {
    font-size: 2.35rem !important; /* Forzamos la propiedad real, no solo la variable */
    line-height: 1.8 !important;
  }

  /* Subtítulo */
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block--ANzdaVldNbXdZODJBZ__text_e8Xr6B,
  #shopify-section-template--20622534279413__carousel_DJfgLq .text-block--ANzdaVldNbXdZODJBZ__text_e8Xr6B p {
    font-size: 1.15rem !important;
    line-height: 1.2 !important;
  }
}
/* --- SECCIÓN GIGANTE CON FONDO GRIS CELESTE Y SIN ESPACIOS --- */
@media screen and (min-width: 990px) {
  
  /* 1. Fondo gris celeste y eliminación de espacios en la sección */
  #shopify-section-template--20622534279413__section_BVmxiJ {
    background-color: #f0f4f7 !important; /* El gris celeste que usamos */
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    height: auto !important;
    overflow: hidden !important;
  }

  /* 2. Eliminamos el espacio blanco de los contenedores internos */
  #shopify-section-template--20622534279413__section_BVmxiJ .section,
  #shopify-section-template--20622534279413__section_BVmxiJ .section-content-wrapper {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    background: transparent !important;
  }

  /* 3. Ajustamos el bloque de texto superior (Destacado por medios...) */
  #shopify-section-template--20622534279413__section_BVmxiJ .text-block {
    padding-top: 20px !important; /* Un pequeño margen para que no pegue al borde superior */
    padding-bottom: 10px !important;
    margin: 0 !important;
  }

  /* 4. La imagen a 250% del alto de pantalla sin recortes */
  #shopify-section-template--20622534279413__section_BVmxiJ img.image-block__image {
    height: 100vh !important; 
    width: auto !important;
    max-width: 100% !important; /* Para que no genere scroll lateral */
    object-fit: contain !important;
    display: block !important;
    margin: 0 auto !important;
    padding: 0 !important;
  }

  /* Forzamos que el fondo gris cubra todo */
  #shopify-section-template--20622534279413__section_BVmxiJ .section-background {
    background-color: #f0f4f7 !important;
    display: block !important;
  }
}
@media screen and (max-width: 749px) {
  #shopify-section-template--20622534279413__carousel_DJfgLq .card {
    scroll-snap-align: center !important;
    scroll-snap-stop: always !important;
  }
  @media screen and (max-width: 749px) {
  .product__media-list {
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  
  .product__media-item {
    scroll-snap-align: center;
    scroll-snap-stop: always;
  }
}
/* Esto afecta a pantallas grandes (Desktop) */
@media screen and (min-width: 750px) {
  body {
    font-size: 18px; /* Agranda la letra general */
  }
  
  h1, .h1 {
    font-size: 50px; /* Agranda los títulos principales */
  }

  .container {
    max-width: 1200px; /* Ayuda a que el diseño se acomode y no se estire al infinito */
    margin: 0 auto;
  }
  /* FUERZA EL HEADER FIJO EN TODA LA WEB */
.shopify-section-group-header-group {
  position: sticky !important;
  top: 0 !important;
  z-index: 9999 !important;
}

/* Evita que se vea transparente al bajar */
.header__row--top, .header__columns {
  background-color: white !important;
}

/* Repara el error de configuración que rompe el sticky */
body, #MainContent {
  overflow: visible !important;
}
/* Asegura que ninguna sección se monte sobre otra */
.shopify-section {
  display: flow-root !important;
  width: 100%;
  clear: both;
}
}
}
}