/** Shopify CDN: Minification failed

Line 17:17 Expected identifier but found whitespace
Line 17:19 Unexpected "{"
Line 17:29 Expected ":"
Line 17:56 Expected identifier but found ","
Line 18:14 Expected identifier but found whitespace
Line 18:16 Unexpected "{"
Line 18:26 Expected ":"
Line 18:51 Expected identifier but found ","
Line 19:16 Expected identifier but found whitespace
Line 19:18 Unexpected "{"
... and 3 more hidden warnings

**/
 :root {
  --font-heading: {{ settings.type_header_font.family }}, serif;
  --font-body: {{ settings.type_base_font.family }}, sans-serif;
  --font-accent: {{ settings.type_base_font.family }}, sans-serif;
}

 {
  box-sizing: border-box;
}

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

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

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

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

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

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

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

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

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

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

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

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

  text-align: left;
}

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

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

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

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

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

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

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

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

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

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

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

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

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

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

.relative {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

/* Typography presets */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  @media screen and (min-width: 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;
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[open] {
    opacity: 1;
  }

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

  &::backdrop {
    background: transparent;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.card-gallery {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

  to {
    transform: translateX(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  button {
    --size: 0.5rem;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.slideshow-controls__thumbnail {
  position: relative;
}

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}
/* === MEIA — Collection Header Redesign === */
.template-collection .meia-collection-intro {
  text-align: center;
  padding: clamp(48px, 6vw, 80px) 20px 40px;
  background: linear-gradient(180deg, #f8f7f5 0%, #eeeae5 100%);
}

.template-collection .meia-collection-title {
  font-family: var(--font-heading--family), serif;
  font-size: clamp(30px, 5vw, 46px);
  letter-spacing: 1px;
  color: #111;
  margin-bottom: 14px;
  text-transform: none;
}

.template-collection .meia-collection-tagline {
  font-family: var(--font-body--family), sans-serif;
  color: #444;
  font-size: clamp(15px, 2.2vw, 17px);
  font-weight: 400;
  max-width: 70ch;
  margin: 0 auto;
  opacity: 0.85;
}


/* ============================================
   MEIA About Us — Video + Text Combined Layout
   ============================================ */
.meia-about-wrapper {
  background: #f8f7f5;
  padding: 80px 20px;
}

.meia-about-container {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 60px;
  max-width: 1200px;
  margin: 0 auto;
}

/* Video Styling */
.meia-about-video {
  flex: 1 1 480px;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}

.meia-about-video video {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 16 / 9;
  border-radius: 14px;
}

/* Text Styling */
.meia-about-text {
  flex: 1 1 480px;
  font-family: var(--font-body--family), sans-serif;
  color: #2b2b2b;
  font-size: 18px;
  line-height: 1.8;
}

.meia-about-text h2 {
  font-family: var(--font-heading--family), serif;
  font-size: 40px;
  font-weight: 600;
  margin-bottom: 25px;
  color: #111;
}

/* Responsive Adjustments */
@media (max-width: 900px) {
  .meia-about-container {
    flex-direction: column;
    gap: 40px;
  }

  .meia-about-video video {
    aspect-ratio: 16 / 9;
  }

  .meia-about-text {
    text-align: center;
    padding: 0 10px;
  }

  .meia-about-text h2 {
    font-size: 32px;
  }
}

/* ===================================================
   MEIA — Contact Page Design
   =================================================== */

.meia-contact {
  background: linear-gradient(180deg, #f5f4f2 0%, #eceae7 100%);
  padding: 100px 10%;
  display: flex;
  justify-content: center;
}

.contact-container {
  max-width: 650px;
  width: 100%;
  text-align: center;
  animation: fadeIn 1s ease-out both;
}

.meia-contact h1 {
  font-family: var(--font-heading--family), serif;
  font-size: 2.6rem;
  letter-spacing: 1px;
  color: #111;
  margin-bottom: 1rem;
}

.meia-contact .intro {
  font-family: var(--font-body--family), sans-serif;
  color: #444;
  font-size: 1.05rem;
  line-height: 1.6;
  margin-bottom: 40px;
}

/* Form */
.contact-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
  text-align: left;
}

.contact-form input,
.contact-form textarea {
  font-family: var(--font-accent--family, var(--font-body--family)), monospace;
  background: #fdfdfc;
  border: 1px solid #ccc;
  padding: 12px 15px;
  border-radius: 4px;
  transition: border 0.3s ease, background 0.3s ease;
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: #111;
  outline: none;
  background: #fff;
}

.submit-button {
  background: #111;
  color: white;
  font-family: var(--font-heading--family), serif;
  border: none;
  padding: 12px 30px;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 1px;
  transition: all 0.3s ease;
}

.submit-button:hover {
  background: #333;
}

/* Details Section */
.contact-details {
  margin-top: 60px;
  text-align: left;
  border-top: 1px solid #ddd;
  padding-top: 30px;
  font-family: var(--font-body--family), sans-serif;
}

.contact-details h3 {
  font-family: var(--font-heading--family), serif;
  font-size: 1.4rem;
  margin-bottom: 15px;
}

.contact-details a {
  color: #111;
  text-decoration: none;
  border-bottom: 1px solid #aaa;
  transition: color 0.3s ease, border 0.3s ease;
}

.contact-details a:hover {
  color: #000;
  border-bottom: 1px solid #000;
}

/* Animation */
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 768px) {
  .meia-contact {
    padding: 60px 8%;
  }
  .meia-contact h1 {
    font-size: 2.2rem;
  }
  .contact-form input,
  .contact-form textarea {
    font-size: 1rem;
  }
}
/* ============================================
   MEIA — Privacy / Policy Page Redesign
   Radiant Theme specific
   ============================================ */

.shopify-policy__container {
  max-width: 900px !important;           /* wider content */
  margin: 0 auto !important;
  padding: 80px 40px !important;
  background: #f7f6f3 !important;        /* soft beige paper tone */
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.05);
  border-radius: 10px;
  font-family: var(--font-body--family), sans-serif !important;
  font-size: 17px !important;
  line-height: 1.8 !important;
  color: #2b2b2b !important;
  text-align: justify !important;
}

/* Headings */
.shopify-policy__container h1 {
  font-family: var(--font-heading--family), serif !important;
  font-weight: 600 !important;
  font-size: 48px !important;
  color: #111 !important;
  text-align: left !important;
  margin-bottom: 30px !important;
  border-bottom: 1px solid #ddd;
  padding-bottom: 10px;
}

.shopify-policy__container h2,
.shopify-policy__container h3 {
  font-family: var(--font-heading--family), serif !important;
  font-weight: 500 !important;
  font-size: 24px !important;
  color: #111 !important;
  margin-top: 40px !important;
  margin-bottom: 15px !important;
}

/* Dates and meta info (like “Last updated…”) */
.shopify-policy__container p:first-of-type {
  color: #555 !important;
  font-style: italic !important;
}

/* Light paper texture for realism */
.shopify-policy__container {
  background-image: url("https://www.transparenttextures.com/patterns/paper-fibers.png");
  background-blend-mode: multiply;
}

/* Responsive for mobile */
@media (max-width: 768px) {
  .shopify-policy__container {
    max-width: 95% !important;
    padding: 50px 20px !important;
    font-size: 16px !important;
    line-height: 1.7 !important;
  }

  .shopify-policy__container h1 {
    font-size: 36px !important;
    text-align: center !important;
  }
}

/* =========================================================
   MEIA BASE FINAL V8 — Transparent Header + Newspaper Grey
   ========================================================= */

/* === 1. Font System (Routed to theme customizer) === */
:root {
  --font-heading: var(--font-heading--family);
  --font-body: var(--font-body--family);
  --font-accent: var(--font-accent--family, var(--font-body--family));
  --color-heading: #111;
  --color-text: #1a1a1a;
  --color-bg-home: #ffffff;
  --color-bg-other: #f2f2f2;
}

/* === 2. Base Typography === */
body, p, li, span, a, input, textarea, button {
  font-family: var(--font-body), sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.75;
  color: var(--color-text);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: 0.01em;
}

h1, h2, h3, h4, h5, h6,
.section-header__title,
.page-title,
.product__title,
.collection-hero__title,
.rich-text__heading {
  font-family: var(--font-heading), serif;
  font-weight: 500;
  color: var(--color-heading);
  text-transform: none;
  line-height: 1.15;
  letter-spacing: 0.02em;
}

h1 { font-size: clamp(2.3rem, 4vw, 3.8rem); }
h2 { font-size: clamp(2rem, 3.2vw, 3.2rem); }
h3 { font-size: clamp(1.7rem, 2.5vw, 2.4rem); }
h4 { font-size: clamp(1.4rem, 2vw, 1.8rem); }
h5, h6 { font-size: clamp(1.2rem, 1.6vw, 1.4rem); }

/* ---------------------------------------------------------
   2. HEADER — Transparent, Fixed, Clean Icons
   --------------------------------------------------------- */
.meia-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1000;
  background: transparent !important;
  border-bottom: 1px solid rgba(0,0,0,0.05);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.meia-header.scrolled {
  background: rgba(255,255,255,0.9) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}

.header-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 28px;
  position: relative;
}

/* Logo */
.site-logo {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.site-logo img {
  height: clamp(34px, 3.5vw, 48px) !important;
  width: auto !important;
  transition: all 0.3s ease;
}

/* Burger & Icons */
.burger-menu {
  background: transparent !important;
  border: none;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 4px;
  cursor: pointer;
}
.burger-menu span {
  width: 22px;
  height: 2px;
  background: var(--color-text) !important;
  border-radius: 1px;
  transition: all 0.3s ease;
}
.icon, .icon svg, .icon path, .ri-search-line, .ri-shopping-bag-line {
  color: var(--color-text) !important;
  fill: none !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 1.25rem;
  transition: color 0.3s ease;
}

/* Menu Drawer (Left Side) */
.meia-menu-panel {
  position: fixed;
  top: 0;
  left: -100%;
  width: 280px;
  height: 100vh;
  background: var(--color-bg-other);
  box-shadow: 2px 0 10px rgba(0,0,0,0.1);
  padding: 60px 25px;
  transition: left 0.4s ease;
  z-index: 999;
  display: flex;
  flex-direction: column;
}
.meia-menu-panel.open { left: 0; }
.meia-nav ul { list-style: none; padding: 0; margin: 0; }
.meia-nav li { margin-bottom: 18px; }
.meia-nav a {
  font-family: var(--font-body), sans-serif;
  color: var(--color-text);
  text-decoration: none;
  font-size: 1.05rem;
  transition: color 0.3s ease;
}
.meia-nav a:hover { color: var(--color-accent, #111); }
.has-submenu ul { margin-left: 15px; display: none; }
.has-submenu.open ul { display: block; }

/* === Submenu Toggle Enhancement (Chevron Animation) === */
.has-submenu > a {
  position: relative;
  padding-right: 18px;
}
.has-submenu > a::after {
  content: "▾";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  font-size: 0.8rem;
  color: var(--color-text);
  transition: transform 0.3s ease;
}
.has-submenu.open > a::after {
  transform: translateY(-50%) rotate(180deg);
}
/* === MEIA Header Icon Spacing & Style === */
.header-right {
  display: flex;
  align-items: center;
  gap: 20px; /* adds consistent spacing between icons */
}

.header-right .icon {
  font-size: 1.4rem;
  color: #111;
  text-decoration: none;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.header-right .icon:hover {
  opacity: 0.7;
  transform: translateY(-1px);
}

/* Optional: balance on small screens */
@media (max-width: 768px) {
  .header-right {
    gap: 16px;
  }
}


/* === 5. Page Backgrounds === */
body.template-index { background-color: var(--color-bg-home) !important; }
body.template-product,
body.template-collection,
body.page,
body.page-about-us,
body.page-contact,
body.page-faq {
  background-color: var(--color-bg-other) !important;
}

/* === 6. Product Grid === */
.collection .product-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
  gap: 40px !important;
  justify-items: center !important;
  padding: 40px 20px !important;
}

.card__inner, .product-card__media, .media.media--hover-effect {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.media.media--hover-effect:hover, .product-card__media:hover, .card__inner:hover {
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 6px 18px rgba(0,0,0,0.08);
}
.product-card__media img, .card__inner img {
  border-radius: 6px;
  transition: transform 0.3s ease;
}
.product-card__media:hover img, .card__inner:hover img {
  transform: scale(1.03);
}

/* === FINAL MEIA FIX — Add to Cart + Buy It Now Buttons === */
.product-form__submit,
.shopify-payment-button__button,
.shopify-payment-button__button--unbranded {
  background-color: #000 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  transition: all 0.3s ease !important;
  box-shadow: none !important;
  filter: none !important;
}

/* hover / focus / active */
.product-form__submit:hover,
.shopify-payment-button__button:hover,
.shopify-payment-button__button--unbranded:hover,
.product-form__submit:focus,
.shopify-payment-button__button:focus,
.shopify-payment-button__button--unbranded:focus {
  background-color: #222 !important;
  color: #fff !important;
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15) !important;
}

/* disable Radiant inline variable overrides */
:root {
  --color-primary-button-background: #000 !important;
  --color-primary-button-text: #fff !important;
  --color-primary-button-border: #000 !important;
  --color-primary-button-hover-background: #222 !important;
  --color-primary-button-hover-text: #fff !important;
  --color-primary-button-hover-border: #222 !important;
}

/* ensure disabled buttons (like preorder state) still match */
.product-form__submit[disabled],
.shopify-payment-button__button[disabled],
.shopify-payment-button__button--unbranded[disabled] {
  background-color: #000 !important;
  color: #fff !important;
  opacity: 0.5 !important;
  cursor: not-allowed !important;
}

/* === 9. FAQ Styling === */
.meia-faq-section {
  max-width: 900px;
  margin: 100px auto;
  padding: 60px;
  background: var(--color-bg-other);
  border-radius: 20px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.05);
  font-family: var(--font-body), sans-serif;
}
.faq-item {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  overflow: hidden;
  transition: transform 0.2s ease;
}
.faq-item:hover { transform: translateY(-3px); }
.faq-question {
  background: #f7f6f3;
  padding: 20px 25px;
  font-size: 18px;
  font-weight: 600;
  color: #111;
  border: none;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.faq-answer p {
  padding: 0 25px 20px;
  color: #555;
  font-size: 16px;
  line-height: 1.6;
}

/* === 10. Responsive === */
@media (max-width: 768px) {
  .header-wrapper { padding: 10px 18px; }
  .site-logo img { height: clamp(30px, 8vw, 42px); }
  .meia-menu-panel { width: 100%; border-radius: 0; }
}

/* ======================================================
   🖤 MEIA MENU — Compact Black Drawer (Minimal Luxury)
   ====================================================== */

.meia-menu-panel {
  position: fixed;
  top: 0;
  left: -100%;
  width: 260px;
  height: 100vh;
  background: #000 !important;
  color: #fff;
  z-index: 9999;
  box-shadow: 6px 0 20px rgba(0,0,0,0.2);
  transition: left 0.4s ease, opacity 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  padding: 60px 24px 40px;
  overflow-y: auto;
  border-right: 1px solid rgba(255,255,255,0.05);
}

.meia-menu-panel.open {
  left: 0;
  opacity: 1;
}

.meia-menu-panel .close-btn {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 1.3rem;
  align-self: flex-end;
  margin-bottom: 28px;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.meia-menu-panel .close-btn:hover {
  opacity: 0.7;
  transform: scale(1.1);
}

.meia-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.meia-nav li {
  margin: 10px 0;
  width: 100%;
}

.meia-nav a {
  display: block;
  font-family: var(--font-body), sans-serif;
  font-size: 0.95rem;
  font-weight: 400;
  color: #fff !important;
  text-decoration: none;
  padding: 6px 0;
  letter-spacing: 0.03em;
  transition: color 0.25s ease, padding-left 0.25s ease;
}
.meia-nav a:hover {
  color: #e5e5e5;
  padding-left: 6px;
}

.has-submenu > a::after {
  content: "▾";
  float: right;
  font-size: 0.8rem;
  opacity: 0.7;
  transition: transform 0.3s ease;
}
.has-submenu.open > a::after {
  transform: rotate(180deg);
}

.has-submenu ul {
  display: none;
  margin-top: 6px;
  padding-left: 14px;
  border-left: 1px solid rgba(255,255,255,0.1);
}
.has-submenu.open ul {
  display: block;
  animation: submenuFade 0.3s ease;
}
@keyframes submenuFade {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

.has-submenu ul li a {
  font-size: 0.9rem;
  opacity: 0.8;
  padding: 4px 0;
}

@media (max-width: 768px) {
  .meia-menu-panel {
    width: 75%;
    max-width: 260px;
    padding: 50px 20px;
  }

  .meia-nav a {
    font-size: 0.9rem;
  }
}
/* === FINAL MEIA MENU — Compact Size & Balanced Padding === */
.meia-menu-panel {
  position: fixed;
  top: 0;
  left: -100%;
  width: 220px; /* smaller, elegant width */
  height: auto;
  max-height: 85vh; /* not full screen */
  background: #000 !important;
  color: #fff;
  z-index: 9999;
  box-shadow: 4px 0 12px rgba(0,0,0,0.2);
  padding: 40px 20px;
  border-radius: 0 12px 12px 0;
  transition: left 0.35s ease, opacity 0.3s ease;
  overflow-y: auto;
}

.meia-menu-panel.open {
  left: 0;
  opacity: 1;
}

.meia-menu-panel .close-btn {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 1.2rem;
  align-self: flex-end;
  margin-bottom: 20px;
  cursor: pointer;
}

.meia-nav ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.meia-nav li {
  margin: 8px 0;
}

.meia-nav a {
  display: block;
  color: #fff;
  font-size: 0.9rem;
  text-decoration: none;
  padding: 4px 0;
  transition: color 0.25s ease, padding-left 0.25s ease;
}

.meia-nav a:hover {
  color: #e5e5e5;
  padding-left: 6px;
}

/* Submenu icons */
.has-submenu > a::after {
  content: "▾";
  float: right;
  font-size: 0.7rem;
  opacity: 0.7;
  transition: transform 0.3s ease;
}
.has-submenu.open > a::after {
  transform: rotate(180deg);
}

/* Mobile adjustment */
@media (max-width: 768px) {
  .meia-menu-panel {
    width: 70%;
    max-width: 240px;
    padding: 35px 18px;
  }
}

/* =========================================================
   🖤 MEIA SIZE DROPDOWN — Elegant + Interactive (Final)
   ========================================================= */

.select,
.product-form__input .select {
  position: relative !important;
  display: inline-block !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  width: auto !important;
  height: auto !important;
}

.select__select,
.product-form__input select,
.variant-picker select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-color: #fff !important;
  color: #111 !important;
  border: 1px solid #111 !important;
  border-radius: 50px !important;
  padding: 0.6em 2.2em 0.6em 1.2em !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
  width: auto !important;
  min-width: 130px !important;
  box-shadow: none !important;
  position: relative !important;
}

.select::after,
.product-form__input .select::after {
  content: "▾";
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.8rem;
  color: #111;
  pointer-events: none;
  transition: transform 0.25s ease, color 0.25s ease;
}

.select__select:hover,
.product-form__input select:hover,
.variant-picker select:hover,
.select__select:focus,
.product-form__input select:focus,
.variant-picker select:focus {
  background-color: #111 !important;
  color: #fff !important;
  outline: none !important;
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}

.select__select option,
.variant-picker select option {
  background-color: #fff !important;
  color: #111 !important;
  font-size: 0.9rem;
  text-transform: uppercase;
  padding: 8px 12px;
}

.select__select:disabled {
  background-color: #f6f6f6 !important;
  color: #aaa !important;
  border: 1px dashed #aaa !important;
  cursor: not-allowed;
}

.product-form__input,
.variant-picker {
  margin-bottom: 0.8rem !important;
}


/* =========================================================
   🖤 MEIA FAQ SECTION — Restored Luxury Minimal Design
   ========================================================= */
.meia-faq-section {
  max-width: 900px;
  margin: 100px auto;
  padding: 60px 50px;
  background: #f2f2f2;
  border-radius: 20px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.05);
  font-family: var(--font-body), sans-serif;
  transition: all 0.3s ease;
}

.faq-item {
  background: #fff;
  border-radius: 12px;
  margin-bottom: 14px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04);
  overflow: hidden;
  transition: transform 0.2s ease, box-shadow 0.3s ease;
}
.faq-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.08);
}

.faq-question {
  width: 100%;
  text-align: left;
  background: #fafafa;
  border: none;
  outline: none;
  padding: 22px 25px;
  font-size: 18px;
  font-weight: 600;
  color: #111;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  letter-spacing: 0.02em;
  transition: background 0.25s ease, color 0.25s ease;
}
.faq-question:hover {
  background: #111;
  color: #fff;
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}
.faq-item.active .faq-answer {
  max-height: 400px;
}
.faq-answer p {
  padding: 0 25px 20px;
  color: #444;
  line-height: 1.6;
  font-size: 16px;
}

.faq-answer::before {
  content: "";
  display: block;
  height: 1px;
  width: 100%;
  background: rgba(0, 0, 0, 0.05);
  margin: 0 0 15px;
}
/* === MEIA FAQ Top Spacing Adjustment === */
.meia-faq-section {
  padding-top: clamp(80px, 8vw, 120px) !important;
}

.meia-faq-section h1,
.meia-faq-section .section-header,
.meia-faq-section .page-title {
  margin-bottom: 40px !important; /* extra breathing room under heading */
}

.faq-item {
  margin-top: 18px !important; /* small gap between cards */
}
/* === MEIA FAQ Arrow Animation === */
.faq-arrow {
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-left: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.3s ease;
}

.faq-item.active .faq-arrow {
  transform: rotate(-135deg);
}

/* =========================================================
   🖤 MEIA STATIC PAGE DESIGN — About, FAQ, Contact, etc.
   ========================================================= */

body.page,
body.page-about-us,
body.page-contact,
body.page-faq,
body.page-policy,
.template-page {
  background-color: #f2f2f2 !important;
  color: #111 !important;
}

.main-page,
.page-width,
.template-page .page-width,
.shopify-policy__container {
  max-width: 100% !important;
  width: 100% !important;
  background: #f2f2f2 !important;
  padding: 60px 5vw !important;
  margin: 0 auto !important;
  box-shadow: none !important;
  border: none !important;
}

.main-page-content,
.shopify-policy__container .policy,
.page-content {
  max-width: 1100px;
  margin: 0 auto;
  background: #ffffff;
  padding: 60px 70px;
  border-radius: 20px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
  font-family: var(--font-body), sans-serif;
  transition: all 0.3s ease;
}

.main-page-content h1,
.page-content h1,
.shopify-policy__title {
  font-family: var(--font-heading), serif;
  font-weight: 600;
  font-size: 2.4rem;
  color: #111;
  margin-bottom: 30px;
}

.main-page-content p,
.page-content p,
.shopify-policy__body p {
  font-size: 1rem;
  line-height: 1.7;
  color: #222;
  margin-bottom: 1.2em;
}

.main-page-content a,
.page-content a,
.shopify-policy__body a {
  color: #111;
  text-decoration: underline;
  transition: color 0.3s ease;
}
.main-page-content a:hover,
.page-content a:hover,
.shopify-policy__body a:hover {
  color: #000;
}

@media (max-width: 768px) {
  .main-page-content,
  .shopify-policy__container .policy {
    padding: 40px 25px;
    border-radius: 14px;
  }
  .main-page-content h1 {
    font-size: 1.9rem;
  }
}
.meia-contact {
  padding: 60px 20px;
  background: #fafafa;
}
.contact-container {
  max-width: 700px;
  margin: 0 auto;
  text-align: center;
}
.contact-form input,
.contact-form textarea {
  width: 100%;
  margin: 10px 0;
  padding: 14px;
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 1rem;
  font-family: inherit;
}
.submit-button {
  display: inline-block;
  margin-top: 10px;
  background: #111;
  color: #fff;
  padding: 14px 32px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.2s ease;
}
.submit-button:hover {
  background: #333;
}
.form-status.success {
  color: #008a35;
  margin-bottom: 16px;
}
.form-status.error {
  color: #d11;
  margin-bottom: 16px;
}
@media (max-width: 600px) {
  .contact-container {
    padding: 0 10px;
    text-align: left;
  }
}

/* =========================================================
   🖤 MEIA — MOBILE VIDEO CONTAINER AUTO-FIT
   ========================================================= */
@media (max-width: 768px) {
  main > div > div:nth-of-type(2) > section > div > div:first-of-type {
    padding: 0 !important;
    margin: 0 auto !important;
    height: auto !important;
    min-height: auto !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: hidden !important;
  }

  main > div > div:nth-of-type(2) > section > div > div:first-of-type video,
  main > div > div:nth-of-type(2) > section > div > div:first-of-type iframe {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 12px !important;
    object-fit: cover !important;
    margin: 0 !important;
  }

  main > div > div:nth-of-type(2) > section > div {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
  }
}
/* =========================================================
   🩶 MEIA FOOTER — Compact & Balanced with Mobile Spacing
   ========================================================= */

.meia-footer {
  width: 100%;
  background: #f7f6f4;
  color: #111;
  font-family: var(--font-body, "Inter"), sans-serif;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  overflow-x: clip;
  animation: meiaFadeIn 1s ease both;
  box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.05);
}

@keyframes meiaFadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ---------- Layout ---------- */
.meia-footer__container {
  max-width: 1150px;
  margin: 0 auto;
  padding: 28px 18px 20px;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 16px;
  box-sizing: border-box;
}

/* ---------- Links (Left) ---------- */
.meia-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 18px;
  justify-content: flex-start;
}

.meia-footer__link {
  color: #111;
  opacity: 0.85;
  text-decoration: none;
  font-size: 0.88rem;
  transition: all 0.25s ease;
}

.meia-footer__link:hover {
  opacity: 1;
  transform: translateY(-1px);
}

/* ---------- Logo (Center) ---------- */
.meia-footer__logo {
  justify-self: center;
}

.meia-footer__logo img {
  width: 100px;
  height: auto;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.2));
  transition: transform 0.35s ease, filter 0.35s ease;
}

