/** Shopify CDN: Minification failed

Line 4545:18 Unexpected "{"
Line 4545:27 Expected ":"
Line 7821:0 Unexpected "}"
Line 8132:0 Unexpected "}"
Line 8516:1 Expected "}" to go with "{"

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.product-card,
.collection-card,
.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);
  z-index: var(--layer-flat);
}

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

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

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

  text-align: left;
}

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

  text-align: center;
}

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

  text-align: right;
}

.text-inherit {
  color: inherit;
}

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

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

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

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

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

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

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

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

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

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

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

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

.relative {
  position: relative;
}

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

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

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

.icon-default {
  fill: currentColor;
}

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

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

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

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

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

/* Typography presets */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    footer {
      view-transition-name: footer;
    }

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

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

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

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

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

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

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

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

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

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

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

.text-block {
  width: 100%;
}

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

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

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

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

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

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

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

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

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

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

  &::backdrop {
    opacity: 0;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

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

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

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

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

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

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

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

/* Collapsible row */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[open] {
    opacity: 1;
  }

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

  &::backdrop {
    background: transparent;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.card-gallery {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  animation-duration: 0.6s;
}

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

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

  animation-duration: 0.8s;
}

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

  5% {
    opacity: 1;
  }

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

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

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

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

/*
 * Slideshow Component
 */
slideshow-component {
  --cursor: grab;
  --slide-offset: 6px;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

  50% {
    opacity: 1;
  }

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

/* Prevent iOS zoom on input focus by ensuring minimum 16px font size on mobile */
@media screen and (max-width: 1200px) {
  input,
  textarea,
  select,
  /* Higher specificity to override type preset classes like .paragraph, .h1, etc. */
  .paragraph.paragraph input,
  .paragraph.paragraph textarea,
  .paragraph.paragraph select,
  .h1.h1 input,
  .h1.h1 textarea,
  .h1.h1 select,
  .h2.h2 input,
  .h2.h2 textarea,
  .h2.h2 select,
  .h3.h3 input,
  .h3.h3 textarea,
  .h3.h3 select,
  .h4.h4 input,
  .h4.h4 textarea,
  .h4.h4 select,
  .h5.h5 input,
  .h5.h5 textarea,
  .h5.h5 select,
  .h6.h6 input,
  .h6.h6 textarea,
  .h6.h6 select {
    font-size: max(1rem, 100%);
  }
}
/* ===== BANNIÈRE ECLORA ===== */

#shopify-section-template--27121489543494__hero_p9CmMG {
  background-color: #F3EEE8;
}

/* Bloc texte */
#shopify-section-template--27121489543494__hero_p9CmMG .banner__box {
  max-width: 520px;
}

/* Titre */
#shopify-section-template--27121489543494__hero_p9CmMG .banner__heading {
  font-family: "Playfair Display", serif;
  font-size: 52px;
  font-weight: 500;
  line-height: 1.1;
  color: #3F3A37;
  margin-bottom: 16px;
}

/* Sous-titre */
#shopify-section-template--27121489543494__hero_p9CmMG .banner__text,
#shopify-section-template--27121489543494__hero_p9CmMG .banner__text p {
  font-family: "Montserrat", sans-serif;
  font-size: 18px;
  color: #6E6661;
  margin-bottom: 24px;
}

/* Bouton */
#shopify-section-template--27121489543494__hero_p9CmMG .button {
  background-color: #C97C5D;
  color: #ffffff;
  border-radius: 12px;
  padding: 14px 28px;
  font-family: "Montserrat", sans-serif;
  font-size: 16px;
  border: none;
  transition: all 0.3s ease;
}

#shopify-section-template--27121489543494__hero_p9CmMG .button:hover {
  background-color: #B96A4D;
  transform: translateY(-2px);
}

/* Ajustement image (évite mauvaise coupe) */
#shopify-section-template--27121489543494__hero_p9CmMG .banner__media img {
  object-position: center right;
}

/* Responsive mobile */
@media screen and (max-width: 749px) {
  #shopify-section-template--27121489543494__hero_p9CmMG .banner__heading {
    font-size: 34px;
  }

  #shopify-section-template--27121489543494__hero_p9CmMG .banner__text,
  #shopify-section-template--27121489543494__hero_p9CmMG .banner__text p {
    font-size: 16px;
  }/* ===== HERO TEXTE GAUCHE OPTIMISÉ ===== */
#shopify-section-template--27121489543494__hero_p9CmMG .group-block{
  max-width:520px;
  padding:60px 0 !important;
}

#shopify-section-template--27121489543494__hero_p9CmMG h1,
#shopify-section-template--27121489543494__hero_p9CmMG h2{
  font-size:56px !important;
  line-height:1.15 !important;
  margin-bottom:22px !important;
  letter-spacing:-0.5px;
}

#shopify-section-template--27121489543494__hero_p9CmMG p{
  font-size:18px !important;
  margin-bottom:32px !important;
  opacity:0.9;
}

#shopify-section-template--27121489543494__hero_p9CmMG .button{
  padding:14px 32px !important;
  border-radius:6px !important;
  font-size:15px !important;
}
/* ECLORA — Fix centrage image mobile (anti full-bleed) */
@media (max-width: 990px){

  /* le conteneur media doit rester dans la largeur du container */
  .eclora-hero__media{
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    overflow: hidden !important; /* coupe tout débordement */
  }

  /* neutralise les styles "100vw / centré viewport" */
  .eclora-hero__media img{
    display: block !important;

    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;

    margin: 0 auto !important;

    position: static !important;
    left: auto !important;
    right: auto !important;

    transform: none !important; /* annule translateX/translateY */
  }
}
/* ECLORA — Mobile: décaler le texte vers la gauche */
@media (max-width: 990px){
  .eclora-section.eclora-hero .eclora-hero__content{
    transform: translateX(0px) !important; /* ajuste -6px à -18px */
  }
}
/* ECLORA — Mobile: décaler les boutons vers la gauche */
@media (max-width: 990px){
  .eclora-section.eclora-hero .eclora-hero__actions{
    transform: translateX(35px) !important; /* même valeur que le texte */
  }
}
/* ECLORA — Mobile: remonter le hero */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-container{
    padding-top: 12px !important;   /* ajuste entre 12px et 28px */
  }

}
@media (max-width: 990px){
  .template-index .eclora-section.eclora-hero{
    margin-top: 0 !important;
  }
}
body {
  outline: 3px solid red;
}
/* ECLORA — Supprimer espace ajouté par header sticky */
@media (max-width: 990px){

  body{
    padding-top: 0 !important;
  }

  .shopify-section:first-of-type{
    margin-top: 0 !important;
  }

}
@media (max-width: 990px){

  .header,
  .site-header{
    margin-bottom: 0 !important;
  }

}
/* ECLORA — Mobile: centrer le trait du kicker */
@media (max-width: 990px){

  .eclora-kicker{
    justify-content: center !important;
    text-align: center !important;
  }

  .eclora-kicker::before{
    margin-left: -10px !important;
  }

}
/* ECLORA — Mobile: recentrer le trait du kicker malgré le décalage du texte */
@media (max-width: 990px){

  /* tu as décalé .eclora-hero__content de -12px,
     donc on re-décale le kicker de +12px */
  .eclora-section.eclora-hero .eclora-kicker{
    transform: translateX(12px) !important; /* <- mets la même valeur que ton -12px */
    text-align: center !important;
  }

  /* si le trait est en pseudo-element */
  .eclora-section.eclora-hero .eclora-kicker::before,
  .eclora-section.eclora-hero .eclora-kicker::after{
    transform: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
/* ECLORA — Mobile: trait centré sous "MAISON FLORALE" */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-kicker{
    display: inline-block !important;
    width: 100% !important;
    text-align: center !important;
    position: relative;
  }

  /* On neutralise d'éventuels traits existants */
  .eclora-section.eclora-hero .eclora-kicker::before{
    content: none !important;
  }

  /* On recrée un trait centré, propre */
  .eclora-section.eclora-hero .eclora-kicker::after{
    content: "" !important;
    display: block !important;
    width: 56px;                 /* ajuste 40–70px */
    height: 1px;
    margin: 10px auto 0 auto !important;  /* centre le trait */
    background: rgba(159,95,84,.35);
  }
}
/* ECLORA — Mobile: supprimer l'ancien trait (thème) */
@media (max-width: 990px){

  /* Si le trait vient d'une bordure sur le kicker ou son wrapper */
  .eclora-section.eclora-hero .eclora-kicker{
    border: 0 !important;
    background-image: none !important;
  }

  /* Si le thème ajoute un "separator" via pseudo-element sur le contenu */
  .eclora-section.eclora-hero .eclora-hero__content::before,
  .eclora-section.eclora-hero .eclora-hero__content::after{
    content: none !important;
    border: 0 !important;
    background: none !important;
  }

  /* Si le thème insère un <hr> ou un séparateur */
  .eclora-section.eclora-hero hr,
  .eclora-section.eclora-hero .separator,
  .eclora-section.eclora-hero .divider{
    display: none !important;
  }
}
/* ECLORA — Mobile: éviter que le kicker remonte sur l'image */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-hero__media{
    margin-bottom: 1px !important; /* ajuste 10–18px */
  }

  /* sécurité: enlever toute marge négative éventuelle */
  .eclora-section.eclora-hero .eclora-kicker{
    margin-top: 0 !important;
  }
}
/* ECLORA — Mobile: empêcher le texte/kicker de remonter sur l'image */
@media (max-width: 990px){

  /* Le media doit avoir une vraie hauteur */
  .eclora-section.eclora-hero .eclora-hero__media{
    position: relative !important;
    width: 100% !important;
    overflow: hidden !important;
    border-radius: 16px; /* optionnel si tu veux que le conteneur porte le radius */
  }

  /* IMPORTANT: remettre l'image dans le flux (si le thème la met en absolute) */
  .eclora-section.eclora-hero .eclora-hero__media img{
    position: static !important;   /* <- clé */
    display: block !important;
    width: 100% !important;

    height: clamp(260px, 46vh, 420px) !important; /* ton réglage */
    object-fit: cover !important;
    object-position: center !important;

    border-radius: 11px; /* si tu préfères radius sur l'image */
  }

  /* Espace garanti entre image et kicker */
  .eclora-section.eclora-hero .eclora-kicker{
    margin-top: 14px !important;
  }
}
/* ECLORA — Mobile: enlever le dernier micro-chevauchement image/kicker */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-hero__media{
    margin-bottom: 24px !important; /* monte à 20–24px si besoin */
  }

  .eclora-section.eclora-hero .eclora-kicker{
    margin-top: 0 !important;
    padding-top: 2px !important; /* micro-espace de sécurité */
  }
}
@media (max-width: 990px){
  .eclora-section.eclora-hero .eclora-hero__media{ margin-bottom: 22px !important; }
}
/* ECLORA — Mobile: séparation nette image / kicker (fix final) */
@media (max-width: 990px){

  /* Assure que l'image est dans son propre flux */
  .eclora-section.eclora-hero .eclora-hero__media{
    margin-bottom: 24px !important;  /* espace réel */
  }

  /* Le kicker doit être clairement en dessous */
  .eclora-section.eclora-hero .eclora-kicker{
    display: block !important;
    margin-top: 0 !important;
    line-height: 1.2 !important;
  }

  /* Si le trait est en pseudo-element */
  .eclora-section.eclora-hero .eclora-kicker::after{
    margin-top: 10px !important;
  }

}
@media (max-width: 990px){
  .eclora-section.eclora-hero .eclora-kicker{
    position: static !important;
  }
}
/* ECLORA — Mobile: baisser légèrement le kicker */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-kicker{
    margin-top: 30px !important;  /* ajuste 6px → 14px selon rendu */
  }

}
/* ECLORA — Mobile: baisser le kicker (méthode fiable) */
@media (max-width: 990px){
  .eclora-section.eclora-hero .eclora-kicker{
    position: relative !important;
    top: 10px !important;           /* ajuste 6px → 16px */
    margin-top: 0 !important;       /* on neutralise les marges */
  }
}
/* ECLORA — Mobile: remonter légèrement la photo */
@media (max-width: 990px){

  .eclora-section.eclora-hero .eclora-hero__media{
    position: relative !important;
    top: -25px !important;   /* ajuste -6px → -16px */
  }

}
@media (max-width: 990px){

  .eclora-hero__title{
    margin-bottom: 16px !important;
  }

  .eclora-hero__text{
    margin-bottom: 22px !important;
  }

}
@media (max-width: 990px){

  .eclora-hero__title{
    margin-bottom: 16px !important;
  }

  .eclora-hero__text{
    margin-bottom: 22px !important;
  }

}
@media (max-width: 990px){

  .eclora-hero__content{
    max-width: 32ch !important;
  }

}
@media (max-width: 990px){

  .eclora-hero__content{
    text-align: left !important;
    max-width: 32ch !important;
  }

  .eclora-hero__actions{
    justify-content: flex-start !important;
  }

}
/* ECLORA — Mobile: passer le texte en alignement gauche (override fort) */
@media (max-width: 990px){

  /* Annule les décalages que tu avais mis pour centrer/décaler */
  .eclora-section.eclora-hero .eclora-hero__content,
  .eclora-section.eclora-hero .eclora-hero__actions,
  .eclora-section.eclora-hero .eclora-kicker{
    transform: none !important;
    left: auto !important;
    right: auto !important;
  }

  /* Force l'alignement du bloc texte */
  .eclora-section.eclora-hero .eclora-hero__content{
    text-align: left !important;
    max-width: 32ch !important;     /* look éditorial (ajuste 30–36ch) */
    margin-left: 0 !important;
    margin-right: auto !important;
  }

  /* Empêche les enfants d'être recentrés par margin:auto */
  .eclora-section.eclora-hero .eclora-hero__title,
  .eclora-section.eclora-hero .eclora-hero__text{
    text-align: left !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  /* Boutons à gauche */
  .eclora-section.eclora-hero .eclora-hero__actions{
    justify-content: flex-start !important;
  }
}
.eclora-hero h1 {
  line-height: 1.15;
  letter-spacing: -0.01em;
}
/* ---------------------------
   ECLORA HERO — Title lines
---------------------------- */
.eclora-hero .eclora-hero__title-line{
  display: block;               /* force la ligne */
}

/* Premium tuning */
.eclora-hero .eclora-hero__title{
  line-height: 1.12;
  letter-spacing: -0.01em;
  margin: 0;
}

/* Optionnel : espace entre les lignes (très subtil) */
.eclora-hero .eclora-hero__title-line + .eclora-hero__title-line{
  margin-top: 0.06em;
}
/* ===========================
   ECLORA HERO — H1 sizing
   =========================== */

/* Mobile */
.eclora-hero .eclora-hero__title{ font-size: 22px !important; }
  font-size: 10px;        /* ajuste ici si besoin */
  line-height: 1.08;
  letter-spacing: -0.02em;
}