.meia-footer__logo img:hover {
  transform: scale(1.04);
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.25));
}

/* ---------- Social Icons (Right) ---------- */
.meia-footer__social {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 14px;
}

.meia-footer__social a img {
  width: 22px;
  height: 22px;
  object-fit: contain;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,0.15));
  transition: transform 0.25s ease, filter 0.3s ease, opacity 0.25s ease;
}

.meia-footer__social a:hover img {
  transform: scale(1.1);
  filter: drop-shadow(0 4px 6px rgba(0,0,0,0.25));
}

/* ---------- Copyright ---------- */
.meia-footer__bottom {
  grid-column: 1 / -1;
  text-align: center;
  font-size: 0.75rem;
  color: rgba(0,0,0,0.55);
  margin-top: 12px;
}

/* ---------- Mobile ---------- */
@media (max-width: 768px) {
  .meia-footer__container {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 24px 14px 26px;
  }

  .meia-footer__logo img {
    width: 80px;
    margin-bottom: 6px; /* space between logo and icons */
  }

  .meia-footer__social {
    justify-content: center;
    gap: 14px;
    margin-top: 2px;
  }

  .meia-footer__social a img {
    width: 20px;
    height: 20px;
  }

  .meia-footer__bottom {
    margin-top: 10px;
    font-size: 0.7rem;
  }
}


/* =========================================================
   🩶 MEIA MENU — Solid White Compact Luxury Mode
   ========================================================= */

.meia-menu-panel {
  position: fixed;
  top: 0;
  left: -100%;
  width: 240px;
  height: auto;
  max-height: 85vh; /* fit only the menu height */
  background: #ffffff !important;
  border-right: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow: 4px 0 25px rgba(0, 0, 0, 0.15);
  z-index: 9999;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  padding: 50px 22px 30px;
  border-radius: 0 14px 14px 0;
  transition: left 0.4s ease, opacity 0.4s ease, box-shadow 0.4s ease;
}

.meia-menu-panel.open {
  left: 0;
  opacity: 1;
  animation: meiaMenuFade 0.45s ease forwards;
}

@keyframes meiaMenuFade {
  from { opacity: 0; transform: translateX(-10px); }
  to { opacity: 1; transform: translateX(0); }
}

/* === Close Button === */
.close-btn {
  position: absolute !important;
  top: 18px;
  right: 18px;
  font-size: 32px;
  color: #111 !important;
  font-weight: 200;
  background: none;
  border: none;
  line-height: 1;
  cursor: pointer;
  z-index: 99999;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.close-btn:hover {
  transform: rotate(90deg);
  opacity: 0.7;
}

/* === Menu Links === */
.meia-nav ul,
.meia-nav li {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.meia-nav {
  margin-top: 25px;
}

.meia-nav a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.95rem;
  font-weight: 500;
  color: #111 !important;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 10px 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  transition: color 0.25s ease, transform 0.2s ease;
}

.meia-nav a:hover {
  color: #666 !important;
  transform: translateX(3px);
}

/* === Submenu Arrows === */
.has-submenu > a::after {
  content: "▾";
  font-size: 0.75rem;
  color: rgba(0, 0, 0, 0.6);
  margin-left: 10px;
  transition: transform 0.3s ease, color 0.3s ease;
}

.has-submenu.open > a::after {
  transform: rotate(180deg);
  color: #000;
}

/* === Submenu === */
.has-submenu ul {
  background: #f8f8f8;
  border-left: 2px solid rgba(0, 0, 0, 0.05);
  border-radius: 8px;
  padding: 8px 14px;
  margin-top: 6px;
  display: none;
}

.has-submenu.open ul {
  display: block;
  animation: submenuFade 0.3s ease;
}

@keyframes submenuFade {
  from { opacity: 0; transform: translateY(-5px); }
  to { opacity: 1; transform: translateY(0); }
}

.has-submenu ul a {
  font-size: 0.9rem;
  color: #333 !important;
  border-bottom: none;
}

/* === Optional White Edge Gradient === */
.meia-menu-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0) 60%);
  mix-blend-mode: overlay;
  opacity: 0.4;
}