/* Si ton thème force un max-width bizarre, on stabilise la lecture */
.eclora-hero .eclora-hero__content{
  max-width: 36rem;
}

/* Tablette */
@media (min-width: 768px){
  .eclora-hero .eclora-hero__title{
    font-size: 56px;
    line-height: 1.06;
  }
}

/* Desktop */
@media (min-width: 990px){
  .eclora-hero .eclora-hero__title{
    font-size: 64px;
    line-height: 1.06;
  }
}
/* Force taille sur le H1 + sur les lignes (spans) */
.eclora-hero .eclora-hero__title,
.eclora-hero .eclora-hero__title-line{
  font-size: 41px !important;
  line-height: 1.08 !important;
  letter-spacing: -0.02em !important;
}
/* ECLORA HERO — espace sous le titre */
.eclora-hero .eclora-hero__title{
  margin-bottom: 36px; /* ajuste entre 24 et 36px */
}

/* Option plus précise : contrôler directement le texte */
.eclora-hero .eclora-hero__text{
  margin-top: 10;
}
#shopify-section-{{ section.id }} .eclora-hero__title{
  margin-bottom: 4px !important;
}
/* =========================================
   ECLORA — HEADER PREMIUM (Balance)
   Colle en bas de assets/base.css
========================================= */

/* 1) Barre d’annonce (moins promo, plus maison) */
.announcement-bar,
.announcement-bar__message,
.announcement-bar__text {
  font-size: 13px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #6B6764 !important;
  padding: 8px 0 !important;
}

/* Option : enlever l’effet "promo" des tirets (si présents via pseudo-éléments) */
.announcement-bar__message::before,
.announcement-bar__message::after {
  content: none !important;
}

/* 2) Header : plus d’air + fond signature */
.header,
.shopify-section-header .header {
  background: #F5F2EE !important;
  padding-top: 16px !important;
  padding-bottom: 16px !important;
  border-bottom: 0 !important;
}

/* 3) Logo/nom : plus premium (contraste, finesse, respiration) */
.header__heading,
.header__heading-link,
.header__heading a {
  color: #1A1A1A !important;
}

/* Si le thème met le logo en image + texte, on harmonise */
.header__heading-logo,
.header__heading-logo-wrapper img {
  max-height: 28px !important; /* ajuste 24–32 */
}

/* 4) Retirer visuellement “- Atelier Floral” si c’est du texte dans le header
   (ça ne supprime pas la source, ça le masque si le texte existe dans un span dédié) */
.header__heading .header__heading-text,
.header__heading .h2,
.header__heading .h1 {
  letter-spacing: -0.01em !important;
}

/* Fallback : si ton titre exact est "Eclora - Atelier Floral" dans un seul noeud texte,
   on ne peut pas couper le texte proprement en CSS.
   -> Dans ce cas, il faudra le modifier dans le contenu du header (logo / shop name / custom liquid). */


/* 5) Icônes menu/panier : taille + couleur + cohérence terracotta */
.header__icon,
.header__icon .icon,
.header__icon svg {
  color: #6B6764 !important;
  fill: currentColor !important;
}

.header__icon svg {
  width: 22px !important;
  height: 22px !important;
}

/* Hover plus premium */
.header__icon:hover,
.header__icon:hover svg {
  color: #9F5F54 !important;
}

/* 6) Alignement & respiration interne */
.header__icons,
.header__icons-wrapper {
  gap: 14px !important;
}

/* 7) Mobile : header un peu plus compact mais toujours luxe */
@media (max-width: 749px){
  .header,
  .shopify-section-header .header{
    padding-top: 12px !important;
    padding-bottom: 12px !important;
  }

  .announcement-bar,
  .announcement-bar__message,
  .announcement-bar__text{
    font-size: 12px !important;
    padding: 7px 0 !important;
  }
}
/* =========================================
   ECLORA — HEADER REFINEMENT FINAL
========================================= */

/* 1️⃣ Barre d’annonce — plus fine, plus luxe */
.announcement-bar,
.announcement-bar__message {
  background: #F5F2EE !important;
  font-size: 12px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6B6764 !important;
  padding: 6px 0 !important;
}

/* 2️⃣ Header fond signature + respiration */
.header,
.shopify-section-header .header {
  background: #F5F2EE !important;
  padding-top: 18px !important;
  padding-bottom: 18px !important;
  border-bottom: none !important;
}

/* 3️⃣ Logo (texte Eclora) plus premium */
.header__heading-link {
  font-size: 20px !important;   /* ajuste 18–22 */
  letter-spacing: -0.01em !important;
  font-weight: 500 !important;
  color: #1A1A1A !important;
}

/* Si logo image */
.header__heading-logo-wrapper img {
  max-height: 30px !important;
}

/* 4️⃣ Icônes plus fines et cohérentes */
.header__icon,
.header__icon svg {
  width: 22px !important;
  height: 22px !important;
  color: #6B6764 !important;
  stroke-width: 1.5 !important;
}

.header__icon:hover,
.header__icon:hover svg {
  color: #9F5F54 !important;
}

/* 5️⃣ Alignement propre des éléments */
.header__icons {
  gap: 16px !important;
}

/* Mobile un peu plus compact */
@media (max-width: 749px){
  .header,
  .shopify-section-header .header{
    padding-top: 14px !important;
    padding-bottom: 14px !important;
  }
}
.header__heading-link {
  font-size: 62px !important;
}
/* LOGO TEXTE — force taille sur le conteneur ET les enfants */
.header__heading-link,
.header__heading-link * {
  font-size: 24px !important;         /* ajuste 20–24 */
  line-height: 1.1 !important;
  letter-spacing: -0.01em !important;
  font-weight: 500 !important;
}
/* =========================================
   ECLORA — LOGO TEXTE (nom de boutique)
   Force la taille même si Balance utilise clamp/variables
========================================= */

/* Cible large : le lien du logo + tous ses enfants (span, strong, etc.) */
.shopify-section-header .header__heading-link,
.shopify-section-header .header__heading-link *{
  font-size: 22px !important;   /* ajuste 20–24 */
  line-height: 1.1 !important;
  letter-spacing: -0.01em !important;
  font-weight: 500 !important;
  color: #1A1A1A !important;
}

/* Fallback si Balance utilise un titre "heading" ailleurs */
.shopify-section-header .header__heading,
.shopify-section-header .header__heading *{
  font-size: 22px !important;
}
/* Filet de sécurité : shop name dans un autre wrapper */
.shopify-section-header .header__heading-logo,
.shopify-section-header .header__heading-logo *,
.shopify-section-header .header__heading-text,
.shopify-section-header .header__heading-text *{
  font-size: 22px !important;
  line-height: 1.1 !important;
}
/* ECLORA — Taille logo texte (nom de boutique) */
a.header-logo,
a.header-logo .header-logo__image-container{
  font-size: 24px !important;      /* teste 20–24 */
  line-height: 1.1 !important;
  letter-spacing: -0.01em !important;
  font-weight: 500 !important;     /* ou 600 si tu veux plus présent */
  color: #1A1A1A !important;
}

/* Mobile un peu plus discret */
@media (max-width: 749px){
  a.header-logo,
  a.header-logo .header-logo__image-container{
    font-size: 20px !important;
  }
}
/* =========================================
   ECLORA — Header premium balance
========================================= */

/* 1️⃣ Logo légèrement plus affirmé */
a.header-logo,
a.header-logo .header-logo__image-container{
  font-size: 26px !important;   /* un peu plus présent */
  font-weight: 500 !important;  /* évite 600 (trop massif) */
  letter-spacing: -0.015em !important;
}

/* 2️⃣ Menu plus discret (il ne doit pas voler la vedette) */
.header__inline-menu a,
.header-nav a{
  font-size: 12px !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #6B6764 !important;
}

/* Hover doux */
.header__inline-menu a:hover,
.header-nav a:hover{
  color: #9F5F54 !important;
}

/* 3️⃣ Plus d’air vertical (clé du premium) */
.header,
.shopify-section-header .header{
  padding-top: 20px !important;
  padding-bottom: 20px !important;
}

/* 4️⃣ Icône panier plus légère */
.header__icon svg{
  width: 20px !important;
  height: 20px !important;
  color: #6B6764 !important;
}
/* =========================================
   ECLORA — Header logo gauche
========================================= */

/* 1️⃣ Conteneur principal en flex propre */
.header__inner,
.header__wrapper,
.header{
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
}

/* 2️⃣ Logo à gauche */
a.header-logo{
  order: 1 !important;
  margin-right: 40px !important; /* espace vers menu */
}

/* 3️⃣ Menu à droite */
.header__inline-menu,
.header-nav{
  order: 2 !important;
  margin-left: auto !important;
}

/* 4️⃣ Icônes tout à droite */
.header__icons{
  order: 3 !important;
  margin-left: 24px !important;
}
.header__column--left{
  order: 1 !important;
}

.header__column--middle{
  order: 2 !important;
  justify-content: flex-start !important;
}

.header__column--right{
  order: 3 !important;
}
/* =========================================
   ECLORA — Header: logo gauche, menu droite
   (Balance / header en 3 colonnes)
========================================= */

/* 1) Mettre les colonnes du header en flex */
.shopify-section-header .header__columns,
.shopify-section-header .header__columns-wrapper,
.shopify-section-header .header__inner {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}

/* 2) Réordonner : gauche = logo, milieu = menu (poussé à droite), droite = icônes */
.shopify-section-header .header__column--left { 
  order: 1 !important;
  flex: 0 0 auto !important;
}

.shopify-section-header .header__column--center{
  order: 2 !important;
  flex: 1 1 auto !important;
  display: flex !important;
  justify-content: flex-end !important;
}

.shopify-section-header .header__column--right {
  order: 3 !important;
  flex: 0 0 auto !important;
}

/* 3) Logo bien ancré à gauche */
.shopify-section-header a.header-logo {
  justify-content: flex-start !important;
  margin-right: 24px !important;
}

/* 4) Menu à droite (même si inline-menu est ailleurs) */
.shopify-section-header .header__inline-menu,
.shopify-section-header nav,
.shopify-section-header .header-nav {
  margin-left: auto !important;
  justify-content: flex-end !important;
  text-align: right !important;
}

/* 5) Icônes à droite + espacement */
.shopify-section-header .header__icons {
  margin-left: 18px !important;
}
a.header-logo,
a.header-logo .header-logo__image-container{
  font-size: 26px;
  font-weight: 500;
  letter-spacing: -0.015em;
}
.header__inline-menu a{
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  opacity: 0.75;
}

.header__inline-menu a:hover{
  opacity: 1;
}
/* TEST ECLORA — doit être visible */
body { outline: 6px solid hotpink !important; }
.header{
  padding-top: 26px !important;
  padding-bottom: 26px !important;
}
/* =========================================
   ECLORA — Header Maison florale parisienne
========================================= */

/* Fond + respiration (le luxe = l’air) */
.shopify-section-header .header{
  background: #F5F2EE !important;
  padding-top: 26px !important;
  padding-bottom: 26px !important;
  border-bottom: 0 !important;
}

/* Barre d’annonce : très fine, très couture */
.announcement-bar,
.announcement-bar__message{
  background: #F5F2EE !important;
  color: #6B6764 !important;
  font-size: 12px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  padding: 6px 0 !important;
}

/* Logo (texte shop name) : discret mais présent */
a.header-logo,
a.header-logo .header-logo__image-container{
  font-size: 22px !important;          /* clé : pas trop grand */
  line-height: 1.05 !important;
  font-weight: 500 !important;         /* couture (évite 600) */
  letter-spacing: -0.01em !important;
  color: #1A1A1A !important;
}

/* Hover terracotta doux */
.shopify-section-header .header__inline-menu a:hover,
.shopify-section-header nav a:hover{
  color: #9F5F54 !important;
  opacity: 1 !important;
}

/* Icônes : fines, discrètes */
.shopify-section-header .header__icon svg{
  width: 19px !important;
  height: 19px !important;
  color: #6B6764 !important;
}
.shopify-section-header .header__icon:hover svg{
  color: #9F5F54 !important;
}

/* Mobile : un peu plus compact */
@media (max-width: 749px){
  .shopify-section-header .header{
    padding-top: 18px !important;
    padding-bottom: 18px !important;
  }
  a.header-logo,
  a.header-logo .header-logo__image-container{
    font-size: 20px !important;
  }
}
/* =========================================
   ECLORA — Mobile logo gauche
========================================= */