/* === Mobile Adjustment === */
@media (max-width: 768px) {
  .meia-menu-panel {
    width: 75%;
    max-width: 240px;
    padding: 45px 20px;
    border-radius: 0 12px 12px 0;
    max-height: 80vh;
  }

  .close-btn {
    top: 16px;
    right: 16px;
    font-size: 28px;
  }

  .meia-nav a {
    font-size: 0.9rem;
  }
}
/* === MEIA MENU — Remove Top + Left Padding Gaps (Refined Final Fix) === */
.meia-menu-panel {
  padding-top: 20px !important;   /* reduced from 50px */
  padding-left: 0 !important;     /* remove left space */
  border-radius: 0 14px 14px 0 !important; /* keep elegant right curve */
  top: 0 !important;              /* ensure it hugs top edge */
  margin-top: 0 !important;
}

@media (max-width: 768px) {
  .meia-menu-panel {
    padding-top: 16px !important; /* slightly tighter on mobile */
    padding-left: 0 !important;
  }
}

/* =========================================================
   🖤 MEIA VARIANT BUTTON FIX — Radiant Theme Specific
   ========================================================= */

/* Base (unselected) button style */
.variant-option__button-label__text {
  background-color: #f9f9f8 !important;
  color: #111 !important;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
  border-radius: 50px !important;
  padding: 0.5em 1.4em !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  transition: all 0.25s ease !important;
  cursor: pointer !important;
  display: inline-block !important;
}

/* Hover */
.variant-option__button-label__text:hover {
  background-color: #111 !important;
  color: #fff !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(0,0,0,0.1);
}

/* Active / Selected */
.variant-option__button-label.is-active .variant-option__button-label__text,
.variant-option__button-label[aria-checked="true"] .variant-option__button-label__text {
  background-color: #111 !important;
  color: #fff !important;
  border-color: #111 !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.25);
}

/* Disabled (out of stock) */
.variant-option__button-label[aria-disabled="true"] .variant-option__button-label__text {
  background-color: #eee !important;
  color: #888 !important;
  opacity: 0.6 !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
}

/* Layout alignment */
.variant-picker__option-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  justify-content: flex-start !important;
}
/* =========================================================
   🩶 MEIA VARIANT BUTTON STYLE — Charcoal Finish (Radiant Fix)
   ========================================================= */

/* Default (unselected) */
.variant-option__button-label__text {
  background-color: #f9f9f8 !important;
  color: #111 !important;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
  border-radius: 50px !important;
  padding: 0.5em 1.4em !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  transition: all 0.25s ease !important;
  cursor: pointer !important;
  display: inline-block !important;
}

/* Hover */
.variant-option__button-label__text:hover {
  background-color: #1a1a1a !important;
  color: #f8f8f8 !important;
  transform: translateY(-1px);
  box-shadow: 0 3px 10px rgba(0,0,0,0.15);
}

/* Selected / Active */
.variant-option__button-label.is-active .variant-option__button-label__text,
.variant-option__button-label[aria-checked="true"] .variant-option__button-label__text {
  background-color: #1a1a1a !important;
  color: #f8f8f8 !important;
  border-color: #1a1a1a !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
  transform: translateY(-1px);
}

/* Disabled (Out of Stock) */
.variant-option__button-label[aria-disabled="true"] .variant-option__button-label__text {
  background-color: #eee !important;
  color: #888 !important;
  opacity: 0.6 !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
}

/* Layout + spacing */
.variant-picker__option-list {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  justify-content: flex-start !important;
}
/* =========================================================
   🩶 MEIA SIZE PICKER — Fabric Tag Style
   ========================================================= */

.meia-size-picker {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}

.meia-size-picker__title {
  font-family: var(--font-heading, "Inter");
  font-weight: 500;
  letter-spacing: 0.04em;
  font-size: 0.95rem;
  text-transform: uppercase;
  margin-bottom: 0.6rem;
  color: #111;
}

.meia-size-picker__options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.meia-size-picker__tag {
  position: relative;
  cursor: pointer;
  border: 1px solid rgba(0, 0, 0, 0.25);
  border-radius: 40px;
  background-color: #f9f9f8;
  padding: 0.55em 1.4em;
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #111;
  transition: all 0.25s ease;
  user-select: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}