@media (max-width: 749px){

  /* Structure du header en flex */
  header-component .header,
  .shopify-section-header .header{
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  /* Colonne centrale (souvent celle du logo) */
  .header__column--middle,
  .header__column--center{
    justify-content: flex-start !important;
    text-align: left !important;
  }

  /* Logo vraiment à gauche */
  a.header-logo{
    margin: 0 !important;
    justify-content: flex-start !important;
  }

  a.header-logo .header-logo__image-container{
    text-align: left !important;
  }

}
@media (max-width: 749px){

  /* Même padding que ton contenu */
  .header{
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* Supprime tout margin négatif */
  a.header-logo{
    margin-left: 0 !important;
  }

}
@media (max-width: 749px){

  /* On aligne header et contenu sur la même grille */
  .header{
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  /* On enlève tout centrage automatique */
  .header__column--middle,
  .header__column--center{
    justify-content: flex-start !important;
    text-align: left !important;
  }

  a.header-logo{
    margin: 0 !important;
    padding: 0 !important;
  }

}
@media (max-width: 749px){

  .header{
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  a.header-logo{
    margin-left: 0 !important;
  }

}
@media (max-width: 749px){

  /* Aligner le container du header sur 16px comme le hero */
  .shopify-section-header .page-width,
  .shopify-section-header .header__inner,
  .shopify-section-header .header__wrapper{
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

}
@media (max-width: 749px){
  .shopify-section-header .header{
    padding-top: 14px !important;
    padding-bottom: 14px !important;
  }
}
/* =========================================
   ECLORA — Collection en vedette (premium)
========================================= */

/* 1) Espacement section */
.featured-collection,
.shopify-section .featured-collection,
.shopify-section .collection,
.shopify-section .collection-list {
  padding-top: 56px !important;
  padding-bottom: 56px !important;
}

@media (max-width: 749px){
  .featured-collection,
  .shopify-section .featured-collection{
    padding-top: 44px !important;
    padding-bottom: 44px !important;
  }
}

/* 2) Titre de section : éditorial */
.featured-collection .title,
.featured-collection h2,
.shopify-section .featured-collection h2{
  margin-bottom: 28px !important;
  letter-spacing: -0.01em;
}

/* 3) Grille : plus d'air */
.featured-collection .grid,
.featured-collection .product-grid,
.shopify-section .product-grid{
  column-gap: 22px;
  row-gap: 28px;
}

@media (max-width: 749px){
  .featured-collection .grid,
  .featured-collection .product-grid,
  .shopify-section .product-grid{
    column-gap: 14px;
    row-gap: 18px;
  }
}

/* 4) Cartes produit : coins + ombre légère */
.card,
.product-card,
.card-wrapper,
.product-grid .card-wrapper{
  border-radius: 18px !important;
}

.card__media,
.card__inner,
.card__content,
.card__information{
  border-radius: 18px !important;
}

.card-wrapper,
.product-grid .card-wrapper{
  box-shadow: 0 10px 30px rgba(26,26,26,0.06) !important;
  transition: transform .18s ease, box-shadow .18s ease;
}

@media (hover:hover){
  .card-wrapper:hover,
  .product-grid .card-wrapper:hover{
    transform: translateY(-2px);
    box-shadow: 0 14px 38px rgba(26,26,26,0.09) !important;
  }
}

/* 5) Textes produit : discret, luxe */
.card__heading,
.card__heading a{
  color: #1A1A1A !important;
  letter-spacing: -0.01em;
}

.price,
.price-item{
  color: #6B6764 !important;
}

/* 6) Boutons (si présents dans les cartes) : capsule terracotta */
.button,
.btn,
a.button,
.product-form__submit,
.card__content .button{
  border-radius: 999px !important;
}

.button--primary,
.btn--primary{
  background: #9F5F54 !important;
  border-color: #9F5F54 !important;
  color: #fff !important;
}

.button--primary:hover,
.btn--primary:hover{
  filter: brightness(0.95);
}
/* =========================================
   ECLORA — Produits en vedette (couture)
========================================= */

/* 1️⃣ Espace entre image et texte */
.card__information,
.card__content{
  margin-top: 14px !important;
}

/* 2️⃣ Titre produit — plus élégant */
.card__heading,
.card__heading a{
  color: #1A1A1A !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em;
  font-size: 18px;
}

/* 3️⃣ Prix — plus discret */
.price,
.price-item{
  color: #6B6764 !important;
  font-size: 15px;
  margin-top: 6px;
}

/* 4️⃣ Plus d’air vertical global */
.featured-collection,
.shopify-section .featured-collection{
  padding-top: 60px !important;
  padding-bottom: 60px !important;
}

/* 5️⃣ Espacement grille mobile */
@media (max-width: 749px){
  .product-grid{
    row-gap: 28px !important;
    column-gap: 18px !important;
  }
}
.card__media,
.card__inner{
  border-radius: 18px !important;
}
/* =========================================
   ECLORA — Rapprocher collection du hero
========================================= */

.featured-collection,
.shopify-section .featured-collection{
  padding-top: 10px !important; /* ajuste 20–40px */
}
/* Force réduction espace entre sections */
.shopify-section + .shopify-section{
  margin-top: 0 !important;
}
/* Rapprocher la section suivante du hero (Produits en vedette) */
.eclora-hero + .shopify-section{
  margin-top: 10px !important; /* teste -16 / -20 / -28 */
}
/* =========================================
   ECLORA — Footer Maison florale parisienne
========================================= */

/* Fond doux, ton sur ton */
.footer,
.shopify-section-footer{
  background: #F5F2EE !important;
  border-top: 1px solid rgba(26,26,26,0.06);
  padding-top: 60px !important;
  padding-bottom: 40px !important;
}

/* Titres colonnes */
.footer h2,
.footer__heading{
  font-size: 13px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6B6764 !important;
  margin-bottom: 18px !important;
}

/* Liens */
.footer a{
  color: #1A1A1A !important;
  font-size: 15px;
  opacity: 0.8;
  transition: opacity .2s ease;
}

.footer a:hover{
  opacity: 1;
  color: #9F5F54 !important;
}

/* Espacement vertical */
.footer__content-top{
  row-gap: 32px !important;
}

/* Bas de footer (copyright etc.) */
.footer__content-bottom{
  border-top: 1px solid rgba(26,26,26,0.06);
  margin-top: 40px;
  padding-top: 20px;
  font-size: 13px;
  color: #6B6764;
}

/* Icônes paiement plus discrètes */
.footer .payment-icons{
  opacity: 0.6;
}

/* Mobile plus compact */
@media (max-width: 749px){
  .footer{
    padding-top: 40px !important;
    padding-bottom: 30px !important;
  }
}
/* =========================================
   ECLORA — Footer A (minimal ultra chic)
========================================= */

.footer,
.shopify-section-footer{
  background: #F5F2EE !important;
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  padding: 56px 0 34px !important;
}

/* Grille : plus d’air, moins de bruit */
.footer__content-top{
  padding-bottom: 0 !important;
  row-gap: 28px !important;
}

/* Titres : petit caps discret */
.footer h2,
.footer__heading{
  font-size: 12px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #6B6764 !important;
  margin: 0 0 14px !important;
}

/* Liens : calme, couture */
.footer a{
  color: #1A1A1A !important;
  opacity: 0.78;
  text-decoration: none !important;
  transition: opacity .18s ease, color .18s ease;
}
.footer a:hover{
  opacity: 1;
  color: #9F5F54 !important;
}

/* Listes propres */
.footer ul{
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.footer li{
  margin: 10px 0 !important;
}

/* Bas de footer : fin et discret */
.footer__content-bottom{
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  margin-top: 34px !important;
  padding-top: 18px !important;
  color: #6B6764 !important;
  font-size: 12px !important;
  letter-spacing: 0.06em;
}

/* Masquer éléments e-commerce trop visibles */
.footer .payment-icons,
.footer__payment,
.footer__localization,
.footer__follow-on-shop{
  display: none !important;
}

/* Mobile compact */
@media (max-width: 749px){
  .footer,
  .shopify-section-footer{
    padding: 40px 0 26px !important;
  }
  .footer li{
    margin: 12px 0 !important;
  }
}
/* Supprimer mention Shopify */
.footer__copyright .powered-by-shopify,
.footer__content-bottom a[href*="shopify"]{
  display: none !important;
}
/* =========================================
   ECLORA — Footer A minimal ultra chic
========================================= */

/* Fond + respiration */
.shopify-section-footer .footer,
.footer{
  background: #F5F2EE !important;
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  padding: 56px 0 28px !important;
}

/* Phrase signature : plus couture, moins “bandeau” */
.footer__content-top p,
.footer p{
  max-width: 760px;
  margin: 0 auto 34px auto !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  color: #1A1A1A !important;
  letter-spacing: -0.01em;
}

/* Trait : plus léger */
.footer hr,
.footer__content-top:before,
.footer__content-top:after{
  opacity: 0.25;
}
.footer a:hover{
  opacity: 1;
  color: #9F5F54 !important;
}

/* Bas de footer : fin et aligné */
.footer__content-bottom{
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  margin-top: 28px !important;
  padding-top: 16px !important;
  color: #6B6764 !important;
  font-size: 12px !important;
}

/* Icônes socials : plus fines */
.footer .icon{
  opacity: 0.7;
}
.footer .icon:hover{
  opacity: 1;
  color: #9F5F54 !important;
}

/* Powered by Shopify : au cas où */
.footer a[href*="shopify.com"],
.footer a[href*="myshopify.com"]{
  display: none !important;
}

/* Mobile compact */
@media (max-width: 749px){
  .footer{
    padding: 40px 0 22px !important;
  }
  .footer__content-top p,
  .footer p{
    font-size: 16px !important;
    margin-bottom: 26px !important;
    padding: 0 16px;
  }
}
/* =========================================
   ECLORA — Footer polish (centré, minimal)
========================================= */

/* 1) Phrase signature : un peu plus compacte */
.footer__content-top p,
.footer p{
  max-width: 680px !important;
  margin: 0 auto 26px auto !important;
}

/* 2) Trait : plus léger et plus court */
.footer__content-bottom{
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  margin-top: 22px !important;
  padding-top: 16px !important;
}

/* Si ton thème ajoute un <hr> : on le neutralise */
.footer hr{
  display: none !important;
}

/* 3) Bas de footer : on centre tout (stop étalement gauche/centre/droite) */
.footer__content-bottom,
.footer__content-bottom-wrapper,
.footer__content-bottom .footer__copyright,
.footer__content-bottom .footer__copyright a{
  text-align: center !important;
  justify-content: center !important;
}

/* 4) Mettre les éléments du bas en colonne sur desktop aussi (ultra chic) */
.footer__content-bottom-wrapper{
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  align-items: center !important;
}

/* 5) Réseaux sociaux : mieux intégrés */
.footer .list-social{
  margin-top: 6px !important;
}
.footer .list-social__item a{
  opacity: 0.7;
}
.footer .list-social__item a:hover{
  opacity: 1;
}

/* 6) Mobile : un peu plus d'air en bas */
@media (max-width: 749px){
  .footer{
    padding-bottom: 28px !important;
  }
  .footer__content-top p,
  .footer p{
    margin-bottom: 22px !important;
  }
}
/* =========================================
   ECLORA — Footer minimal (Balance)
========================================= */

.shopify-section-group-footer-group {
  background: #F5F2EE !important;
  border-top: 1px solid rgba(26,26,26,0.06) !important;
}

/* Phrase signature (le texte en haut du footer) */
.shopify-section-group-footer-group p {
  max-width: 680px !important;
  margin: 0 auto 26px auto !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
  color: #1A1A1A !important;
}

/* Enlever le gros trait (souvent un hr ou border) */
.shopify-section-group-footer-group hr {
  display: none !important;
}

/* Zone utilitaires (© / lien policies / icônes) */
.shopify-section-group-footer-group .footer-utilities {
  border-top: 1px solid rgba(26,26,26,0.06) !important;
  margin-top: 22px !important;
  padding-top: 16px !important;

  display: flex !important;
  flex-direction: column !important;   /* ✅ centre et calme */
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  text-align: center !important;
}

/* Liens footer */
.shopify-section-group-footer-group a {
  color: #1A1A1A !important;
  opacity: 0.78 !important;
  text-decoration: none !important;
}
.shopify-section-group-footer-group a:hover {
  color: #9F5F54 !important;
  opacity: 1 !important;
}

/* Social : un peu plus discret */
.shopify-section-group-footer-group .list-social a {
  opacity: 0.7 !important;
}
.shopify-section-group-footer-group .list-social a:hover {
  opacity: 1 !important;
}

/* Mobile : plus compact */
@media (max-width: 749px){
  .shopify-section-group-footer-group p{
    font-size: 16px !important;
    margin-bottom: 22px !important;
    padding: 0 16px !important;
  }
}
/* =========================================
   ECLORA — Footer bottom: desktop inline, mobile stacked
========================================= */

/* Desktop: une ligne centrée */
@media (min-width: 750px){
  .shopify-section-group-footer-group .footer-utilities,
  .shopify-section-group-footer-group .footer__content-bottom,
  .shopify-section-group-footer-group .footer__content-bottom-wrapper,
  .shopify-section-group-footer-group .footer__bottom{
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 26px !important;
    text-align: center !important;
  }
}

/* Mobile: on garde la colonne (ton rendu actuel) */
@media (max-width: 749px){
  .shopify-section-group-footer-group .footer-utilities,
  .shopify-section-group-footer-group .footer__content-bottom,
  .shopify-section-group-footer-group .footer__content-bottom-wrapper,
  .shopify-section-group-footer-group .footer__bottom{
    flex-direction: column !important;
    gap: 10px !important;
  }
}
@media (min-width: 750px){
  .shopify-section-group-footer-group .footer-utilities,
  .shopify-section-group-footer-group .footer__content-bottom{
    font-size: 12px !important;
    color: #6B6764 !important;
  }
}
/* =========================================
   ECLORA — Footer bottom centered (desktop)
   Force override on Balance grid layout
========================================= */

@media (min-width: 750px){

  /* Cible large : la zone utilitaire + ses wrappers */
  .shopify-section-group-footer-group .footer-utilities,
  .shopify-section-group-footer-group .footer-utilities > div,
  .shopify-section-group-footer-group .footer-utilities__inner,
  .shopify-section-group-footer-group .footer-utilities__wrapper,
  .shopify-section-group-footer-group .footer__content-bottom,
  .shopify-section-group-footer-group .footer__content-bottom-wrapper{
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 26px !important;
    text-align: center !important;

    /* neutralise grid si présent */
    grid-template-columns: none !important;
    grid-auto-flow: unset !important;
  }

  /* Chaque item ne doit pas prendre 1/3 */
  .shopify-section-group-footer-group .footer-utilities > *{
    flex: 0 0 auto !important;
    justify-self: auto !important;
  }
}
/* =========================================
   ECLORA — Footer utilities: desktop inline centered
   Fix parent grid in footer-utilities section
========================================= */

@media (min-width: 750px){

  /* Le parent qui est en grid (d'après ton inspecteur) */
  #shopify-section-sections--27281890771270__footer-utilities .section.section--page-width{
    display: block !important; /* neutralise le grid */
  }

  /* La barre utilitaires en ligne centrée */
  #shopify-section-sections--27281890771270__footer-utilities .utilities{
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 26px !important;
    text-align: center !important;
  }

  /* Empêche les enfants de prendre 1/3 */
  #shopify-section-sections--27281890771270__footer-utilities .utilities > *{
    flex: 0 0 auto !important;
  }
}
/* =========================================
   ECLORA — Footer utilities desktop: inline centered (guaranteed)
   Uses data-testid="footer-utilities"
========================================= */

@media (min-width: 750px){

  /* Le wrapper exact de la zone du bas */
  [data-testid="footer-utilities"]{
    width: 100% !important;
    display: flex !important;
    justify-content: center !important; /* ✅ stop left/center/right */
  }

  /* Le bloc qui contient © / lien / social */
  [data-testid="footer-utilities"] .utilities{
    width: auto !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 26px !important;
    text-align: center !important;
  }

  /* Empêche chaque item de prendre 1/3 */
  [data-testid="footer-utilities"] .utilities > *{
    flex: 0 0 auto !important;
    justify-self: auto !important;
  }
}
/* =========================================
   ECLORA — Footer: trait court + bas plus proche
========================================= */

/* Réduire l'espace avant la zone utilitaires */
.shopify-section-group-footer-group [data-testid="footer-utilities"],
#shopify-section-sections--27281890771270__footer-utilities [data-testid="footer-utilities"]{
  margin-top: 18px !important;
}

/* Zone utilitaires : un peu moins d'air */
.shopify-section-group-footer-group .utilities{
  gap: 8px !important;
  padding-top: 14px !important;
}

/* Trait : plus court (et plus léger) */
.shopify-section-group-footer-group .utilities{
  border-top: none !important; /* on enlève le trait full width */
}

.shopify-section-group-footer-group .utilities::before{
  content: "" !important;
  display: block !important;
  width: min(520px, 70vw) !important;   /* trait court */
  height: 1px !important;
  background: rgba(26,26,26,0.10) !important;
  margin: 0 auto 14px auto !important;
}

/* Desktop : remonter un peu le footer (optionnel) */
@media (min-width: 750px){
  .shopify-section-group-footer-group{
    padding-bottom: 20px !important;
  }
}
/* =========================================
   ECLORA — Kill the big footer line (guaranteed)
========================================= */

/* 1) Si c’est un <hr> (très fréquent) */
.shopify-section-group-footer-group hr{
  display: none !important;
}

/* 2) Si c’est une bordure sur un wrapper */
.shopify-section-group-footer-group .section,
.shopify-section-group-footer-group .section::before,
.shopify-section-group-footer-group .section::after,
.shopify-section-group-footer-group [data-testid="footer-utilities"],
.shopify-section-group-footer-group [data-testid="footer-utilities"]::before,
.shopify-section-group-footer-group [data-testid="footer-utilities"]::after{
  border-top: 0 !important;
}

/* 3) Cas Balance: la ligne est parfois sur .utilities lui-même */
.shopify-section-group-footer-group .utilities{
  border-top: 0 !important;
}
/* Enlever le grand trait (border-top du footer group) */
.shopify-section-group-footer-group{
  border-top: 0 !important;
}
.shopify-section-group-footer-group p{
  margin-bottom: 5px !important;
}
.shopify-section-group-footer-group .utilities::before{
  background: rgba(26,26,26,0.07) !important;
}
.shopify-section-group-footer-group .list-social svg{
  width: 18px !important;
  height: 18px !important;
}
/* TEST — surligner le champ téléphone sur la page contact */
.template-page.contact .field input[type="tel"],
.template-page.contact input[type="tel"] {
  outline: 3px solid red !important;
  background: rgba(255, 0, 0, 0.06) !important;
}
/* CONTACT — masquer le champ téléphone */
#ContactForm-phone {
  display: none !important;
}

/* Masquer aussi le label associé */
label[for="ContactForm-phone"] {
  display: none !important;
}
/* Nettoyage espacement */
#ContactForm-phone + * {
  margin-top: 0 !important;
}
/* =========================
   ECLORA — CONTACT (Ultra premium)
   ========================= */

/* Variables (si tu veux centraliser) */
:root{
  --eclora-beige: #F5F2EE;
  --eclora-black: #1A1A1A;
  --eclora-gray:  #6B6764;
  --eclora-terracotta: #9F5F54;
}

/* Zone contact : texte + email */
.template-page .contact,
.template-page .main-page-title {
  color: var(--eclora-black);
}

.template-page .contact p,
.template-page .contact a {
  color: var(--eclora-gray);
}

.template-page .contact a:hover{
  color: var(--eclora-black);
}

/* Champs du formulaire : bordures fines, plus “maison” */
.contact-form .contact-form__input,
.contact-form .field__input,
.contact-form input,
.contact-form textarea {
  border: 1px solid rgba(26, 26, 26, 0.22) !important; /* fin et doux */
  border-radius: 14px !important;                     /* plus premium */
  background: rgba(245, 242, 238, 0.55) !important;   /* beige léger */
  color: var(--eclora-black) !important;
  box-shadow: none !important;
}

/* Placeholders : discrets */
.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color: rgba(107, 103, 100, 0.75) !important;
}

/* Focus : signature terracotta, très subtil */
.contact-form .contact-form__input:focus,
.contact-form .field__input:focus,
.contact-form input:focus,
.contact-form textarea:focus{
  outline: none !important;
  border-color: rgba(159, 95, 84, 0.55) !important;
  box-shadow: 0 0 0 3px rgba(159, 95, 84, 0.14) !important;
  background: rgba(245, 242, 238, 0.75) !important;
}

/* Textarea : un peu plus “éditorial” */
.contact-form textarea{
  min-height: 180px !important;
  resize: vertical; /* ou none si tu veux figer */
}

/* Bouton : terracotta capsule, typographie nette */
.contact-form button[type="submit"],
.contact-form .button[type="submit"]{
  background: var(--eclora-terracotta) !important;
  color: #F5F2EE !important;
  border: 1px solid rgba(159, 95, 84, 0.9) !important;
  border-radius: 999px !important;
  padding: 12px 18px !important;
  letter-spacing: 0.02em;
  box-shadow: none !important;
}

/* Hover : plus “maison” (noir doux), sans agressivité */
.contact-form button[type="submit"]:hover,
.contact-form .button[type="submit"]:hover{
  background: var(--eclora-black) !important;
  border-color: var(--eclora-black) !important;
  color: #F5F2EE !important;
}

/* Optionnel : réduire légèrement l’espace entre intro et formulaire */
.template-page .contact-form{
  margin-top: 18px !important;
}
/* =========================================================
   ECLORA — HERO (sections/eclora-hero.liquid)
   Style premium doux / artisanal / moderne
   ========================================================= */

/* 0) Variables (si déjà dans ton theme, tu peux enlever) */
:root{
  --e-bg: #F5F2EE;
  --e-text: #1A1A1A;
  --e-muted: #6B6764;
  --e-accent: #9F5F54;
  --e-accent-hover: #7E473E;

  --e-radius-soft: 18px;
  --e-radius-pill: 999px;

  --e-shadow-soft: 0 10px 40px rgba(0,0,0,.05);
  --e-shadow-soft-2: 0 14px 55px rgba(0,0,0,.07);

  --e-container: 1200px; /* ajustable */
}

/* 1) Section background */
.eclora-section.eclora-hero{
  color: var(--e-text);
  background: transparent;
}

/* Fond signature si warm_bg */
.eclora-section.eclora-hero.eclora-section--warm{
  background: var(--e-bg);
}

/* 2) Container (si ton thème a déjà .eclora-container, garde juste ce qui manque) */
.eclora-hero .eclora-container{
  max-width: var(--e-container);
  margin: 0 auto;
  padding: clamp(40px, 6vw, 78px) clamp(18px, 4vw, 56px);
}

/* 3) Grid desktop : image légèrement dominante */
.eclora-hero__grid{
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: clamp(18px, 3.2vw, 44px);
  align-items: center;
}

/* 4) Colonne texte */
.eclora-hero__content{
  max-width: 560px;
}

/* Kicker */
.eclora-kicker{
  display: inline-block;
  font-size: 20px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--e-accent);
  margin: 0 0 12px 0;
}

/* Titre (si tu utilises newline_to_br plus tard, ça marchera pareil) */
.eclora-hero__title{
  margin: 0 0 14px 0;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.15;
  letter-spacing: -0.01em;
}

/* Texte */
.eclora-hero__text{
  margin: 0 0 22px 0;
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.7;
  color: var(--e-muted);
  max-width: 52ch;
}

/* 5) Actions */
.eclora-hero__actions{
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* 6) Boutons (sans casser ton style theme si déjà défini) */
.eclora-btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border-radius: var(--e-radius-pill);
  padding: 13px 26px;
  font-size: 14px;
  letter-spacing: .02em;
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease, color .22s ease;
}

/* Primary */
.eclora-btn--primary{
  background: var(--e-accent);
  color: #fff;
  border: 1px solid transparent;
  box-shadow: 0 10px 26px rgba(159,95,84,.22);
}
.eclora-btn--primary:hover{
  background: var(--e-accent-hover);
  transform: translateY(-1px);
  box-shadow: 0 16px 34px rgba(126,71,62,.26);
}
.eclora-btn--primary:active{ transform: translateY(0); }

/* Secondary (premium discret) */
.eclora-btn--secondary{
  background: transparent;
  color: var(--e-text);
  border: 1px solid rgba(26,26,26,.18);
}
.eclora-btn--secondary:hover{
  border-color: rgba(26,26,26,.32);
  transform: translateY(-1px);
  box-shadow: 0 10px 26px rgba(0,0,0,.06);
}
.eclora-btn--secondary:active{ transform: translateY(0); }

/* Focus accessible */
.eclora-btn:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px rgba(159,95,84,.18), 0 16px 34px rgba(0,0,0,.08);
}

/* 7) Media / Image */
.eclora-hero__media{
  position: relative;
}

/* Shopify image_tag rend souvent un <img> direct.
   On stylise img à l’intérieur de la zone media. */
.eclora-hero__media img{
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--e-radius-soft);
  box-shadow: var(--e-shadow-soft);
  object-fit: cover;

  /* effet éditorial premium */
  transform: translateY(18px);
  transition: transform .35s ease, box-shadow .35s ease;
}

/* Hover image subtil (desktop) */
@media (hover:hover) and (pointer:fine){
  .eclora-hero__media img:hover{
    transform: translateY(14px);
    box-shadow: var(--e-shadow-soft-2);
  }
}

/* Placeholder si pas d’image */
.eclora-hero__placeholder{
  border-radius: var(--e-radius-soft);
  background: rgba(26,26,26,.03);
  border: 1px dashed rgba(26,26,26,.12);
  padding: 22px;
  color: var(--e-muted);
}

/* 8) Responsive mobile : image d’abord, lisibilité, spacing */
@media (max-width: 990px){
  .eclora-hero__grid{
    grid-template-columns: 1fr;
    align-items: start;
  }

  /* Met l’image au-dessus */
  .eclora-hero__media{ order: -1; }

  .eclora-hero__content{
    max-width: 100%;
  }

  .eclora-hero__title{
    margin-top: 14px;
  }

  .eclora-hero__media img{
    transform: none;
    border-radius: 16px;
  }

  .eclora-hero__actions{
    gap: 10px;
  }

  /* Boutons confortables sans full-width */
  .eclora-btn{
    padding: 14px 28px;
  }
}

/* 9) Très petit mobile */
@media (max-width: 420px){
  .eclora-hero .eclora-container{
    padding: 34px 16px;
  }
}

/* 10) Réduction de mouvement */
@media (prefers-reduced-motion: reduce){
  .eclora-hero *{
    transition: none !important;
    animation: none !important;
  }
}
/* =====================================================
   ECLORA — HERO FINAL
   Version consolidée propre
   ===================================================== */

/* ================= DESKTOP ================= */

.eclora-hero__grid{
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 44px;
  align-items: center;
}

.eclora-hero__content{
  max-width: 560px;
}

.eclora-kicker{
  display: inline-block;
  font-size: 20px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #9F5F54;
  margin-bottom: 14px;
}

.eclora-hero__title{
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: 16px;
}

.eclora-hero__text{
  font-size: clamp(15px, 1.2vw, 18px);
  line-height: 1.7;
  color: #6B6764;
  margin-bottom: 22px;
}

.eclora-hero__media img{
  width: 100%;
  border-radius: 18px;
  box-shadow: 0 10px 40px rgba(0,0,0,.05);
  display: block;
}

/* ================= MOBILE ================= */

@media (max-width: 990px){

  /* Layout vertical */
  .eclora-hero__grid{
    display: flex;
    flex-direction: column;
    gap: 18px;
  }

  /* Remonte légèrement l'image */
  .eclora-hero__media{
    position: relative;
    top: -10px;
    width: 100%;
  }

  .eclora-hero__media img{
    height: clamp(260px, 46vh, 420px);
    object-fit: cover;
    object-position: center;
    border-radius: 16px;
  }

  /* Bloc texte */
  .eclora-hero__content{
    max-width: 34ch;
    margin: 0 auto;
    text-align: center; /* ← change en left si version éditoriale */
  }

  /* Kicker */
  .eclora-kicker{
    display: block;
    position: relative;
    top: 10px; /* abaisse légèrement sous l'image */
    margin-bottom: 10px;
  }

  /* Trait mobile propre */
  .eclora-kicker::before{
    content: none;
  }

  .eclora-kicker::after{
    content: "";
    display: block;
    width: 56px;
    height: 1px;
    margin: 10px auto 0 auto;
    background: rgba(159,95,84,.35);
  }

  /* Espacements */
  .eclora-hero__title{
    margin-bottom: 16px;
  }

  .eclora-hero__text{
    margin-bottom: 22px;
  }

  /* Boutons */
  .eclora-hero__actions{
    justify-content: center;
  }
}
body {
  background: red !important;
}
@media (max-width: 990px){

  .eclora-hero__grid{
    display: flex !important;
    flex-direction: column !important;
  }

  .eclora-hero__media{
    order: -1 !important;
    width: 100% !important;
  }

  .eclora-hero__media img{
    width: 100% !important;
    height: 340px !important;
    object-fit: cover !important;
  }

  .eclora-hero__content{
    text-align: center !important;
    max-width: 34ch !important;
    margin: 0 auto !important;
  }

}
/* =========================
   ECLORA — HERO ajustements
   ========================= */