.meia-size-picker__tag:hover {
  background-color: #1a1a1a;
  color: #f8f8f8;
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.meia-size-picker__input {
  display: none;
}

/* Active / selected tag */
.meia-size-picker__input:checked + .meia-size-picker__label,
.meia-size-picker__tag:has(input:checked) {
  background-color: #1a1a1a;
  color: #f8f8f8;
  border-color: #1a1a1a;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  transform: translateY(-1px);
}

/* Text inside label */
.meia-size-picker__label {
  pointer-events: none;
}

/* Mobile refinement */
@media (max-width: 768px) {
  .meia-size-picker__options {
    gap: 8px;
  }
  .meia-size-picker__tag {
    padding: 0.45em 1.1em;
    font-size: 0.85rem;
  }
}
/* =========================================================
   🩶 MEIA SIZE PICKER — Hover Text Visibility Fix
   ========================================================= */

/* Ensure text stays visible when hovered or selected */
.meia-size-picker__tag:hover,
.meia-size-picker__tag:hover .meia-size-picker__label,
.meia-size-picker__tag:has(input:checked),
.meia-size-picker__tag:has(input:checked) .meia-size-picker__label {
  color: #f8f8f8 !important; /* Soft ivory white */
}

/* Also fix for Safari (doesn't support :has) */
.meia-size-picker__input:checked + .meia-size-picker__label {
  color: #f8f8f8 !important;
}
/* =========================================================
   🩶 MEIA POLICY PAGES — Privacy, Terms, Returns, etc.
   ========================================================= */

/* Page Background */
body.template-policy {
  background: #f7f6f4 !important;
  color: #111;
  font-family: var(--font-body, "Inter"), sans-serif;
}

/* Main Container */
.shopify-policy__container {
  max-width: 900px;
  margin: 100px auto;
  background: #fff;
  padding: 60px 70px;
  border-radius: 20px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
  text-align: left;
  line-height: 1.7;
}

/* Title */
.shopify-policy__title {
  font-family: var(--font-heading, "Playfair Display"), serif;
  font-size: clamp(2rem, 3vw, 2.6rem);
  font-weight: 600;
  margin-bottom: 30px;
  color: #111;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  padding-bottom: 10px;
}

/* Body Text */
.shopify-policy__body p {
  font-size: 1rem;
  color: #333;
  margin-bottom: 1.2em;
}

/* Headings inside content */
.shopify-policy__body h2,
.shopify-policy__body h3 {
  font-family: var(--font-heading, serif);
  color: #111;
  margin-top: 1.8em;
  margin-bottom: 0.6em;
  font-size: 1.3rem;
}

/* Links */
.shopify-policy__body a {
  color: #111;
  text-decoration: underline;
  transition: color 0.2s ease;
}
.shopify-policy__body a:hover {
  color: #000;
}

/* Mobile Adjustments */
@media (max-width: 768px) {
  .shopify-policy__container {
    padding: 40px 24px;
    margin: 60px auto;
    border-radius: 12px;
  }
  .shopify-policy__title {
    font-size: 1.8rem;
  }
}
/* =========================================================
   🖤 MEIA — Product Page Fine-Tuning (2025)
   ========================================================= */

/* --- PRODUCT DETAILS --- */
.product-details,
.product-details .group-block {
  font-size: 0.95rem;
  line-height: 1.6;
  letter-spacing: 0.01em;
  color: var(--color-text, #111);
}

.product-details h1,
.product-details h2,
.product-details h3 {
  font-weight: 600;
  line-height: 1.35;
  margin-bottom: 0.4em;
}

.product-details h1 {
  font-size: 1.6rem;
}
.product-details h2 {
  font-size: 1.3rem;
}
.product-details h3 {
  font-size: 1.1rem;
}

/* --- BUTTON REFINEMENT (DESKTOP + MOBILE) --- */
.product-form__buttons button,
.product-form__submit,
.shopify-payment-button__button {
  font-size: 0.9rem !important;
  padding: 0.7em 1.6em !important;
  border-radius: 48px !important;
  letter-spacing: 0.02em;
  font-weight: 500;
  transition: all 0.25s ease;
}

/* --- VARIANT BUTTONS --- */
.variant-option__button-label__text {
  font-size: 0.85rem !important;
  padding: 0.45em 1.2em !important;
  border-radius: 40px !important;
  transition: all 0.2s ease;
}

/* --- PRODUCT MEDIA GALLERY --- */
.product-information__media,
.product-media-gallery,
media-gallery {
  width: 100%;
  max-width: 100%;
  display: block;
  overflow: hidden;
}

.product-media-container img,
.product-media-container video {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 6px;
}

/* --- MOBILE OPTIMIZATION --- */
@media screen and (max-width: 749px) {
  .product-details {
    font-size: 0.85rem !important;
    line-height: 1.5 !important;
  }

  .product-details h1 {
    font-size: 1.2rem !important;
  }

  .product-form__buttons button,
  .product-form__submit,
  .shopify-payment-button__button {
    font-size: 0.8rem !important;
    padding: 0.6em 1.2em !important;
    min-height: 40px !important;
  }

  .variant-option__button-label__text {
    font-size: 0.75rem !important;
    padding: 0.3em 0.9em !important;
  }

  /* Full-width clean gallery */
  .product-information__media,
  .product-media-gallery,
  media-gallery {
    margin: 0 auto;
    width: 100vw;
    max-width: 100vw;
    border-radius: 0;
  }

  /* Prevent cropped product images */
  .product-media-container img {
    object-fit: contain !important;
  }

  /* Reduce vertical spacing */
  .product-information {
    gap: 12px 0;
  }
}
/* =========================================================
   🖤 MEIA — Editorial Product Detail Styling (Slim Layout)
   ========================================================= */

/* --- Base Text --- */
.product-details,
.product-details .group-block {
  font-family: var(--font-body, "Inter", sans-serif);
  font-size: 0.9rem !important; /* smaller body */
  line-height: 1.6 !important;
  color: #111 !important;
  letter-spacing: 0.01em;
}

/* --- Titles & Price --- */
.product-details h1 {
  font-size: 1.15rem !important;
  font-weight: 500 !important;
  line-height: 1.3 !important;
  margin-bottom: 0.4em !important;
}

.product-details .price,
.product-details .product__price {
  font-size: 0.95rem !important;
  font-weight: 400 !important;
  color: #111 !important;
}

/* --- Labels (Color / Pattern / Size Chart) --- */
.product-details label,
.product-details .variant-picker__option-label,
.product-details .product-form__label {
  font-size: 0.8rem !important;
  font-weight: 400 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: #111 !important;
}

/* --- Variant Buttons (Size / Color) --- */
.variant-option__button-label__text {
  font-size: 0.75rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em;
  padding: 0.4em 0.9em !important;
  border-radius: 50px !important;
  border: 1px solid #ccc !important;
  background: #fff !important;
  transition: all 0.25s ease;
}

.variant-option__button-label__text:hover,
.variant-option__button-label__text[aria-pressed="true"] {
  background: #111 !important;
  color: #fff !important;
  border-color: #111 !important;
}

/* --- Add to Cart Button --- */
.product-form__buttons button,
.product-form__submit,
.shopify-payment-button__button {
  background-color: #111 !important;
  color: #fff !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  text-transform: none !important;
  border-radius: 4px !important;
  padding: 0.7em 1.2em !important;
  height: auto !important;
  letter-spacing: 0.02em !important;
  transition: background-color 0.25s ease;
}

.product-form__buttons button:hover,
.product-form__submit:hover {
  background-color: #333 !important;
}

/* --- Accordion (Description Tabs) --- */
.accordion,
.accordion .accordion__header {
  font-size: 0.85rem !important;
  letter-spacing: 0.01em;
}

.accordion .accordion__content {
  font-size: 0.85rem !important;
  line-height: 1.6;
}

/* --- Mobile Refinement --- */
@media screen and (max-width: 749px) {
  .product-details {
    font-size: 0.85rem !important;
    line-height: 1.5 !important;
  }

  .product-details h1 {
    font-size: 1rem !important;
  }

  .variant-option__button-label__text {
    font-size: 0.7rem !important;
    padding: 0.35em 0.8em !important;
  }

  .product-form__buttons button,
  .product-form__submit {
    font-size: 0.8rem !important;
    padding: 0.6em 1em !important;
    border-radius: 3px !important;
  }

  .product-details .price {
    font-size: 0.9rem !important;
  }
}
/* =========================================================
   🖤 MEIA PRODUCT FORM — COMPACT LUXURY ADJUSTMENT
   Matches client reference (small text, smaller buttons)
   ========================================================= */

/* Size Picker (smaller & tighter layout) */
.meia-size-picker__title {
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em;
  text-transform: none !important;
  margin-bottom: 0.5rem !important;
  color: #111 !important;
}

.meia-size-picker__options {
  gap: 6px !important;
}

.meia-size-picker__tag {
  padding: 0.35em 1em !important;
  font-size: 0.75rem !important;
  border-radius: 40px !important;
  letter-spacing: 0.02em !important;
  font-weight: 400 !important;
  background-color: #f9f9f8 !important;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
  transition: all 0.25s ease;
}

.meia-size-picker__tag:hover,
.meia-size-picker__input:checked + .meia-size-picker__label,
.meia-size-picker__tag:has(input:checked) {
  background-color: #111 !important;
  color: #fff !important;
  border-color: #111 !important;
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
}

.meia-size-picker__label {
  font-size: 0.75rem !important;
  font-weight: 400 !important;
}

/* Quantity Selector (matching height to size buttons) */
.product-form__input--quantity,
.quantity__wrapper,
.meia-quantity {
  display: inline-flex !important;
  align-items: center;
  border: 1px solid rgba(0,0,0,0.25) !important;
  border-radius: 40px !important;
  background-color: #f9f9f8 !important;
  height: 34px !important;
  overflow: hidden;
}

.quantity__button,
.meia-quantity__button {
  background: none !important;
  border: none !important;
  width: 28px !important;
  height: 34px !important;
  font-size: 0.75rem !important;
  color: #111 !important;
  cursor: pointer;
  transition: background 0.2s ease;
}

.quantity__button:hover,
.meia-quantity__button:hover {
  background-color: #eaeaea !important;
}

.quantity__input,
.meia-quantity__input {
  width: 40px !important;
  font-size: 0.75rem !important;
  text-align: center;
  border: none !important;
  background: transparent !important;
  outline: none !important;
  color: #111 !important;
}

/* Add to Cart / Buy Now Buttons — compact minimal */
.product-form__submit,
.shopify-payment-button__button,
.shopify-payment-button__button--unbranded {
  font-size: 0.8rem !important;
  padding: 0.6em 1.2em !important;
  border-radius: 40px !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  text-transform: none !important;
  background-color: #111 !important;
  color: #fff !important;
  transition: all 0.25s ease;
  box-shadow: none !important;
}

.product-form__submit:hover,
.shopify-payment-button__button:hover {
  background-color: #333 !important;
  transform: translateY(-1px);
}

/* Alignment and spacing cleanup */
.product-form__buttons {
  gap: 10px !important;
  margin-top: 1rem !important;
}

.product-form__input {
  margin-bottom: 0.5rem !important;
}

/* --- Mobile scaling (below 768px) --- */
@media (max-width: 768px) {
  .meia-size-picker__tag {
    padding: 0.3em 0.9em !important;
    font-size: 0.7rem !important;
  }

  .quantity__wrapper {
    height: 30px !important;
  }

  .quantity__button {
    width: 26px !important;
    height: 30px !important;
    font-size: 0.7rem !important;
  }

  .quantity__input {
    width: 32px !important;
    font-size: 0.7rem !important;
  }

  .product-form__submit {
    font-size: 0.75rem !important;
    padding: 0.5em 1em !important;
  }
}
/* =========================================================
   🖤 MEIA QUANTITY SELECTOR — Compact & Minimal
   ========================================================= */

.quantity-selector {
  display: inline-flex !important;
  align-items: center !important;
  border: 1px solid rgba(0, 0, 0, 0.25) !important;
  border-radius: 50px !important;
  background-color: #f9f9f8 !important;
  overflow: hidden;
  height: 34px !important;
  width: fit-content !important;
  transition: all 0.25s ease;
}

.quantity-selector:hover {
  border-color: #111 !important;
}

/* Buttons */
.quantity-minus,
.quantity-plus {
  background: none !important;
  border: none !important;
  width: 34px !important;
  height: 34px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: background 0.25s ease, transform 0.2s ease;
  padding: 0 !important;
}

.quantity-minus:hover,
.quantity-plus:hover {
  background-color: #ececec !important;
  transform: translateY(-1px);
}

/* Icon size inside buttons */
.quantity-minus .svg-wrapper svg,
.quantity-plus .svg-wrapper svg {
  width: 12px !important;
  height: 12px !important;
  stroke-width: 1.8;
}

/* Input field */
.quantity-selector input[type="number"] {
  font-size: 0.75rem !important;
  font-weight: 400 !important;
  color: #111 !important;
  text-align: center !important;
  width: 44px !important;
  height: 34px !important;
  border: none !important;
  outline: none !important;
  background: transparent !important;
  appearance: textfield !important;
}

/* Remove spinner arrows (Chrome / Firefox) */
.quantity-selector input::-webkit-outer-spin-button,
.quantity-selector input::-webkit-inner-spin-button {
  -webkit-appearance: none !important;
  margin: 0 !important;
}
.quantity-selector input[type=number] {
  -moz-appearance: textfield !important;
}

/* --- Mobile compact adjustment --- */
@media (max-width: 768px) {
  .quantity-selector {
    height: 30px !important;
  }

  .quantity-minus,
  .quantity-plus {
    width: 28px !important;
    height: 30px !important;
  }

  .quantity-selector input[type="number"] {
    font-size: 0.7rem !important;
    width: 36px !important;
  }

  .quantity-minus .svg-wrapper svg,
  .quantity-plus .svg-wrapper svg {
    width: 10px !important;
    height: 10px !important;
  }
}
/* =========================================================
   🖤 MEIA ADD TO CART — Compact Minimal Fix (Radiant Theme)
   ========================================================= */

/* Base button */
.add-to-cart-button.button,
.add-to-cart-button.button-secondary,
.button.add-to-cart-button {
  background-color: #111 !important;
  color: #fff !important;
  border: none !important;
  border-radius: 40px !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  text-transform: none !important;
  padding: 0.6em 1.4em !important;
  min-height: 36px !important;
  height: auto !important;
  width: 100% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5em !important;
  transition: background-color 0.25s ease, transform 0.25s ease;
  box-shadow: none !important;
}

/* Hover / active state */
.add-to-cart-button.button:hover,
.add-to-cart-button.button-secondary:hover {
  background-color: #333 !important;
  color: #fff !important;
  transform: translateY(-1px);
}

/* Icon adjustments */
.add-to-cart-icon svg,
.add-to-cart-icon--added svg {
  width: 12px !important;
  height: 12px !important;
  stroke-width: 1.8;
  margin-right: 2px !important;
}

/* Text styling */
.add-to-cart-text__content {
  font-size: 0.8rem !important;
  letter-spacing: 0.03em !important;
}

/* Added state styling (checkmark) */
.atc-added .add-to-cart-button {
  background-color: #111 !important;
  color: #fff !important;
  transform: none !important;
}

/* Disabled button */
.add-to-cart-button[disabled] {
  opacity: 0.5 !important;
  cursor: not-allowed !important;
  background-color: #000 !important;
  color: #fff !important;
}

/* --- Mobile refinement --- */
@media (max-width: 749px) {
  .add-to-cart-button.button,
  .add-to-cart-button.button-secondary {
    font-size: 0.75rem !important;
    padding: 0.5em 1.2em !important;
    min-height: 34px !important;
  }

  .add-to-cart-icon svg,
  .add-to-cart-icon--added svg {
    width: 10px !important;
    height: 10px !important;
  }
}
/* =========================================================
   🩶 MEIA ADD TO CART — Text & Icon Color Override Fix
   ========================================================= */

/* Force white text and icon color inside the button */
.add-to-cart-button.button,
.add-to-cart-button.button-secondary,
.button.add-to-cart-button {
  color: #fff !important;
  --color-button-text: #fff !important;
  --color-primary-button-text: #fff !important;
  --color-primary-button-hover-text: #fff !important;
}

/* Inner text elements */
.add-to-cart-button .add-to-cart-text,
.add-to-cart-button .add-to-cart-text__content,
.add-to-cart-button .add-to-cart-text--added,
.add-to-cart-button span,
.add-to-cart-button svg,
.add-to-cart-button path {
  color: #fff !important;
  fill: #fff !important;
  stroke: #fff !important;
}

/* Ensure hover keeps white text */
.add-to-cart-button.button:hover,
.add-to-cart-button.button-secondary:hover {
  color: #fff !important;
}

.add-to-cart-button:hover span,
.add-to-cart-button:hover svg,
.add-to-cart-button:hover path {
  color: #fff !important;
  fill: #fff !important;
  stroke: #fff !important;
}

/* Added/checked state (when item is added) */
.atc-added .add-to-cart-button,
.atc-added .add-to-cart-text--added {
  color: #fff !important;
  fill: #fff !important;
  stroke: #fff !important;
}
/* =========================================================
   🩶 MEIA Quick Add Modal — Mobile Product Image Centering
   ========================================================= */
@media (max-width: 749px) {
  /* Container sizing */
  .quick-add-modal,
  .product-quick-add__content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center !important;
  }

  /* Product image wrapper */
  .quick-add-modal__media,
  .product-quick-add__media,
  .product__media,
  .product-media,
  .media-gallery,
  .media-gallery__item {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0 auto !important;
    max-width: 90% !important;
    height: auto !important;
  }

  /* Product image element */
  .quick-add-modal__media img,
  .product-quick-add__media img,
  .product-media img,
  .media-gallery__item img {
    width: auto !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: 50vh !important;
    object-fit: contain !important;
    margin: 0 auto !important;
    display: block !important;
  }

  /* Optional: add gentle drop shadow + rounded corners */
  .quick-add-modal__media img {
    border-radius: 12px !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.15);
  }

  /* Tighten up spacing under the image */
  .product-quick-add__content .product-details,
  .quick-add-modal__details {
    margin-top: 1rem !important;
  }
}
/* =========================================================
   🖤 MEIA — Product Grid Mobile Edge-to-Edge Image Fix
   ========================================================= */