/* 1) Aligner le texte à gauche (force) */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content{
  text-align: left !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}

/* 2) Couleurs : label / titre / texte */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content{
  color: var(--eclora-black, #1A1A1A);
}

.shopify-section section.eclora-section.eclora-hero .eclora-hero__content p{
  color: var(--eclora-gray, #6B6764) !important;
}

/* Le petit label “MAISON FLORALE” (souvent un span/small/p) :
   on le met en terracotta + tracking léger */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content *:is(.eyebrow,.kicker,.subtitle,small,span,p){
  /* on ne peut pas deviner la classe exacte, donc on cible le tout premier petit texte si besoin */
}

/* Ciblage pratique : le premier élément texte court au-dessus du H1 */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content > *:first-child{
  color: var(--eclora-terracotta, #9F5F54) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-size: 12px !important;
}

/* Titre (H1) en noir doux */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content h1,
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content .h1{
  color: var(--eclora-black, #1A1A1A) !important;
}

/* 3) Réduire la hauteur de la photo (sans déformer) */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__media img{
  max-height: 100px !important;     /* ajuste ici: 360–520 selon ton goût */
  width: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 18px !important;
  display: block !important;
}

/* Option : éviter que le hero entier prenne trop de hauteur */
.shopify-section section.eclora-section.eclora-hero{
  padding-top: 56px !important;
  padding-bottom: 56px !important;
}

/* Mobile : image un peu moins haute + texte centré ou gauche (je recommande gauche même sur mobile) */
@media (max-width: 990px){
  .shopify-section section.eclora-section.eclora-hero .eclora-hero__content{
    text-align: left !important;
    margin: 0 auto !important;
  }

  .shopify-section section.eclora-section.eclora-hero .eclora-hero__media img{
    max-height: 320px !important;
  }
}
/* =========================
   ECLORA — KICKER + TRAIT
   ========================= */

/* Wrapper du contenu hero */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content{
  position: relative;
}

/* Trait fin au-dessus du kicker */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content .kicker{
  position: relative;
  display: inline-block;
  color: var(--eclora-terracotta, #9F5F54) !important;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 12px;
  margin-bottom: 16px;
}

/* Ligne ultra fine */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content .kicker::before{
  content: "";
  display: block;
  width: 40px;              /* longueur du trait */
  height: 1px;              /* finesse */
  background: rgba(159, 95, 84, 0.6); /* terracotta subtil */
  margin-bottom: 12px;
}
/* TEST — est-ce qu’on cible bien le kicker ? */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content .kicker{
  outline: 2px solid red !important;
}
/* Fallback : kicker = premier petit texte dans le contenu hero */
.shopify-section section.eclora-section.eclora-hero .eclora-hero__content > :first-child{
  position: relative !important;
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 10px !important;
  color: var(--eclora-terracotta, #9F5F54) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  font-size: 12px !important;
}

.shopify-section section.eclora-section.eclora-hero .eclora-hero__content > :first-child::before{
  content: "" !important;
  display: block !important;
  width: 56px !important;
  height: 1px !important;
  background: rgba(159, 95, 84, 0.55) !important;
}
/* TEST IMPOSSIBLE À RATER */
body { outline: 6px solid red !important; }
/* ============================= */
/* PRODUCT ACCORDIONS PREMIUM  */
/* ============================= */

.product__accordion,
.collapsible-content,
.accordion {
  border-top: 1px solid rgba(0,0,0,0.06);
  padding: 18px 0;
}

.product__accordion summary,
.collapsible-content summary,
.accordion summary {
  font-family: var(--font-display);
  font-size: 15px;
  letter-spacing: 0.03em;
  cursor: pointer;
  transition: color .25s ease;
}

.product__accordion summary:hover,
.collapsible-content summary:hover,
.accordion summary:hover {
  color: #9F5F54; /* terracotta */
}

.product__accordion .accordion__content,
.collapsible-content__inner {
  padding-top: 10px;
  color: #6B6764;
  line-height: 1.6;
  font-size: 14px;
}
/* ============================= */
/* PRODUCT ACCORDION – PLUS ICON */
/* ============================= */

/* Cache l’icône native Shopify */
.product__accordion summary svg,
.collapsible-content summary svg,
.accordion summary svg {
  display: none !important;
}

/* Positionnement du summary */
.product__accordion summary,
.collapsible-content summary,
.accordion summary {
  position: relative;
  padding-right: 20px;
}

/* Création du + */
.product__accordion summary::after,
.collapsible-content summary::after,
.accordion summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  font-weight: 300;
  color: #9F5F54; /* terracotta */
  transition: transform 0.25s ease;
}

/* Quand ouvert → devient - */
.product__accordion[open] summary::after,
.collapsible-content[open] summary::after,
.accordion[open] summary::after {
  content: "–";
}
/* ============================= */
/* PRODUCT — Quantité premium     */
/* ============================= */

/* Le conteneur quantité */
.template-product quantity-input,
.template-product .quantity,
.template-product .quantity__wrapper,
.template-product .quantity-input {
  border: 1px solid rgba(26,26,26,0.14) !important;
  border-radius: 999px !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Réduit la hauteur, plus chic */
.template-product .quantity,
.template-product quantity-input {
  min-height: 44px !important;
  height: 44px !important;
  padding: 0 6px !important;
}

/* Boutons + / - : plus discrets */
.template-product .quantity__button {
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  background: transparent !important;
  color: #1A1A1A !important;
  opacity: 0.7 !important;
}

.template-product .quantity__button:hover {
  opacity: 1 !important;
  background: rgba(26,26,26,0.04) !important;
}

/* Le chiffre au centre */
.template-product .quantity__input {
  font-size: 14px !important;
  color: #1A1A1A !important;
  background: transparent !important;
  border: 0 !important;
  width: 34px !important;
}

/* Retire les gros cercles si ton thème les force via pseudo éléments */
.template-product .quantity__button::before,
.template-product .quantity__button::after {
  background: transparent !important;
}
/* TEST CIBLAGE */
.template-product .quantity,
.template-product quantity-input,
.template-product .product-form__submit,
.template-product button[name="add"]{
  outline: 3px solid red !important;
}
/* ============================= */
/* PRODUIT — CTA premium Eclora  */
/* ============================= */

button.add-to-cart-button,
button[name="add"],
button[id^="BuyButtons-ProductSubmitButton-"]{
  background: #9F5F54 !important;       /* terracotta */
  color: #F5F2EE !important;            /* beige */
  border: 1px solid rgba(159,95,84,0.9) !important;
  border-radius: 999px !important;
  padding: 16px 26px !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  box-shadow: none !important;
  text-transform: none !important;
}

/* Hover : noir doux */
button.add-to-cart-button:hover,
button[name="add"]:hover,
button[id^="BuyButtons-ProductSubmitButton-"]:hover{
  background: #1A1A1A !important;
  border-color: #1A1A1A !important;
}
/* ============================= */
/* PRODUIT — Quantité ultra premium */
/* ============================= */

/* Wrapper */
.quantity-selector-wrapper{
  display: inline-flex !important;
}

/* Le composant quantité (capsule fine) */
.quantity-selector{
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  height: 44px !important;
  padding: 0 10px !important;
  border: 1px solid rgba(26,26,26,0.14) !important;
  border-radius: 999px !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Input chiffre */
.quantity-selector input[type="number"]{
  width: 34px !important;
  padding: 0 !important;
  margin: 0 !important;
  text-align: center !important;
  font-size: 14px !important;
  color: #1A1A1A !important;
  background: transparent !important;
  border: 0 !important;
}

/* Boutons +/- discrets (pas de gros cercles) */
.quantity-selector .quantity-minus,
.quantity-selector .quantity-plus{
  width: 32px !important;
  height: 32px !important;
  border-radius: 999px !important;
  background: transparent !important;
  border: 0 !important;
  color: #1A1A1A !important;
  opacity: 0.65 !important;
  transition: background .2s ease, opacity .2s ease !important;
}

/* Hover doux */
.quantity-selector .quantity-minus:hover,
.quantity-selector .quantity-plus:hover{
  opacity: 1 !important;
  background: rgba(26,26,26,0.04) !important;
}

/* Retire styles internes éventuels (icônes/pseudos) */
.quantity-selector .quantity-minus::before,
.quantity-selector .quantity-minus::after,
.quantity-selector .quantity-plus::before,
.quantity-selector .quantity-plus::after{
  background: transparent !important;
}
/* ============================= */
/* PRODUIT — CTA terracotta premium */
/* ============================= */

button.add-to-cart-button,
button[name="add"],
button[id^="BuyButtons-ProductSubmitButton-"]{
  background: #9F5F54 !important;
  color: #F5F2EE !important;
  border: 1px solid rgba(159,95,84,0.9) !important;
  border-radius: 999px !important;
  padding: 16px 26px !important;
  font-weight: 500 !important;
  letter-spacing: 0.03em !important;
  box-shadow: none !important;
}

button.add-to-cart-button:hover,
button[name="add"]:hover,
button[id^="BuyButtons-ProductSubmitButton-"]:hover{
  background: #1A1A1A !important;
  border-color: #1A1A1A !important;
}
/* Accordéon — + parfaitement centré */
.product__accordion summary,
.collapsible-content summary,
.accordion summary{
  position: relative;
  padding-right: 28px !important;
}

.product__accordion summary::after,
.collapsible-content summary::after,
.accordion summary::after{
  right: 0 !important;
  top: 50% !important;
  transform: translateY(-52%) !important; /* léger ajustement premium */
  line-height: 1 !important;
}
/* Quantité — bord plus subtil */
.quantity-selector{
  border-color: rgba(26,26,26,0.10) !important;
}
/* Produit — resserrer le bloc achat */
.product-form,
.product-form-buttons,
#AddToCartButtonContainer{
  margin-top: 12px !important;
}
/* Prix — plus éditorial */
.product .price,
.price{
  font-size: 16px !important;
  color: #6B6764 !important;
  font-weight: 400 !important;
  margin-top: 6px !important;
}
/* CTA — plus d'air */
button.add-to-cart-button{
  margin-top: 14px !important;
}
/* Alignement quantité */
.quantity-selector-wrapper{
  margin-right: 10px !important;
}
/* Rassurance plus fine */
.product .product__description ul,
.product ul{
  list-style: none !important;
  padding-left: 0 !important;
}

.product ul li{
  position: relative;
  padding-left: 18px;
  font-size: 14px;
  color: #6B6764;
}

.product ul li::before{
  content: "✓";
  position: absolute;
  left: 0;
  color: #9F5F54;
  font-size: 13px;
}
/* CTA desktop — largeur maîtrisée */
@media (min-width: 990px){

  button.add-to-cart-button,
  button[name="add"],
  button[id^="BuyButtons-ProductSubmitButton-"]{
    width: auto !important;
    min-width: 320px !important;
  }

}
/* Alignement bloc achat */
.quantity-selector-wrapper{
  margin-right: 16px !important;
}

#AddToCartButtonContainer,
.product-form-buttons{
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
}
/* Titre produit */
.product h1{
  line-height: 1.15 !important;
  margin-bottom: 10px !important;
}
/* Description produit */
.product .product__description,
.product .rte{
  font-size: 15px !important;
  line-height: 1.7 !important;
  color: #6B6764 !important;
}
/* ============================= */
/* ECLORA — CTA produit premium  */
/* ============================= */

/* Bouton principal */
button.add-to-cart-button,
button[name="add"],
button[id^="BuyButtons-ProductSubmitButton-"]{
  background: #9F5F54 !important;
  color: #F5F2EE !important;
  border: 1px solid rgba(159,95,84,0.85) !important;
  border-radius: 999px !important;

  padding: 16px 26px !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;   /* plus éditorial */
  box-shadow: 0 10px 30px rgba(0,0,0,0.06) !important; /* relief doux */
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease !important;
}

/* Hover : noir doux + léger lift */
button.add-to-cart-button:hover,
button[name="add"]:hover,
button[id^="BuyButtons-ProductSubmitButton-"]:hover{
  background: #1A1A1A !important;
  border-color: #1A1A1A !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 38px rgba(0,0,0,0.08) !important;
}

/* Largeur premium desktop (moins “bloc”) */
@media (min-width: 990px){
  button.add-to-cart-button,
  button[name="add"],
  button[id^="BuyButtons-ProductSubmitButton-"]{
    width: auto !important;
    min-width: 320px !important;
  }
}

/* Retirer l’icône panier (plus maison, moins e-commerce) */
button.add-to-cart-button svg,
button[name="add"] svg,
button[id^="BuyButtons-ProductSubmitButton-"] svg{
  display: none !important;
}
/* Description produit — respiration premium */
.product .rte p{
  margin-bottom: 18px !important;
}

.product .rte p:first-child{
  font-size: 16px !important;
}
/* ============================= */
/* Micro-description premium     */
/* ============================= */

.product-micro{
  font-size: 17px !important;
  line-height: 1.6 !important;
  color: #1A1A1A !important;
  margin-top: 14px !important;
  margin-bottom: 22px !important;
  font-weight: 400 !important;
}

/* Description principale plus douce */
.product .rte{
  font-size: 15px !important;
  line-height: 1.75 !important;
  color: #6B6764 !important;
}
.product-micro{
  font-style: italic;
}
/* === CARROUSEL PRODUIT PREMIUM === */

.media-gallery__navigation-button,
.slider-button {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #F5F2EE; /* beige doux */
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: none;
  transition: all .2s ease;
}

.media-gallery__navigation-button svg,
.slider-button svg {
  width: 16px;
  height: 16px;
  stroke: #2E4A43; /* ton vert profond */
}

.media-gallery__navigation-button:hover,
.slider-button:hover {
  background: #EAE4DC;
}
.slider-counter__link,
.slider-dots__dot {
  width: 6px;
  height: 6px;
  background: rgba(0,0,0,0.2);
  border-radius: 50%;
}

.slider-counter__link.is-active,
.slider-dots__dot.is-active {
  background: #2E4A43;
}
/* ============================= */
/* CARROUSEL PRODUIT — FLÈCHES PREMIUM */
/* ============================= */

.slideshow-control{
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px !important;

  background: rgba(245, 242, 238, 0.92) !important; /* beige signature */
  border: 1px solid rgba(26, 26, 26, 0.10) !important;
  box-shadow: none !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  transition: background .2s ease, border-color .2s ease, transform .2s ease !important;
}

/* Icône flèche (SVG) */
.slideshow-control svg{
  width: 16px !important;
  height: 16px !important;
  stroke: #1A1A1A !important; /* noir doux */
  opacity: 0.85 !important;
}

/* Hover subtil */
.slideshow-control:hover{
  background: rgba(245, 242, 238, 1) !important;
  border-color: rgba(159, 95, 84, 0.35) !important; /* terracotta léger */
  transform: translateY(-1px) !important;
}

.slideshow-control:hover svg{
  stroke: #9F5F54 !important; /* terracotta */
  opacity: 1 !important;
}
/* ============================= */
/* CARROUSEL — DOTS PREMIUM */
/* ============================= */

slideshow-controls .slider-dots__dot,
slideshow-controls .slider-counter__link{
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: rgba(26,26,26,0.18) !important;
}

slideshow-controls .is-active,
slideshow-controls .slider-dots__dot[aria-current="true"]{
  background: #9F5F54 !important;
}
/* ===================================== */
/* CARROUSEL PRODUIT — CONTRÔLES PREMIUM */
/* ===================================== */

/* Flèches */
.slideshow-control{
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;

  background: rgba(245, 242, 238, 0.95) !important; /* beige */
  border: 1px solid rgba(26, 26, 26, 0.10) !important;

  box-shadow: 0 10px 28px rgba(0,0,0,0.06) !important;
  backdrop-filter: blur(6px);

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  transition: transform .18s ease, background .18s ease, border-color .18s ease, box-shadow .18s ease !important;
}

/* Icône */
.slideshow-control svg{
  width: 16px !important;
  height: 16px !important;
  stroke:rgb(248, 28, 28) !important; /* noir doux */
  opacity: 0.75 !important;
}

/* Hover : terracotta subtil */
.slideshow-control:hover{
  transform: translateY(-1px) !important;
  border-color: rgba(159, 95, 84, 0.35) !important;
  box-shadow: 0 14px 34px rgba(0,0,0,0.08) !important;
}

.slideshow-control:hover svg{
  stroke: #9F5F54 !important; /* terracotta */
  opacity: 1 !important;
}

/* Dots (pagination) — micro et discrets */
slideshow-controls .slider-dots,
slideshow-controls .slider-counter{
  margin-top: 14px !important;
}

slideshow-controls .slider-dots__dot,
slideshow-controls .slider-counter__link{
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: rgba(26,26,26,0.18) !important;
  border: 0 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Dot actif */
slideshow-controls .slider-dots__dot[aria-current="true"],
slideshow-controls .slider-counter__link.is-active{
  background: rgba(159,95,84,0.75) !important; /* terracotta doux */
}
/* ===================================== */
/* FORCE OVERRIDE — flèches carrousel    */
/* ===================================== */

button.slideshow-control.button-unstyled--transparent{
  background: rgba(245, 242, 238, 0.95) !important;
  border: 1px solid rgba(26,26,26,0.10) !important;
  border-radius: 999px !important;
  box-shadow: 0 10px 28px rgba(0,0,0,0.06) !important;
}

/* Si le thème dessine un “fond” via pseudo-élément */
button.slideshow-control.button-unstyled--transparent::before,
button.slideshow-control.button-unstyled--transparent::after{
  background: transparent !important;
  opacity: 0 !important;
  box-shadow: none !important;
}

/* Icône */
button.slideshow-control.button-unstyled--transparent svg{
  stroke:rgb(14, 104, 36) !important;
  opacity: 0.75 !important;
}

/* Hover */
button.slideshow-control.button-unstyled--transparent:hover{
  border-color: rgba(159,95,84,0.35) !important;
  transform: translateY(-1px) !important;
}

button.slideshow-control.button-unstyled--transparent:hover svg{
  stroke: #9F5F54 !important;
  opacity: 1 !important;
}
/* Icônes flèches — force stroke/fill */
button.slideshow-control.button-unstyled--transparent svg,
button.slideshow-control.button-unstyled--transparent svg *{
  stroke: #1A1A1A !important;
  fill: none !important;
  opacity: 0.85 !important;
  filter: none !important;
}

/* Hover: terracotta */
button.slideshow-control.button-unstyled--transparent:hover svg,
button.slideshow-control.button-unstyled--transparent:hover svg *{
  stroke: #9F5F54 !important;
  fill: none !important;
  opacity: 1 !important;
}
button.slideshow-control.button-unstyled--transparent::before,
button.slideshow-control.button-unstyled--transparent::after{
  content: none !important;
  display: none !important;
}
/* ===================================== */
/* RESET TOTAL flèches carrousel */
/* ===================================== */

button.slideshow-control{
  background: rgba(245, 242, 238, 0.95) !important;
  border: 1px solid rgba(26,26,26,0.08) !important;
  border-radius: 999px !important;
  width: 38px !important;
  height: 38px !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06) !important;
}

/* Supprime tout remplissage noir interne */
button.slideshow-control svg{
  fill: none !important;
}

button.slideshow-control svg circle{
  display: none !important;
}

button.slideshow-control svg path{
  stroke: #1A1A1A !important;
  fill: none !important;
  stroke-width: 2 !important;
}

/* Hover */
button.slideshow-control:hover{
  border-color: rgba(159,95,84,0.35) !important;
}

button.slideshow-control:hover svg path{
  stroke: #9F5F54 !important;
}
/* ===================================== */
/* CARROUSEL — OVERRIDE TOTAL FLÈCHES    */
/* ===================================== */

button.slideshow-control{
  /* on neutralise toutes les astuces du thème */
  background-image: none !important;
  mask-image: none !important;
  -webkit-mask-image: none !important;
  filter: none !important;

  /* notre bouton premium */
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  background: rgba(245, 242, 238, 0.95) !important; /* beige */
  border: 1px solid rgba(26,26,26,0.10) !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.06) !important;

  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* on cache complètement l’icône d’origine (celle qui contient le rond noir) */
button.slideshow-control svg{
  display: none !important;
}

/* on dessine une flèche fine en CSS */
button.slideshow-control::after{
  content: "" !important;
  width: 8px !important;
  height: 8px !important;
  border-right: 2px solid #1A1A1A !important;
  border-bottom: 2px solid #1A1A1A !important;
  transform: rotate(135deg) !important; /* flèche gauche par défaut */
  opacity: 0.85 !important;
}

/* flèche droite */
button.slideshow-control--next::after{
  transform: rotate(-45deg) !important;
}

/* hover terracotta */
button.slideshow-control:hover{
  border-color: rgba(159,95,84,0.35) !important;
}
button.slideshow-control:hover::after{
  border-right-color: #9F5F54 !important;
  border-bottom-color: #9F5F54 !important;
  opacity: 1 !important;
}
/* Mobile : on garde le swipe, on masque les flèches */
@media (max-width: 749px){
  button.slideshow-control{
    display: none !important;
  }
}

/* Mobile : dots visibles et premium */
@media (max-width: 749px){
  slideshow-controls .slider-dots__dot,
  slideshow-controls .slider-counter__link{
    width: 6px !important;
    height: 6px !important;
    border-radius: 999px !important;
    background: rgba(26,26,26,0.18) !important;
  }
  slideshow-controls .slider-dots__dot[aria-current="true"],
  slideshow-controls .slider-counter__link.is-active{
    background: rgba(159,95,84,0.75) !important;
  }
}
/* Supprimer les flèches du carrousel partout */
button.slideshow-control{
  display: none !important;
}
/* Desktop : flèches uniquement au hover (premium) */
@media (min-width: 750px){
  button.slideshow-control{
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity .2s ease !important;
  }

  media-gallery:hover button.slideshow-control,
  .media-gallery:hover button.slideshow-control{
    opacity: 1 !important;
    pointer-events: auto !important;
  }
}
/* ============================= */
/* PRODUIT — Miniatures visibles */
/* ============================= */

@media (min-width: 750px){
  .product media-gallery .thumbnail-list,
  .product .media-gallery .thumbnail-list,
  .product .thumbnail-list{
    display: flex !important;
    gap: 10px !important;
    margin-top: 14px !important;
    justify-content: flex-start !important;
  }

  .product .thumbnail-list__item,
  .product .thumbnail-list__item button{
    border-radius: 12px !important;
    overflow: hidden !important;
  }

  .product .thumbnail-list__item button{
    border: 1px solid rgba(26,26,26,0.10) !important;
    background: transparent !important;
    padding: 0 !important;
  }

  .product .thumbnail-list__item[aria-current="true"] button,
  .product .thumbnail-list__item button[aria-current="true"]{
    border-color: rgba(159,95,84,0.55) !important; /* terracotta subtil */
  }
}
/* Mobile : pas de flèches */
@media (max-width: 749px){
  button.slideshow-control{
    display: none !important;
  }
}

/* Desktop : flèches visibles */
@media (min-width: 750px){
  button.slideshow-control{
    display: inline-flex !important;
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }
}
/* Flèches style premium */
@media (min-width: 750px){

  button.slideshow-control{
    width: 38px !important;
    height: 38px !important;
    border-radius: 999px !important;

    background: rgba(245,242,238,0.95) !important;
    border: 1px solid rgba(26,26,26,0.08) !important;
    box-shadow: 0 8px 24px rgba(0,0,0,0.06) !important;

    transition: all .2s ease !important;
  }

  button.slideshow-control svg{
    stroke: #1A1A1A !important;
    fill: none !important;
    opacity: .8 !important;
  }

  button.slideshow-control:hover{
    border-color: rgba(159,95,84,0.35) !important;
    transform: translateY(-1px) !important;
  }

  button.slideshow-control:hover svg{
    stroke: #9F5F54 !important;
    opacity: 1 !important;
  }
}
/* Supprimer les dots du carrousel produit */
slideshow-controls,
.slider-dots,
.slider-counter{
  display: none !important;
}
/* ============================= */
/* CARROUSEL — flèches sans rond */
/* ============================= */

@media (min-width: 750px){

  /* Supprime le fond rond */
  button.slideshow-control{
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    width: auto !important;
    height: auto !important;
    padding: 0 !important;
  }

  /* Supprime tout fond SVG noir */
  button.slideshow-control svg{
    fill: none !important;
  }

  /* Style flèche */
  button.slideshow-control svg path{
    stroke: #1A1A1A !important; /* noir doux */
    stroke-width: 2 !important;
    fill: none !important;
    opacity: 0.8 !important;
  }

  /* Hover terracotta */
  button.slideshow-control:hover svg path{
    stroke: #9F5F54 !important;
    opacity: 1 !important;
  }

}
/* ===================================== */
/* FLÈCHES SANS RONDS — OVERRIDE TOTAL   */
/* ===================================== */

@media (min-width: 750px){

  /* Le bouton devient transparent */
  button.slideshow-control{
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
    width: 44px !important;   /* zone cliquable confortable */
    height: 44px !important;
    border-radius: 0 !important;

    background-image: none !important;
    mask-image: none !important;
    -webkit-mask-image: none !important;

    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* On tue TOUT ce que le thème dessine (souvent le rond noir) */
  button.slideshow-control::before,
  button.slideshow-control::after{
    background: none !important;
    box-shadow: none !important;
    filter: none !important;
  }

  /* On masque l'icône SVG d'origine (qui contient le rond noir) */
  button.slideshow-control svg{
    display: none !important;
  }

  /* On dessine une flèche fine en CSS */
  button.slideshow-control span,
  button.slideshow-control i{
    display: none !important;
  }

  button.slideshow-control{
    /* rien */
  }

  /* Flèche gauche par défaut */
  button.slideshow-control::after{
    content: "" !important;
    width: 9px !important;
    height: 9px !important;
    border-left: 2px solid #1A1A1A !important;
    border-bottom: 2px solid #1A1A1A !important;
    transform: rotate(45deg) !important;
    opacity: 0.85 !important;
  }

  /* Flèche droite */
  button.slideshow-control--next::after{
    transform: rotate(-135deg) !important;
  }

  /* Hover terracotta */
  button.slideshow-control:hover::after{
    border-left-color: #9F5F54 !important;
    border-bottom-color: #9F5F54 !important;
    opacity: 1 !important;
  }
}
@media (min-width: 750px){
  slideshow-arrows,
  .slideshow-arrows,
  .media-gallery--carousel slideshow-arrows{
    background: transparent !important;
  }
}
/* ================================================== */
/* FIX DEFINITIF — enlever ronds (fond du bouton)     */
/* ================================================== */
@media (min-width: 750px){

  /* Le bouton NE DOIT PAS être un rond rempli */
  button.slideshow-control.button-unstyled--transparent{
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    border-radius: 0 !important;
    width: 44px !important;   /* zone cliquable */
    height: 44px !important;
    padding: 0 !important;
  }

  /* On neutralise les états qui remettent un fond */
  button.slideshow-control.button-unstyled--transparent:hover,
  button.slideshow-control.button-unstyled--transparent:focus,
  button.slideshow-control.button-unstyled--transparent:active,
  button.slideshow-control.button-unstyled--transparent:focus-visible{
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
  }

  /* Flèche : noir doux -> terracotta au hover */
  button.slideshow-control.button-unstyled--transparent svg{
    fill: none !important;
  }

  button.slideshow-control.button-unstyled--transparent svg path{
    stroke: #1A1A1A !important;
    stroke-width: 2 !important;
    opacity: .85 !important;
  }

  button.slideshow-control.button-unstyled--transparent:hover svg path{
    stroke: #9F5F54 !important;
    opacity: 1 !important;
  }
}
@media (min-width: 750px){
  button.slideshow-control.button-unstyled--transparent{
    opacity: 0 !important;
    transition: opacity .2s ease !important;
  }
  media-gallery:hover button.slideshow-control.button-unstyled--transparent,
  .media-gallery:hover button.slideshow-control.button-unstyled--transparent{
    opacity: 1 !important;
  }
}
/* ===================================== */
/* PRODUIT — miniatures sous l'image     */
/* ===================================== */

@media (min-width: 750px){

  /* La liste de miniatures */
  .product .thumbnail-list,
  .product media-gallery .thumbnail-list,
  .product .media-gallery .thumbnail-list{
    display: flex !important;
    gap: 10px !important;
    margin-top: 14px !important;
    justify-content: flex-start !important;
    overflow-x: auto !important;
    padding-bottom: 6px !important;
  }

  /* Chaque miniature */
  .product .thumbnail-list__item{
    flex: 0 0 auto !important;
  }

  .product .thumbnail-list__item button{
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid rgba(26,26,26,0.10) !important;
    background: transparent !important;
    padding: 0 !important;
    transition: border-color .2s ease !important;
  }

  /* Miniature active */
  .product .thumbnail-list__item[aria-current="true"] button{
    border-color: rgba(159,95,84,0.55) !important; /* terracotta subtil */
  }
}
/* Eclora — thumbnails sous l'image */
.product-media-gallery {
  display: flex;
  flex-direction: column;
}

.product-media-gallery__thumbnails {
  order: 2;
  margin-top: 16px;
}
/* Eclora — miniatures sous l'image */
.product-media-gallery {
  display: flex;
  flex-direction: column;
}

.product-media-gallery__thumbnails {
  order: 2;
  margin-top: 16px;
}
/* Eclora — miniatures sous l'image */
.product-media-gallery {
  display: flex;
  flex-direction: column;
}

.product-media-gallery__thumbnails {
  order: 2;
  margin-top: 18px;
}
/* Eclora — Force miniatures SOUS l'image (desktop) */
@media screen and (min-width: 750px) {
  /* Conteneur galerie (Dawn & dérivés) */
  .product__media-wrapper .media-gallery,
  .product__media-wrapper media-gallery,
  .product__media-wrapper .product-media-gallery,
  .product__media-wrapper product-media-gallery {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Zone image principale */
  .product__media-wrapper .media-gallery__viewer,
  .product__media-wrapper .product-media-gallery__viewer,
  .product__media-wrapper .slider,
  .product__media-wrapper .slideshow {
    order: 1 !important;
    width: 100% !important;
  }

  /* Zone miniatures (plusieurs variantes de thèmes) */
  .product__media-wrapper .thumbnail-slider,
  .product__media-wrapper .thumbnail-list,
  .product__media-wrapper .product-media-gallery__thumbnails,
  .product__media-wrapper .media-gallery__thumbnails {
    order: 2 !important;
    width: 100% !important;
    margin-top: 16px !important;

    /* miniatures en ligne */
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 10px !important;

    /* évite le “panneau latéral” */
    max-height: none !important;
  }

  /* Items miniatures */
  .product__media-wrapper .thumbnail-list__item,
  .product__media-wrapper .thumbnail-slider__slide,
  .product__media-wrapper .product-media-gallery__thumbnail {
    flex: 0 0 auto !important;
  }
}
/* Eclora — force les miniatures SOUS l'image (desktop only) */
@media screen and (min-width: 750px) {

  /* Le wrapper global galerie (Dawn + dérivés) */
  .product__media-wrapper media-gallery,
  .product__media-wrapper .media-gallery,
  .product__media-wrapper product-media-gallery,
  .product__media-wrapper .product-media-gallery {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Le viewer (image principale / slider) */
  .product__media-wrapper .media-gallery__viewer,
  .product__media-wrapper .product-media-gallery__viewer,
  .product__media-wrapper .slider {
    order: 1 !important;
    width: 100% !important;
  }

  /* Les miniatures (naming Dawn & variantes) */
  .product__media-wrapper .thumbnail-slider,
  .product__media-wrapper .thumbnail-list,
  .product__media-wrapper .media-gallery__thumbnails,
  .product__media-wrapper .product-media-gallery__thumbnails {
    order: 2 !important;
    width: 100% !important;
    margin-top: 16px !important;

    /* forcer en ligne sous l'image */
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    justify-content: center !important;

    /* empêche la colonne latérale */
    max-height: none !important;
  }

  /* Si ton thème a un mode vertical */
  .product__media-wrapper .thumbnail-slider--vertical,
  .product__media-wrapper .thumbnail-list--vertical {
    flex-direction: row !important;
  }
}
@media screen and (min-width: 750px) {

  /* si la galerie est en grid, on annule et on repasse en colonne */
  .product__media-wrapper .media-gallery,
  .product__media-wrapper media-gallery {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .product__media-wrapper .thumbnail-slider,
  .product__media-wrapper .thumbnail-list,
  .product__media-wrapper .media-gallery__thumbnails {
    grid-column: 1 / -1 !important;
  }
}
/* Eclora — miniatures sous l'image (theme dialog-*) */
@media screen and (min-width: 750px) {

  /* Le wrapper global de la galerie doit être en colonne */
  .product__media-wrapper .dialog-media-gallery,
  .product__media-wrapper .dialog-gallery,
  .product__media-wrapper .media-gallery,
  .product__media-wrapper media-gallery {
    display: flex !important;
    flex-direction: column !important;
  }

  /* La zone miniatures prend toute la largeur et passe en dessous */
  .product__media-wrapper .dialog-thumbnails-list-container {
    order: 2 !important;
    width: 100% !important;
    margin-top: 16px !important;
  }

  /* La liste de miniatures devient une rangée horizontale */
  .product__media-wrapper .dialog-thumbnails-list {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    justify-content: center !important;

    /* on annule les contraintes “colonne à droite” */
    max-height: none !important;
  }

  /* Les boutons miniatures */
  .product__media-wrapper .dialog-thumbnails-list__thumbnail {
    flex: 0 0 auto !important;
  }
}
@media screen and (min-width: 750px) {
  .product__media-wrapper .dialog-media-gallery,
  .product__media-wrapper .dialog-gallery,
  .product__media-wrapper .media-gallery {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .product__media-wrapper .dialog-thumbnails-list-container {
    grid-column: 1 / -1 !important;
  }
}
/* Eclora — miniatures sous image (layout grid fix) */
@media screen and (min-width: 750px) {

  /* On force la galerie en une seule colonne */
  slideshow-slide.product-media-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }

  /* Image principale = ligne 1 */
  slideshow-slide.product-media-container .product-media {
    grid-row: 1 !important;
  }

  /* Miniatures = ligne 2 */
  slideshow-slide.product-media-container .slideshow-controls,
  slideshow-slide.product-media-container .thumbnail-list,
  slideshow-slide.product-media-container .thumbnail-slider {
    grid-row: 2 !important;
    margin-top: 16px !important;
  }
}
@media screen and (min-width: 750px) {

  .thumbnail-list button,
  .thumbnail-slider button {
    opacity: .6;
    transition: opacity .25s ease;
    border: none;
  }

  .thumbnail-list button[aria-selected="true"],
  .thumbnail-slider button[aria-selected="true"] {
    opacity: 1;
  }

  .thumbnail-list button:hover,
  .thumbnail-slider button:hover {
    opacity: .85;
  }
}
/* Eclora — miniatures sous l'image (inline product gallery) */
@media screen and (min-width: 750px) {
  /* Le container devient une colonne : slides puis controls */
  slideshow-container {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Zone image/slider en premier */
  slideshow-container > slideshow-slides {
    order: 1 !important;
    width: 100% !important;
  }

  /* Controls (miniatures/points) en dessous */
  slideshow-container > slideshow-controls {
    order: 2 !important;
    width: 100% !important;
    margin-top: 16px !important;

    /* centre, sobre, premium */
    display: flex !important;
    justify-content: center !important;
  }
}
@media screen and (min-width: 750px) {
  slideshow-container > slideshow-controls .thumbnail-list,
  slideshow-container > slideshow-controls .thumbnail-slider {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    justify-content: center !important;
    width: 100% !important;
    max-height: none !important;
  }
}
@media screen and (min-width: 750px) {
  slideshow-container > slideshow-controls button {
    border: none !important;
    box-shadow: none !important;
    opacity: .55;
    transition: opacity .25s ease;
  }

  slideshow-container > slideshow-controls button[aria-selected="true"],
  slideshow-container > slideshow-controls button[aria-current="true"] {
    opacity: 1;
  }

  slideshow-container > slideshow-controls button:hover {
    opacity: .85;
  }
}
/* Eclora — FORCE miniatures sous l'image (desktop) */
@media screen and (min-width: 750px) {

  /* 1) Le container passe en grid 1 colonne */
  .product__media-wrapper slideshow-container,
  .product__media-wrapper .slideshow-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
    align-items: start !important;
  }

  /* 2) Le slider (images) = ligne 1 */
  .product__media-wrapper slideshow-container > slideshow-slides,
  .product__media-wrapper .slideshow-container > .scroller,
  .product__media-wrapper slideshow-slides.scroller {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
  }

  /* 3) Les controls (miniatures/points) = ligne 2 + on annule tout positionnement */
  .product__media-wrapper slideshow-container > slideshow-controls,
  .product__media-wrapper slideshow-controls[ref="slideshowControls"],
  .product__media-wrapper .slideshow-controls {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;

    position: static !important;
    inset: auto !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;

    width: 100% !important;
    margin-top: 16px !important;

    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  /* 4) Si les miniatures sont dans une liste interne, on force l'horizontal */
  .product__media-wrapper slideshow-controls .thumbnail-list,
  .product__media-wrapper slideshow-controls .thumbnail-slider,
  .product__media-wrapper .slideshow-controls .thumbnail-list,
  .product__media-wrapper .slideshow-controls .thumbnail-slider {
    display: flex !important;
    flex-direction: row !important;
    gap: 10px !important;
    justify-content: center !important;
    max-height: none !important;
  }
}
@media screen and (min-width: 750px) {
  slideshow-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }

  slideshow-container > slideshow-controls {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    width: 100% !important;
    margin-top: 16px !important;
    display: flex !important;
    justify-content: center !important;
  }
}
/* Eclora — Galerie produit : miniatures SOUS l'image (desktop) */
@media screen and (min-width: 750px) {

  /* 1) On cible UNIQUEMENT la galerie de la fiche produit */
  .product__media-wrapper slideshow-container {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }

  /* 2) Images = ligne 1 */
  .product__media-wrapper slideshow-container > slideshow-slides {
    grid-column: 1 / -1 !important;
    grid-row: 1 !important;
  }

  /* 3) Controls (miniatures) = ligne 2 + on annule toute position */
  .product__media-wrapper slideshow-container > slideshow-controls {
    grid-column: 1 / -1 !important;
    grid-row: 2 !important;

    position: static !important;
    inset: auto !important;
    transform: none !important;

    width: 100% !important;
    margin-top: 16px !important;

    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  /* 4) Si la liste interne est “verticale”, on force l'horizontal */
  .product__media-wrapper slideshow-container > slideshow-controls .dialog-thumbnails-list,
  .product__media-wrapper slideshow-container > slideshow-controls .thumbnail-list,
  .product__media-wrapper slideshow-container > slideshow-controls .thumbnail-slider {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 10px !important;
    width: 100% !important;
    max-height: none !important;
  }
}
/* Eclora — annule la colonne thumbs à droite au niveau du container produit */
@media screen and (min-width: 750px) {
  .product__media-wrapper .product-media-container {
    grid-template-columns: 1fr !important;
  }
}
}
/* Eclora — thumbs sous image (desktop) : restructure le wrapper produit */
@media screen and (min-width: 750px) {

  /* Le wrapper global médias produit passe en colonne */
  .product-media-container {
    display: flex !important;
    flex-direction: column !important;
  }

  /* Le slider d'images d'abord */
  .product-media-container slideshow-slides {
    order: 1 !important;
  }

  /* Les controls (miniatures/points) sous l'image */
  .product-media-container slideshow-controls {
    order: 2 !important;
    position: static !important;
    inset: auto !important;
    transform: none !important;

    width: 100% !important;
    margin-top: 16px !important;

    display: flex !important;
    justify-content: center !important;
  }
}
/* Eclora — FORCE miniatures sous l'image (INLINE, desktop) */
@media screen and (min-width: 750px) {

  /* On scope très fort pour battre les règles du thème */
  #MainContent .product-media-container ~ slideshow-controls,
  #MainContent slideshow-container > slideshow-controls,
  #MainContent slideshow-container[ref="slideshowContainer"] > slideshow-controls,
  #MainContent slideshow-controls[ref="slideshowControls"] {
    position: static !important;
    inset: auto !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;

    display: flex !important;
    justify-content: center !important;
    align-items: center !important;

    width: 100% !important;
    margin-top: 16px !important;

    opacity: 1 !important;
    visibility: visible !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  /* Le container doit empiler : slides puis controls */
  #MainContent slideshow-container,
  #MainContent slideshow-container[ref="slideshowContainer"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto !important;
  }

  #MainContent slideshow-container > slideshow-slides,
  #MainContent slideshow-container[ref="slideshowContainer"] > slideshow-slides {
    grid-row: 1 !important;
    grid-column: 1 / -1 !important;
  }

  #MainContent slideshow-container > slideshow-controls,
  #MainContent slideshow-container[ref="slideshowContainer"] > slideshow-controls {
    grid-row: 2 !important;
    grid-column: 1 / -1 !important;
  }

  /* Si la liste interne est verticale / contrainte, on la met horizontale */
  #MainContent slideshow-controls .thumbnail-list,
  #MainContent slideshow-controls .thumbnail-slider,
  #MainContent slideshow-controls .dialog-thumbnails-list {
    display: flex !important;
    flex-direction: row !important;
    justify-content: center !important;
    gap: 10px !important;

    width: 100% !important;
    max-height: none !important;
    overflow: visible !important;
  }
}
/* Eclora — Miniatures premium */
@media screen and (min-width: 750px) {

  /* Espacement respirant */
  #MainContent slideshow-controls {
    margin-top: 22px !important;
  }

  /* Ligne horizontale élégante */
  #MainContent slideshow-controls .thumbnail-list,
  #MainContent slideshow-controls .thumbnail-slider,
  #MainContent slideshow-controls .dialog-thumbnails-list {
    gap: 14px !important;
  }

  /* Boutons miniatures */
  #MainContent slideshow-controls button {
    border: none !important;
    box-shadow: none !important;
    background: none !important;

    opacity: .55;
    transition: opacity .25s ease;
  }

  /* État actif — sobre */
  #MainContent slideshow-controls button[aria-selected="true"],
  #MainContent slideshow-controls button[aria-current="true"] {
    opacity: 1;
  }

  /* Hover doux */
  #MainContent slideshow-controls button:hover {
    opacity: .8;
  }
}
#MainContent slideshow-controls button[aria-selected="true"] {
  position: relative;
}

#MainContent slideshow-controls button[aria-selected="true"]::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 20%;
  width: 60%;
  height: 1px;
  background: #c46f5a; /* ton terracotta */
}
/* Eclora — fond galerie plus premium */
.product-media-container {
  background: transparent !important;
}
/* Eclora — Taille miniatures (desktop) */
@media screen and (min-width: 750px) {
  :root { --eclora-thumb: 90px; } /* mets 68px si tu veux plus grand */

  #MainContent slideshow-controls button {
    width: var(--eclora-thumb) !important;
    height: var(--eclora-thumb) !important;
    padding: 0 !important;
  }

  #MainContent slideshow-controls button img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
  }
}
#MainContent slideshow-controls {
  background: transparent !important;
  padding-top: 8px !important;
  padding-bottom: 4px !important;
}
#MainContent slideshow-controls button {
  opacity: .65;
  transition: all .25s ease;
}

#MainContent slideshow-controls button[aria-selected="true"] {
  opacity: 1;
  transform: scale(1.05);
}

#MainContent slideshow-controls button:hover {
  opacity: .9;
}
#MainContent slideshow-controls button[aria-selected="true"]::after {
  content: "";
  position: absolute;
  bottom: -6px;
  left: 25%;
  width: 50%;
  height: 1px;
  background: #9c5c4d; /* ton terracotta */
}
@media screen and (min-width: 750px) {
  #MainContent slideshow-controls button:not([class*="thumbnail"]):not(.dialog-thumbnails-list__thumbnail) {
    display: none !important;
  }
}
/* Eclora — image produit moins zoomée */
@media screen and (min-width: 750px) {
  .product-media img {
    object-fit: contain !important;
  }
}
/* Eclora — Anti-zoom image principale (desktop) */
@media screen and (min-width: 750px) {
  /* Cas le plus fréquent : Shopify met cover sur .media img */
  .product-media-container--image img,
  .product-media-container--image .media img,
  .product-media-container--image picture img {
    object-fit: contain !important;
    object-position: 50% 50% !important;
  }

  /* Fond transparent si letterboxing */
  .product-media-container--image .media {
    background: transparent !important;
  }
}
@media screen and (min-width: 750px) {
  .product-media-container--image .media {
    background-size: contain !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
  }
}
/* Eclora — hauteur image plus équilibrée */
@media screen and (min-width: 750px) {
  .product-media-container {
    --grid-template-rows-desktop: 58dvh 1fr !important; /* essaye 55–62 */
  }
}
/* Eclora — hauteur image plus équilibrée */
@media screen and (min-width: 750px) {
  .product-media-container {
    --grid-template-rows-desktop: 58dvh 1fr !important; /* essaye 55–62 */
  }
}
/* Eclora — position de l'image (desktop) */
@media screen and (min-width: 750px) {
  .product-media-container--image img,
  .product-media-container--image .media img,
  .product-media-container--image picture img {
    object-fit: contain !important;
    object-position: 42% !important; /* remonte légèrement */
  }
}
/* Eclora — cover plus doux (si tu préfères plein cadre) */
@media screen and (min-width: 750px) {
  .product-media-container--image img,
  .product-media-container--image .media img,
  .product-media-container--image picture img {
    object-fit: cover !important;
    object-position: 50% 35% !important; /* évite de couper le sujet */
  }
}
/* Eclora — hauteur image équilibrée (desktop) */
@media screen and (min-width: 750px) {

  slideshow-slide.product-media-container {
    --grid-template-rows-desktop: auto !important;
  }

  .product-media-container {
    min-height: auto !important;
  }

  .product-media-container .media {
    height: auto !important;
  }

}
/* Eclora — enlever l'effet zoom (ratio forcé) */
@media screen and (min-width: 750px) {

  /* On annule le ratio imposé par le thème */
  .product-media-container,
  .product-media-container .product-media,
  .product-media-container .media {
    aspect-ratio: auto !important;
  }

  /* On empêche le crop */
  .product-media__image,
  .product-media-container img {
    object-fit: contain !important;
    height: auto !important;
    max-height: none !important;
  }

}
@media screen and (min-width: 750px) {
  .product-media-container .media {
    max-height: 620px !important;
  }
}
/* Mobile — rendre le bouton menu visible et cliquable */
@media screen and (max-width: 749px) {
  header,
  .header,
  .section-header {
    position: relative;
    z-index: 50 !important;
  }
}
/* Mobile — éviter qu’un bloc recouvre le header */
@media screen and (max-width: 749px) {
  .shopify-section-group-header-group,
  .shopify-section-header-sticky,
  .shopify-section--header {
    position: relative;
    z-index: 100 !important;
  }
}
}
/* Mobile — icône menu visible (SVG + mask) */
@media screen and (max-width: 749px) {
  /* force la couleur du header (souvent currentColor) */
  header, .header {
    color: #b7795f !important;
  }
}
/* Mobile — afficher l’icône du menu (mask / svg) */
@media screen and (max-width: 749px) {

  /* 1) Le header doit avoir une couleur foncée (currentColor) */
  header, .header {
    color: #b7795f !important;
  }

  /* 2) Cas SVG : on force stroke/fill */
  header svg, .header svg {
    opacity: 1 !important;
  }
  header svg *, .header svg * {
    stroke: currentColor !important;
    fill: currentColor !important;
  }

  /* 3) Cas MASK-IMAGE : l’icône prend la couleur du background-color */
  header .icon,
  .header .icon,
  header [class*="icon"],
  .header [class*="icon"] {
    background-color: currentColor !important;
  }
}
/* Eclora — Mobile : icône menu visible (sans carré) */
@media screen and (max-width: 749px) {
  /* Couleur du header = couleur des icônes (currentColor) */
  header, .header {
    color: #b7795f !important;
  }
}
/* Trait au-dessus du kicker */
.eclora-kicker{
  position: relative;
  padding-top: 18px;
}