@media screen and (max-width: 749px) {
  /* Ensure the product grid uses full width */
  .collection .product-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    padding: 0 !important;
    margin: 0 auto !important;
    width: 100% !important;
  }

  /* Product card spans full width */
  .product-card,
  .product-grid__card {
    width: 100% !important;
    max-width: 100% !important;
    background: transparent !important;
    padding: 0 !important;
    border: none !important;
  }

  /* Gallery / image wrapper fills the whole card */
  .card-gallery,
  .product-card__media,
  .product-media-container {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: auto !important;
    overflow: hidden !important;
    border-radius: 0 !important;
  }

  /* The actual product image */
  .card-gallery img,
  .product-card__media img,
  .product-media-container img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }

  /* Center product title and price neatly below image */
  .product-grid__card .h4,
  .product-grid__card .h6 {
    text-align: center !important;
    margin-top: 10px !important;
  }
}
/* =========================================================
   🖤 MEIA — Product Card Container Resize Fix (Mobile Final)
   ========================================================= */
@media screen and (max-width: 749px) {
  /* Make grid single-column and give breathing room */
  .collection .product-grid {
    grid-template-columns: 1fr !important;
    gap: 34px !important;
    padding: 10px 0 !important;
    margin: 0 auto !important;
    width: 100% !important;
  }

  /* Product card container — taller and fuller */
  .product-grid__item,
  .product-card,
  .product-grid__card {
    width: 100% !important;
    max-width: 100% !important;
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 auto !important;
    height: auto !important;
  }

  /* Make card gallery height proportional to screen width */
  .card-gallery,
  .product-card__media,
  .product-media-container {
    width: 100% !important;
    aspect-ratio: 4 / 5 !important; /* taller portrait layout */
    overflow: hidden !important;
    border-radius: 0 !important;
  }

  /* Keep images proportional inside container */
  .card-gallery img,
  .product-card__media img,
  .product-media-container img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    margin: 0 auto !important;
  }

  /* Titles and prices spacing under image */
  .product-grid__card .h4,
  .product-grid__card .h6 {
    text-align: center !important;
    margin-top: 10px !important;
  }
}

/* === MEIA FOOTER — Final Balanced White Layout === */
.meia-footer {
  background: #fff;
  border-top: 1px solid #e6e4e0;
  color: #111;
  font-family: var(--font-body), sans-serif;
  padding: 70px 0 40px;
}

.meia-footer .mw-wrap {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
}

/* 3-column grid (desktop) */
.meia-footer__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  align-items: start;
  justify-items: center;
  gap: 60px;
  margin-bottom: 60px;
  text-align: center;
}