.eclora-kicker::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;

  width: 60px;
  height: 2px;
  background: #A06557;
}
/* Trait premium au-dessus du kicker */
.eclora-kicker{
  position: relative;
  padding-top: 22px;
}

.eclora-kicker::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;

  width: 64px;
  height: 1px;
  background: #A06557;
  opacity: 0.7;
}
.eclora-hero__content{
  align-items: flex-start;
  text-align: left;
}
/* Décaler l'image hero vers la droite */
.eclora-hero__media{
  margin-left: 40px;
}
/* Décalage éditorial de l'image hero */
.eclora-hero__media{
  transform: translateX(40px);
}

.eclora-hero{
  overflow: hidden;
}
/* Panier plus petit sur desktop */
@media screen and (min-width: 990px){

  button[data-testid="cart-drawer-trigger"]{
    width: 36px;
    height: 36px;
  }

  button[data-testid="cart-drawer-trigger"] svg{
    width: 36px;
    height: 36px;
  }

}
/* TEST réduire hauteur hero */
.eclora-hero{
  padding-top: 80px !important;
  padding-bottom: 80px !important;
}
/* HERO mobile — passer en 1 colonne */
@media screen and (max-width: 990px){

  .eclora-hero__grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  .eclora-hero__media{
    order: 1;
    width: 100%;
    transform: none !important;
    margin: 0 !important;
  }

  .eclora-hero__content{
    order: 2;
    text-align: left;
    padding: 0;
  }

}
/* TEST 1A — BASE (mobile) */
@media (max-width: 990px){
  .eclora-section { background: transparent !important; }
}
/* FIX MOBILE — force 1 colonne (ciblage très fort) */
@media (max-width: 990px){
  .eclora-section .eclora-container .eclora-hero__grid{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }

  .eclora-section .eclora-container .eclora-hero__media{
    transform: none !important;
    margin: 0 !important;
    width: 100% !important;
  }

  .eclora-section .eclora-container .eclora-hero__content{
    padding: 0 !important;
    text-align: left !important;
    align-items: flex-start !important;
  }
}
/* Éditeur Shopify — masquer l'outline de sélection */
.shopify-section:focus,
.shopify-section *:focus {
  outline: none !important;
}
/* Mobile — centrer l'image hero */
@media (max-width: 990px){
  .eclora-section .eclora-hero__media{
    justify-self: center !important;
    width: 100% !important;
  }
/* Mobile — un seul trait au-dessus du kicker */
@media (max-width: 990px){
  .eclora-hero__content > .eclora-kicker::after{
    content: none !important;
    display: none !important;
  }
}
/* HERO mobile — image centrée pleine largeur */
@media (max-width: 990px){

  .eclora-hero__media{
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }

  .eclora-hero__media img{
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 auto !important;
    display: block !important;
  }

}
/* HERO mobile — image centrée (pas full width) */
@media (max-width: 990px){

  .eclora-hero__media{
    width: 100% !important;
    display: flex !important;
    justify-content: center !important;
  }

  .eclora-hero__media img{
    width: min(320px, 100%) !important;   /* ajuste 300–360px */
    height: auto !important;
    display: block !important;
    margin: 0 auto !important;
  }

}
/* HERO — enlever tout background ajouté (tests / overrides) */
.eclora-section,
.eclora-container,
.eclora-hero,
.eclora-hero__grid,
.eclora-hero__content,
.eclora-hero__media{
  background: transparent !important;
}
/* HERO — padding transparent */
.eclora-section .eclora-container{
  background: transparent !important;
}
/* TEST — déplacer l'image fortement */
@media (max-width: 990px){

  .eclora-hero__media{
    transform: translateX(-60px) !important;
  }

}
/* TEST GRID */
@media (max-width: 990px){

  .eclora-hero__grid{
    transform: translateX(-15px) !important;
  }

}
.eclora-hero__text{
  margin-bottom: 18px;
}

.eclora-hero__subtext{
  margin-top: 0;
}
/* ECLORA BENEFITS — force desktop 3 colonnes */
@media (min-width: 990px){
  body .eclora-benefits .eclora-benefits__grid{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 40px !important;
    align-items: start !important;
  }

  body .eclora-benefits .eclora-benefits__item{
    width: auto !important;
    max-width: none !important;
  }
}
/* Fix section bénéfices */
.eclora-benefits__grid.grid{
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 40px !important;
}
@media (min-width: 990px){
  body .eclora-benefits__grid.grid{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 40px !important;
    align-items: start !important;

    /* au cas où le thème force du flex */
    flex: none !important;
    flex-wrap: unset !important;
  }
}
/* BENEFITS — force desktop (ciblage Shopify section ID) */
@media (min-width: 750px){
  [id*="__eclora_benefits"] .eclora-benefits__grid{
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 40px !important;
    width: 100% !important;
  }

  [id*="__eclora_benefits"] .eclora-benefits__item{
    width: auto !important;
    max-width: none !important;
    justify-self: stretch !important;
  }
}
.separator-eclora{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:36px 0;
  color:#c9b8aa;
}
/* ===== HERO TEXT WHITE OVERRIDE ===== */

.banner__content,
.banner__content * ,
.banner__box,
.banner__box * ,
.banner__heading,
.banner__heading *,
.banner__text,
.banner__text *,
.banner__buttons,
.banner__buttons * {
  color: #ffffff !important;
}

/* CTA button */
.banner__buttons .button,
.banner__buttons .button--primary {
  color: #ffffff !important;
  border-color: #ffffff !important;
}

/* Optional text shadow for readability */
.banner__content * {
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}
/* FORCE TEXTE HERO EN BLANC */
section[id*="Banner"] *,
section[id*="banner"] *,
[id*="Banner"] .rte *,
[id*="banner"] .rte *,
[id*="Banner"] h1,
[id*="Banner"] h2,
[id*="Banner"] p,
[id*="banner"] h1,
[id*="banner"] h2,
[id*="banner"] p {
  color: #fff !important;
}

/* Si le texte est dans des blocs custom du thème */
.hero *,
.hero__content *,
.hero-banner *,
.hero-banner__content *,
.slideshow *,
.slideshow__text *,
.image-banner *,
.image-banner__content * {
  color: #fff !important;
}

/* Ombre pour lisibilité */
section[id*="Banner"] h1,
section[id*="Banner"] h2,
section[id*="Banner"] p,
section[id*="banner"] h1,
section[id*="banner"] h2,
section[id*="banner"] p {
  text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45) !important;
}
/* FORCE TEXTE HERO EN BLANC - DESKTOP + MOBILE */
@media screen and (min-width: 750px) {
  .banner__content h1,
  .banner__content h2,
  .banner__content p,
  .banner__content span,
  .banner__content div,
  .banner__heading,
  .banner__text,
  .banner__text p,
  .banner__box,
  .banner__box * {
    color: #ffffff !important;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45) !important;
  }
}

/* Sélecteur plus large si ton thème utilise un hero custom */
@media screen and (min-width: 750px) {
  section[class*="banner"] *,
  section[class*="Banner"] *,
  section[class*="hero"] *,
  section[class*="Hero"] * {
    color: #ffffff !important;
  }
}