/* Newsletter */
.newsletter-center h3 {
  font-family: var(--font-heading), sans-serif;
  font-weight: 600;
  font-size: 1rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.newsletter-center p {
  font-style: italic;
  color: #666;
  margin-bottom: 20px;
  font-size: 0.9rem;
}

/* Newsletter form */
.meia-footer__form {
  display: inline-flex;
  align-items: center;
  background: #fff;
  border: 1px solid #dcdcdc;
  border-radius: 4px;
  overflow: hidden;
  max-width: 360px;
  width: 100%;
}

.meia-footer__form input {
  flex: 1;
  border: none;
  padding: 12px 16px;
  font-size: 0.9rem;
  outline: none;
  background: transparent;
}

.meia-footer__form button {
  background: none;
  border: none;
  padding: 0 18px;
  font-size: 1.2rem;
  color: #111;
  cursor: pointer;
  transition: transform 0.2s ease;
}

.meia-footer__form button:hover {
  transform: translateX(3px);
}

/* Newsletter messages */
.newsletter-success {
  color: #2e7d32;
  font-size: 0.85rem;
  margin-top: 8px;
}

.newsletter-error {
  color: #d32f2f;
  font-size: 0.85rem;
  margin-top: 8px;
}

/* Care + Follow columns */
.footer-column {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.footer-column h4 {
  font-family: var(--font-heading), sans-serif;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 600;
  color: #777;
  margin-bottom: 10px;
}

.footer-column a {
  text-decoration: none;
  font-size: 0.9rem;
  color: #333;
  transition: color 0.2s ease;
}

.footer-column a:hover {
  color: #000;
  text-decoration: underline;
}

/* Copyright */
.meia-footer__bottom {
  text-align: center;
  border-top: 1px solid #efefef;
  padding-top: 20px;
  font-size: 0.85rem;
  color: #777;
}

/* === Responsive === */
@media (max-width: 900px) {
  .meia-footer {
    padding: 50px 0 30px;
  }

  .meia-footer__grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .footer-column,
  .newsletter-center {
    text-align: center;
  }

  .meia-footer__form {
    max-width: 100%;
  }

  .newsletter-center h3 {
    font-size: 0.95rem;
  }

  .newsletter-center p {
    font-size: 0.85rem;
  }
}

/* === MEIA FEATURE ROW — Fixed Minimalist Layout === */
.meia-feature-row {
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  background: #fff;
  padding: 26px 0;
}

.meia-feature-row__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: nowrap;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
  box-sizing: border-box;
}

.meia-feature {
  flex: 1;
  min-width: 160px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.meia-feature img {
  width: 26px;
  height: 26px;
  object-fit: contain;
  opacity: 0.9;
}

.meia-feature p {
  margin: 0;
  font-family: var(--font-heading), sans-serif;
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #111;
  line-height: 1.4;
}

/* Divider */
.meia-feature-divider {
  display: block;
  width: 1px;
  height: 30px;
  background-color: #d8d8d8;
}

/* Responsive */
@media (max-width: 768px) {
  .meia-feature-row__wrap {
    flex-wrap: nowrap;
    gap: 0;
    padding: 0 1rem;
  }

  .meia-feature img {
    width: 24px;
    height: 24px;
  }

  .meia-feature p {
    font-size: 0.78rem;
  }
}
/* === MEIA SECTION BACKGROUND FIX === */
.meia-aboutus-simple,
.meia-faq,
.meia-contact,
.page-content,
.shopify-section {
  background-color: #ffffff !important;
}

/* if you use CSS variable backgrounds */
.meia-aboutus-simple,
.meia-faq,
.meia-contact {
  --bg: #ffffff !important;
}
/* === Force About, Contact, and FAQ sections to white === */
.meia-aboutus-simple,
.meia-contact,
.meia-faq {
  background: #ffffff !important;
  --bg: #ffffff !important;
}
/* === MEIA FEATURE ROW — Mobile Overflow Fix === */
.meia-feature-row__wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap !important;  /* allow wrapping on mobile */
  overflow: hidden;
  gap: 32px 24px;              /* balanced spacing when wrapped */
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
  box-sizing: border-box;
}

/* prevent horizontal scroll */
.meia-feature-row {
  overflow-x: hidden !important;
}

/* adjust divider behavior */
.meia-feature-divider {
  display: block;
  width: 1px;
  height: 24px;
  background-color: #dcdcdc;
}

@media (max-width: 768px) {
  .meia-feature-row__wrap {
    flex-wrap: wrap !important;
    gap: 16px 24px;
  }

  .meia-feature-divider {
    display: none; /* hide dividers on small screens */
  }

  .meia-feature {
    flex: 1 1 45%; /* two per row on phones */
    min-width: 140px;
  }
}

/* === MEIA MENU — revert to natural layout (stable build) === */
.meia-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: auto !important;          /* no vh forcing */
  max-height: 100%;                 /* respect viewport naturally */
  transform: translateX(-100%);
  transition: transform 0.4s ease-in-out;
  overflow: visible !important;     /* prevents internal clipping */
  background: transparent;
  z-index: 9999;
}
.meia-menu.open {
  transform: translateX(0);
}

/* main panel inside drawer */
.meia-menu-panel {
  background: #fff;
  padding: 16px 22px 22px 14px !important; /* small top/left, soft bottom */
  border-radius: 0 16px 16px 0;            /* right side curved only */
  box-shadow: none;
  height: auto !important;                 /* let it size to content */
  min-height: unset !important;
  max-height: none !important;
  overflow: visible !important;            /* no scroll cutoff */
  box-sizing: border-box;
}

/* nav alignment flush to edges */
.meia-menu__inner,
.meia-nav,
.meia-nav ul {
  margin: 0 !important;
  padding: 0 !important;
  list-style: none;
}

/* make sure no shadow/after element adds visual strip */
.meia-menu::after,
.meia-menu-panel::after {
  display: none !important;
  content: none !important;
}

html, body {
  overflow-x: hidden !important;
}
/* =========================================================
   🖤 MEIA POLICY SECTION STYLE — Theme Customizer Controlled
   ========================================================= */

.meia-policy-section {
  background-color: #fff;
  color: var(--color-text, #111);
  padding: 80px 20px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  box-sizing: border-box;
}

.policy-wrapper {
  max-width: 820px;
  width: 100%;
}

.policy-title {
  font-family: var(--font-heading--family, var(--font-heading, serif));
  font-size: calc(var(--font-heading--scale, 1) * 1.6rem);
  font-weight: 600;
  text-transform: uppercase;
  text-align: center;
  color: var(--color-heading, #111);
  margin-bottom: 2rem;
  letter-spacing: 0.03em;
}

.policy-text {
  font-family: var(--font-body--family, var(--font-body, sans-serif));
  font-size: var(--font-body--size, 1rem);
  line-height: 1.75;
  letter-spacing: 0.01em;
  color: var(--color-text, #111);
}

.policy-text h3 {
  font-family: var(--font-heading--family, var(--font-heading, serif));
  font-weight: 600;
  margin-top: 1.8rem;
  margin-bottom: 0.8rem;
  font-size: 1.1rem;
  color: var(--color-heading, #111);
}

.policy-text ul {
  margin-left: 1.2rem;
  list-style-type: disc;
}

.policy-text a {
  color: var(--color-text, #111);
  text-decoration: underline;
  transition: color 0.2s ease;
}

.policy-text a:hover {
  color: rgba(0, 0, 0, 0.6);
}

/* Mobile */
@media screen and (max-width: 768px) {
  .meia-policy-section {
    padding: 60px 16px;
  }
  .policy-title {
    font-size: calc(var(--font-heading--scale, 1) * 1.3rem);
    margin-bottom: 1.5rem;
  }
  .policy-text {
    font-size: calc(var(--font-body--size, 1rem) * 0.95);
    line-height: 1.7;
  }
}
/* === MEIA FAQ SECTION — remove container background & shadow === */
.meia-faq-section {
  background: #ffffff !important;   /* pure white background */
  box-shadow: none !important;      /* remove drop shadow */
  border-radius: 0 !important;      /* remove corner rounding */
  margin: 100px auto !important;    /* keep spacing consistent */
  padding: 60px 50px !important;    /* preserve internal spacing */
}
