/** Shopify CDN: Minification failed

Line 4056:0 Unexpected "{"
Line 4056:1 Expected identifier but found "%"
Line 4206:0 Unexpected "{"
Line 4206:1 Expected identifier but found "%"
Line 4804:285 Unexpected "!"
Line 6761:66 Unexpected "{"
Line 6802:60 Unexpected "{"
Line 7238:0 Unexpected "<"
Line 7250:12 Expected identifier but found whitespace
Line 7250:14 Unexpected "{"
... and 7 more hidden warnings

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

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

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

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

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

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

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

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

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

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

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

{% stylesheet %}
.ip-piercings{max-width:1100px;margin:0 auto;padding:0 20px}
.ip-head{
  text-align:center;
  padding:60px 0 48px;
}

.ip-title{margin:0 0 10px 0}
.ip-subtitle{
  margin:0 0 32px 0;
  opacity:.7;
}

.ip-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin:0}
.ip-tab{
  font-family:Montserrat, var(--font-body-family), sans-serif;
  font-size:14px;
  padding:10px 18px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.16);
  background:transparent;
  cursor:pointer;
  transition:background-color .25s ease,border-color .25s ease,opacity .25s ease;
  outline:none;
}
.ip-tab:hover{background:rgba(0,0,0,.04);border-color:rgba(0,0,0,.22)}
.ip-tab.is-active{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.28)}

.ip-panels{position:relative}
.ip-panel{display:none;opacity:0;transform:translateY(6px);transition:opacity .28s ease,transform .28s ease}
.ip-panel.is-active{display:block}
.ip-panel.is-show{opacity:1;transform:translateY(0)}

.ip-grid{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:22px;
  padding:18px 0 12px;
}
.ip-card{background:transparent;border:0;padding:0;cursor:pointer;outline:none}
.ip-card__imgwrap{
  width:clamp(200px, 22vw, 270px);
  aspect-ratio:1/1;
  border-radius:22px;
  overflow:hidden;
  position:relative;
}
.ip-card__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.001);
}
.ip-card__label{
  position:absolute;
  left:0;right:0;bottom:0;
  padding:14px 14px 12px;
  text-align:center;
}
.ip-card__name{
  font-size:clamp(12px,1.15vw,15px);
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#fff;
}
.ip-card__price{
  margin-top:4px;
  font-size:clamp(12px,1.1vw,14px);
  color:#fff;
  opacity:.9;
}

.ip-lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index:9999;
}

.ip-lightbox.is-open{
  display:flex;
  align-items:center;
  justify-content:center;
}

.ip-lightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.ip-lightbox__panel{
  position:relative;
  width:min(980px, calc(100% - 28px));
  margin:0;
  background:#fff;
  border-radius:22px;
  overflow:hidden;
  display:grid;
  grid-template-columns:1.05fr .95fr;
}
@media (max-width: 900px){
  .ip-lightbox__panel{grid-template-columns:1fr;margin:12px auto}
}
.ip-lightbox__close{
  position:absolute;top:10px;right:12px;
  width:40px;height:40px;border-radius:999px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff;
  cursor:pointer;
  outline:none;
}
.ip-lightbox__media{
  background:#000;
  display:flex;
  align-items:center;
  justify-content:center;
}

.ip-lightbox__img{
  max-width:100%;
  max-height:min(74vh, 640px);
  width:auto;
  height:auto;
  object-fit:contain;
  display:block;
}

@media (max-width: 900px){
  .ip-lightbox__img{height:min(58vh, 520px)}
}
.ip-lightbox__content{padding:22px}
.ip-lightbox__title{
  margin:0 0 8px 0;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.ip-lightbox__price{font-size:16px;opacity:.75;margin:0 0 10px 0}
.ip-lightbox__text{margin:0 0 16px 0;opacity:.75}
.ip-lightbox__actions{display:flex;flex-wrap:wrap;gap:10px}
.ip-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:10px 16px;border-radius:999px;
  text-decoration:none;
  font-family:Montserrat, var(--font-body-family), sans-serif;
  border:1px solid rgba(0,0,0,.16);
  background:#fff;
  cursor:pointer;
  outline:none;
}
.ip-btn--primary{background:#000;color:#fff;border-color:#000}
.ip-btn--ghost{background:rgba(0,0,0,.04)}
{% endstylesheet %}








.ip-subcategory{
  width:100%;
  margin:40px 0 10px;
  text-align:left;
}

.ip-subcategory h3{
  margin:0;
  font-size:22px;
  letter-spacing:.02em;
}

.ip-subcategory small{
  margin-left:8px;
  font-size:13px;
  opacity:.6;
  font-weight:normal;
}







/* STRASS : 2 par ligne uniquement dans Formes + Spécial, sans agrandir les cards */
.ip-strass [data-ip-panel="formes"] .ip-grid,
.ip-strass [data-ip-panel="special"] .ip-grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 270px));
  justify-content:center;
  gap:22px;
}

/* Mobile : 1 par ligne */
@media (max-width: 700px){
  .ip-strass [data-ip-panel="formes"] .ip-grid,
  .ip-strass [data-ip-panel="special"] .ip-grid{
    grid-template-columns: 1fr;
    justify-items:center;
  }
}

/* Dégradé noir derrière le texte (lisibilité) */
.ip-card__label{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:16px 14px 12px;
  text-align:center;
}

.ip-card__label::before{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:140%;
  background:linear-gradient(to top, rgba(0,0,0,.82) 0%, rgba(0,0,0,.25) 55%, rgba(0,0,0,0) 100%);
  pointer-events:none;
}


.ip-card__name,
.ip-card__price{
  position:relative;
  z-index:1;
}

/* Dégradé plus haut */
.ip-card__label::before{
  height:100%;
  background:linear-gradient(to top, rgba(0,0,0,.78), rgba(0,0,0,0));
}






















.pmu-ba{padding:60px 0}
.pmu-ba__head{text-align:center;margin:0 0 28px}
.pmu-ba__title{margin:0 0 10px}
.pmu-ba__subtitle{margin:0;opacity:.7}

.pmu-ba__grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
}

@media (max-width: 990px){
  .pmu-ba__grid{grid-template-columns:repeat(2, minmax(0, 1fr))}
}
@media (max-width: 750px){
  .pmu-ba__grid{grid-template-columns:1fr}
}

.pmu-ba__item{display:flex;flex-direction:column;gap:12px}

.pmu-ba__frame{
  position:relative;
  width:100%;
  aspect-ratio: 1 / 1;
  border-radius:22px;
  overflow:hidden;
  background:#eee;
}

.pmu-ba__img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.pmu-ba__before{
  position:absolute;
  inset:0;
  width:50%;
  overflow:hidden;
}

.pmu-ba__divider{
  position:absolute;
  top:0; bottom:0;
  left:50%;
  width:2px;
  background:rgba(255,255,255,.85);
  box-shadow:0 0 0 1px rgba(0,0,0,.15);
  transform:translateX(-1px);
  pointer-events:none;
}

.pmu-ba__range{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:ew-resize;
}

.pmu-ba__badges{
  display:flex;
  justify-content:space-between;
  margin-top:10px;
  padding:0 6px;
}

.pmu-ba__badge{
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  opacity:.7;
}

.pmu-ba__meta{
  text-align:center;
}

.pmu-ba__item-title{
  font-size:14px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.pmu-ba__item-text{
  margin-top:6px;
  font-size:13px;
  opacity:.7;
}

/* ============================= */
/* TEXTE DORÉ GLOBAL (TOUT LE SITE) */
/* ============================= */

h1,h2,h3,h4,h5,h6,
p,span,strong,em,small,
a,li,label,figcaption,
blockquote,cite{
  background:linear-gradient(
    180deg,
    #f2df9c 0%,
    #e2c86b 30%,
    #c79a2b 55%,
    #e6cf79 80%,
    #f2df9c 100%
  );
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  color:transparent;

  text-shadow:
    0 0 4px rgba(199,154,43,.25);
}

/* ============================= */
/* MENU HEADER – DORÉ MAT, PROPRE */
/* ============================= */

header a,
.header a{
  background:none;
  color:#c79a2b !important;
  -webkit-text-fill-color:#c79a2b !important;
  text-shadow:none;
}

/* ============================= */
/* BOUTONS (HORS HEADER) */
/* ============================= */

button:not(.nav):not(.thumb),
.button,
.btn,
a.button,
.shopify-section button:not(.nav):not(.thumb),
.shopify-section .button{
  background:linear-gradient(
    180deg,
    #1a1207 0%,
    #0e0a04 100%
  );
  border:1px solid rgba(199,154,43,.85);
  border-radius:14px;

  padding:14px 30px;

  color:#f2df9c !important;
  -webkit-text-fill-color:#f2df9c !important;
  text-shadow:none;

  font-weight:500;
  letter-spacing:.05em;

  box-shadow:
    inset 0 0 6px rgba(199,154,43,.25),
    0 6px 16px rgba(0,0,0,.45);

  transition:background .3s ease, box-shadow .3s ease, transform .25s ease;
}

/* ============================= */
/* HOVER BOUTON */
/* ============================= */

button:hover:not(header button),
.button:hover:not(header .button),
.btn:hover:not(header .btn),
a.button:hover:not(header a),
.shopify-section button:hover,
.shopify-section .button:hover{
  background:linear-gradient(
    180deg,
    #2a1e0b 0%,
    #120d05 100%
  );
  box-shadow:
    inset 0 0 10px rgba(199,154,43,.35),
    0 8px 22px rgba(0,0,0,.6);
  transform:translateY(-1px);
}


/* ============================= */
/* EXCLUSION HEADER ICONES */
/* ============================= */

header button,
.header button,
header .button,
.header .button,
.header__icon,
.header__icon svg{
  background:none !important;
  border:none !important;
  box-shadow:none !important;
}

/* Icônes du header visibles (compte, recherche, panier) */
.header__icon,
.header__icon:link,
.header__icon:visited{
  color:#c79a2b !important;
}
.header__icon svg{
  fill:none !important;
  stroke:currentColor !important;
}

/* ============================= */
/* BOUTONS CTA UNIQUEMENT */
/* (header + footer impossibles à toucher) */
/* ============================= */

/* CTA explicites uniquement */
a.button,
a.button-secondary,
button.button,
button.btn,
button[type="submit"]:not(.newsletter-form__button){
  background:linear-gradient(180deg,#1a1207 0%,#0e0a04 100%) !important;
  border:1px solid rgba(199,154,43,.85) !important;
  border-radius:14px !important;
  padding:14px 30px !important;

  color:#f2df9c !important;
  -webkit-text-fill-color:#f2df9c !important;
  text-shadow:none !important;

  font-weight:500 !important;
  letter-spacing:.05em !important;

  box-shadow:
    inset 0 0 6px rgba(199,154,43,.25),
    0 6px 16px rgba(0,0,0,.45) !important;

  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;

  transition:background .3s ease, box-shadow .3s ease, transform .25s ease !important;
}

/* Hover */
a.button:hover,
a.button-secondary:hover,
button.button:hover,
button.btn:hover,
button[type="submit"]:not(.newsletter-form__button):hover{
  background:linear-gradient(180deg,#2a1e0b 0%,#120d05 100%) !important;
  box-shadow:
    inset 0 0 10px rgba(199,154,43,.35),
    0 8px 22px rgba(0,0,0,.6) !important;
  transform:translateY(-1px) !important;
}

/* ============================= */
/* EXCLUSION BOUTON POLICIES */
/* ============================= */

button.policy-list-trigger,
button.policy-list-trigger:hover{
  background:none !important;
  border:none !important;
  box-shadow:none !important;
  padding:0 !important;

  color:inherit !important;
  -webkit-text-fill-color:inherit !important;
  text-shadow:none !important;

  font-weight:inherit !important;
  letter-spacing:inherit !important;
  transform:none !important;
}



/* ============================= */
/* FIX DÉFINITIF ICÔNE COMPTE */
/* ============================= */






/* Icônes SVG normales */
.header__icon svg{
  stroke:#c79a2b !important;
  transition:stroke .2s ease !important;
}

/* Icône compte injectée */
.account-button::before{
  background-color:#c79a2b;
  transition:background-color .2s ease;
}

/* ============================= */
/* HOVER ICONES HEADER */
/* ============================= */

.header__icon:hover,
.account-button:hover{
  background:none !important;
  box-shadow:none !important;
  transform:none !important;
}

/* Hover couleur plus claire */
.header__icon:hover svg{
  stroke:#f2df9c !important;
}

.account-button:hover::before{
  background-color:#f2df9c;
}



/* Même traitement pour le bouton compte */
header .account-button,
header .account-button:hover,
header .account-button:focus,
header .account-button:focus-visible,
header .account-button:active{
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
  outline:none !important;
  transform:none !important;
}

/* Hover : juste un éclaircissement léger */
header .header__icon svg{
  stroke:#c79a2b !important;
  transition:stroke .2s ease !important;
}
header .header__icon:hover svg{
  stroke:#f2df9c !important;
}

/* ============================= */
/* ICONE COMPTE : VERSION CONTOUR */
/* ============================= */

/* Couleur normale + hover */
.account-button::before{
  background-color:#c79a2b;
  transition:background-color .2s ease;
}
.account-button:hover::before{
  background-color:#f2df9c;
}

/* IMPORTANT : remplace uniquement les 2 lignes mask-image de ton .account-button::before
   par celles-ci (tu laisses le reste de ton bloc .account-button::before identique) */
.account-button::before{
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E");
}


/* ============================= */
/* HEADER ACTIONS : RESET TOTAL */
/* (loupe + panier comme compte) */
/* ============================= */

header .header-actions__action,
header .search-modal__button,
header .cart-drawer-trigger,
header .header-actions__action:hover,
header .search-modal__button:hover,
header .cart-drawer-trigger:hover,
header .header-actions__action:focus,
header .search-modal__button:focus,
header .cart-drawer-trigger:focus,
header .header-actions__action:active,
header .search-modal__button:active,
header .cart-drawer-trigger:active{
  background:transparent !important;
  border:none !important;
  box-shadow:none !important;
  outline:none !important;
  padding:0 !important;
  margin:0 !important;
  transform:none !important;
}



/* SVG icônes loupe + panier */
header .header-actions__action svg{
  stroke:#c79a2b !important;
  fill:none !important;
  transition:stroke .2s ease !important;
}

/* Hover : juste éclaircissement, PAS de carré */
header .header-actions__action:hover svg{
  stroke:#f2df9c !important;
}

/* Sécurité ultime : aucun pseudo-élément */
header .header-actions__action::before,
header .header-actions__action::after{
  content:none !important;
  display:none !important;
}

/* ============================= */
/* FIX FINAL VISIBILITÉ ICÔNE COMPTE */
/* ============================= */

/* Le bouton compte doit rester visible */
header .account-button{
  position:relative !important;
  background:transparent !important;
  box-shadow:none !important;
}



/* Hover cohérent avec les autres icônes */
header .account-button:hover::before{
  background-color:#f2df9c;
}

/* ============================= */
/* HEADER ICONES : COULEUR IDENTIQUE */
/* ============================= */

/* Couleur de base identique pour loupe + panier */
header .header__icon{
  color:#c79a2b !important;
}

/* SVG loupe + panier suivent la couleur */
header .header__icon svg{
  stroke:currentColor !important;
  fill:none !important;
}

/* Compte injecté : même doré que les autres */
header .account-button::before{
  background-color:#c79a2b !important;
}

/* Hover : plus clair sur les 3 */
header .header__icon:hover{
  color:#f2df9c !important;
}
header .account-button:hover::before{
  background-color:#f2df9c !important;
}

/* ============================= */
/* OVERRIDE FINAL : ICONE COMPTE MEME COULEUR + MEME STYLE */
/* (A COLLER TOUT EN BAS DU CSS) */
/* ============================= */

/* Couleur unique */
:root{ --header-icon:#c79a2b; --header-icon-hover:#f2df9c; }

/* Loupe + panier (SVG) */
header .header__icon{
  color:var(--header-icon) !important;
}
header .header__icon svg{
  stroke:currentColor !important;
  fill:none !important;
}
header .header__icon:hover{
  color:var(--header-icon-hover) !important;
}

/* Reset total bouton compte */
header .account-button,
header .account-button:hover,
header .account-button:focus,
header .account-button:active{
  background:transparent !important;
  box-shadow:none !important;
  border:none !important;
  transform:none !important;
}




  /* Icône outline (comme tes autres SVG en stroke) */
  -webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") !important;
  mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21a8 8 0 0 0-16 0'/%3E%3Ccircle cx='12' cy='7' r='4'/%3E%3C/svg%3E") !important;
}

header .account-button:hover::before{
  background-color:var(--header-icon-hover) !important;
}

/* ============================= */
/* ICONE COMPTE = MEME SYSTEME QUE LOUPE & PANIER */
/* ============================= */

.account-button svg{
  display:block !important;
  width:20px !important;
  height:20px !important;

  fill:none !important;
  stroke:currentColor !important;
  stroke-width:1.5 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}



/* hover identique aux autres */
header .account-button:hover{
  color:#f2df9c !important;
}





.gold-divider{
  position: relative;
  height: 0;
  margin-top: var(--gold-mt, 0px);
  margin-bottom: var(--gold-mb, 0px);
  overflow: visible;
}

/* ligne full width */
.gold-divider::before,
.gold-divider::after{
  content:"";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: var(--gold-h, 5px);
  background: linear-gradient(90deg,#5A3A00,#A66A00,#E0B84F,#FFF3B0,#D4A017,#8C5A00);
  pointer-events: none;
  z-index: 20;
  display: none;
}

.gold-divider--top::before{ top: 0; display: block; }
.gold-divider--bottom::after{ top: 0; display: block; }
.gold-divider--both::before{ top: 0; display: block; }
.gold-divider--both::after{ top: 0; display: block; }

@media (max-width: 768px){
  .gold-divider--hide-mobile{ display: none !important; }
}

/* Golden badges — catégories sommaire */
.real-toc__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.real-toc__links a {
  display: inline-flex;
  align-items: center;
  padding: 4px 20px;
  line-height: 1;
  height: auto;
  margin-top: 8px;
  border-radius: 100px;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  text-shadow: none !important;
  transition: color 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.2s ease;
}

.real-toc__links a::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%);
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
}

.real-toc__links a:hover {
  -webkit-text-fill-color: #ffe082 !important;
  color: #ffe082 !important;
  border-color: rgba(255, 200, 60, 0.85);
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 30px rgba(201, 168, 76, 0.18);
  transform: translateY(-2px);
}

.real-toc__links a:hover::before {
  left: 140%;
}

/* FAQ — couleur des séparateurs */
.section-wrapper accordion-custom details {
  border-color: #5d3b63 !important;
}

.section-wrapper accordion-custom summary {
  border-bottom: 1px solid #5d3b63 !important;
}

/* ============================= */
/* EFFET SHIMMER — TOUS LES BOUTONS */
/* ============================= */

a.button:not(.product-media-container__zoom-button),
a.button-secondary,
button.button:not(.product-media-container__zoom-button),
button.btn {
  position: relative !important;
  overflow: hidden !important;
}

a.button:not(.product-media-container__zoom-button)::before,
a.button-secondary::before,
button.button:not(.product-media-container__zoom-button)::before,
button.btn::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.25) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

a.button:not(.product-media-container__zoom-button):hover::before,
a.button-secondary:hover::before,
button.button:not(.product-media-container__zoom-button):hover::before,
button.btn:hover::before {
  left: 140% !important;
}

/* ============================= */
/* SÉPARATEURS ROSE — AVANT/APRÈS SECTIONS */
/* ============================= */

/* Classe à ajouter manuellement sur la section dans le HTML si besoin */
/* Mais surtout : séparateur automatique via CSS sur les shopify-sections */

.sep-before::before,
.sep-after::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  );
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}








#shopify-section-template--27479441015161__section_9wpCng::before {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  );
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}



/* ============================= */
/* BADGES DORÉS — PREST-TOC */
/* ============================= */

.prest-toc__links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}

.prest-toc__links a {
  display: inline-flex;
  align-items: center;
  padding: 4px 20px;
  line-height: 1;
  height: auto;
  margin-top: 8px;
  border-radius: 100px;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  text-shadow: none !important;
  transition: color 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.2s ease;
}

.prest-toc__links a::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%);
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
}

.prest-toc__links a:hover {
  -webkit-text-fill-color: #ffe082 !important;
  color: #ffe082 !important;
  border-color: rgba(255, 200, 60, 0.85);
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 30px rgba(201, 168, 76, 0.18);
  transform: translateY(-2px);
}

.prest-toc__links a:hover::before {
  left: 140%;
}









/* ============================= */
/* SECTION PIERCINGS + STRASS — FIXES COMPLETS */
/* ============================= */

/* Dégradé violet en haut — via pseudo-élément sur le shopify-section */
#shopify-section-template--27390256710009__custom_liquid_KdJnDN::before,
#shopify-section-template--27390256710009__custom_liquid_4FcY7b::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 350px;
  background: linear-gradient(to bottom, rgba(80, 0, 60, 0.55) 0%, rgba(80, 0, 60, 0.2) 70%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}

#shopify-section-template--27390256710009__custom_liquid_KdJnDN,
#shopify-section-template--27390256710009__custom_liquid_4FcY7b {
  position: relative;
}

/* Reset bouton card — annule le style global bouton */
.ip-card {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  transition: transform 0.25s ease !important;
}

.ip-card:hover {
  transform: translateY(-3px) !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Contour doré uniquement sur imgwrap */
.ip-card__imgwrap {
  border: 2px solid rgba(221, 203, 138, 0.75) !important;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.ip-card:hover .ip-card__imgwrap {
  border-color: rgba(242, 223, 156, 0.95) !important;
  box-shadow: 0 0 14px rgba(201, 168, 76, 0.45), 0 0 32px rgba(201, 168, 76, 0.2) !important;
}

/* Shimmer sur les images au hover */
.ip-card__imgwrap::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.18) 50%, transparent 100%);
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
  z-index: 2;
}

.ip-card:hover .ip-card__imgwrap::after {
  left: 140%;
}

/* ============================= */
/* BADGES CATÉGORIES .ip-tab */
/* ============================= */

.ip-tab {
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 24px !important;
  line-height: 1 !important;
  height: auto !important;
  border-radius: 12px !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  position: relative !important;
  overflow: hidden !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  text-shadow: none !important;
  box-shadow: none !important;
  transition: color 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.2s ease !important;
}

.ip-tab::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

.ip-tab:hover,
.ip-tab.is-active {
  -webkit-text-fill-color: #ffe082 !important;
  color: #ffe082 !important;
  border-color: rgba(255, 200, 60, 0.85) !important;
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 30px rgba(201, 168, 76, 0.18) !important;
  transform: translateY(-2px) !important;
}

.ip-tab:hover::before,
.ip-tab.is-active::before {
  left: 140% !important;
}



/* ============================= */
/* PMU AVANT/APRÈS — HANDLE + SÉPARATEUR */
/* ============================= */

/* Ligne séparatrice — bien visible */
.pmu-compare-grid .comparison-slider__media-wrapper::after {
  content: '' !important;
  display: block !important;
  width: 1px !important;
  background: #110011 !important;
  box-shadow: 2px 0 8px rgba(17, 0, 17, 0.8), -2px 0 8px rgba(17, 0, 17, 0.8) !important;
}

/* Handle — cercle réduit */
.pmu-compare-grid .cs-slider__handle {
  width: 24px !important;
  height: 24px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  background: rgba(201, 168, 76, 0.75) !important;
  border: 1px solid rgba(255, 200, 60, 0.85) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 28px rgba(201, 168, 76, 0.2) !important;
  gap: 4px !important;
  overflow: hidden !important;
  transition: background 0.35s ease, box-shadow 0.35s ease !important;
}

/* Shimmer */
.pmu-compare-grid .cs-slider__handle::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 240, 150, 0.35) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

/* Hover */
.pmu-compare-grid .comparison-slider__media-wrapper:hover .cs-slider__handle {
  background: rgba(201, 168, 76, 0.9) !important;
  box-shadow: 0 0 16px rgba(201, 168, 76, 0.6), 0 0 36px rgba(201, 168, 76, 0.3) !important;
}

.pmu-compare-grid .comparison-slider__media-wrapper:hover .cs-slider__handle::before {
  left: 140% !important;
}

/* Flèches dorées */
.pmu-compare-grid .cs-slider__chevron svg {
  stroke: #1a1207 !important;
  fill: none !important;
  width: 10px !important;
  height: 10px !important;
}



/* ============================= */
/* PMU GRILLE — ALIGNEMENT HAUT FORCÉ */
/* ============================= */

.pmu-compare-grid__grid {
  align-items: start !important;
  grid-auto-rows: auto !important;
}

.pmu-compare-grid__item-head {
  min-height: 60px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.pmu-compare-grid__item {
  display: flex !important;
  flex-direction: column !important;
}

/* ============================= */
/* FAQ SOMMAIRE — BADGES DORÉS (FINAL) */
/* ============================= */

.faq-toc__links {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  gap: 10px !important;
}

.faq-toc__links a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  width: fit-content !important;
  padding: 10px 24px !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  border-radius: 999px !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  position: relative !important;
  overflow: hidden !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  text-shadow: none !important;
  box-shadow: none !important;
  transition: color 0.35s ease, border-color 0.35s ease, background 0.35s ease, box-shadow 0.35s ease, transform 0.2s ease !important;
}

.faq-toc__links a::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

.faq-toc__links a:hover {
  -webkit-text-fill-color: #ffe082 !important;
  color: #ffe082 !important;
  border-color: rgba(255, 200, 60, 0.85) !important;
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 30px rgba(201, 168, 76, 0.18) !important;
  transform: translateY(-2px) !important;
}

.faq-toc__links a:hover::before {
  left: 140% !important;
}

#shopify-section-template--27380842660217__section_a9pGbV a:not(.button):not(.btn):hover {
  -webkit-text-fill-color: #ffe082 !important;
  color: #ffe082 !important;
  border-color: rgba(255, 200, 60, 0.85) !important;
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 30px rgba(201, 168, 76, 0.18) !important;
  transform: translateY(-2px) !important;
}

#shopify-section-template--27380842660217__section_a9pGbV a:not(.button):not(.btn):hover::before {
  left: 140% !important;
}

.ip-tab {
  border-radius: 999px !important;
}

/* ============================= */
/* IMAGE BLOCKS — SHIMMER HOVER */
/* ============================= */

#shopify-section-template--27396256301433__section_gFCcbP .image-block,
#shopify-section-template--27396256301433__section_M9bf7d .image-block,
#shopify-section-template--27381324546425__section_JaxqnN .image-block,
#shopify-section-template--27232347685241__section_PCrLwW .image-block,
#shopify-section-template--27232347718009__section_dCUYfJ .image-block,
#shopify-section-template--27232347718009__section_6WaW7c .image-block,
#shopify-section-template--27232347718009__section_xLWVAQ .image-block,
#shopify-section-template--27232347718009__section_Fri7zq .image-block,
#shopify-section-template--27381324546425__section_nqnL9E .image-block,
#shopify-section-template--27381324546425__section_zFAN63 .image-block,
#shopify-section-template--27381324546425__section_r8hmNX .image-block,
#shopify-section-template--27381324546425__section_jQp9pT .image-block,
#shopify-section-template--27381324546425__section_4qJDe7 .image-block {
  position: relative !important;
  overflow: hidden !important;
  border-radius: 18px !important;
}

#shopify-section-template--27396256301433__section_gFCcbP .image-block::after,
#shopify-section-template--27396256301433__section_M9bf7d .image-block::after,
#shopify-section-template--27381324546425__section_JaxqnN .image-block::after,
#shopify-section-template--27232347685241__section_PCrLwW .image-block::after,
#shopify-section-template--27232347718009__section_dCUYfJ .image-block::after,
#shopify-section-template--27232347718009__section_6WaW7c .image-block::after,
#shopify-section-template--27232347718009__section_xLWVAQ .image-block::after,
#shopify-section-template--27232347718009__section_Fri7zq .image-block::after,
#shopify-section-template--27381324546425__section_nqnL9E .image-block::after,
#shopify-section-template--27381324546425__section_zFAN63 .image-block::after,
#shopify-section-template--27381324546425__section_r8hmNX .image-block::after,
#shopify-section-template--27381324546425__section_jQp9pT .image-block::after,
#shopify-section-template--27381324546425__section_4qJDe7 .image-block::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(105deg, transparent 0%, rgba(216, 100, 255, 0.18) 50%, transparent 100%) !important;
  transition: left 0.7s ease !important;
  pointer-events: none !important;
  z-index: 2 !important;
  /* PAS de border-radius ici — clippé par le parent overflow:hidden + border-radius:18px */
}

#shopify-section-template--27396256301433__section_gFCcbP .image-block:hover::after,
#shopify-section-template--27396256301433__section_M9bf7d .image-block:hover::after,
#shopify-section-template--27381324546425__section_JaxqnN .image-block:hover::after,
#shopify-section-template--27232347685241__section_PCrLwW .image-block:hover::after,
#shopify-section-template--27232347718009__section_dCUYfJ .image-block:hover::after,
#shopify-section-template--27232347718009__section_6WaW7c .image-block:hover::after,
#shopify-section-template--27232347718009__section_xLWVAQ .image-block:hover::after,
#shopify-section-template--27232347718009__section_Fri7zq .image-block:hover::after,
#shopify-section-template--27381324546425__section_nqnL9E .image-block:hover::after,
#shopify-section-template--27381324546425__section_zFAN63 .image-block:hover::after,
#shopify-section-template--27381324546425__section_r8hmNX .image-block:hover::after,
#shopify-section-template--27381324546425__section_jQp9pT .image-block:hover::after,
#shopify-section-template--27381324546425__section_4qJDe7 .image-block:hover::after {
  left: 140% !important;
}








/* ============================= */
/* LAYERED SLIDESHOW — FLÈCHES + POINTS + PEEK */
/* ============================= */

#shopify-section-template--27232347685241__layered_slideshow_ctEGpx {
  position: relative;
}

.lss-nav {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 20;
}

/* FLÈCHES — style identique à .gallery-slider .nav */
.lss-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: auto;
  height: auto;
  border-radius: 8px !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  background: rgba(180, 130, 20, 0.15) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  pointer-events: all;
  overflow: hidden;
  padding: 10px 14px !important;
  box-shadow: none !important;
  transition: background 0.35s ease, box-shadow 0.35s ease !important;
}

/* Flèche en caractère comme gallery-slider */
.lss-arrow span {
  font-size: 32px;
  line-height: 1;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-shadow: none !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  transition: color 0.3s ease;
}

/* Shimmer */
.lss-arrow::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%);
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
}

.lss-arrow:hover {
  background: rgba(180, 130, 20, 0.35) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 28px rgba(201, 168, 76, 0.15) !important;
  transform: translateY(-50%) !important;
}

.lss-arrow:hover span {
  color: #ffe082 !important;
  -webkit-text-fill-color: #ffe082 !important;
}

.lss-arrow:hover::before {
  left: 140%;
}

.lss-arrow--prev { left: 16px; }
.lss-arrow--next { right: 16px; }

@media screen and (max-width: 749px) {
  .lss-dots {
    display: none !important;
  }

  .lss-arrow--prev {
    right: 16px !important;
    left: auto !important;
    top: 16px !important;
    bottom: auto !important;
    transform: none !important;
    width: 72px !important;
    height: 44px !important;
    min-height: unset !important;
    min-width: unset !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 8px !important;
  }

  .lss-arrow--next {
    right: 16px !important;
    left: auto !important;
    top: auto !important;
    bottom: 16px !important;
    transform: none !important;
    width: 72px !important;
    height: 44px !important;
    min-height: unset !important;
    min-width: unset !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 8px !important;
  }

  .lss-arrow:hover {
    transform: none !important;
  }

  .lss-arrow--prev .lss-arrow-char {
    font-size: 0 !important;
    line-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .lss-arrow--prev .lss-arrow-char::after {
    content: '∧' !important;
    font-size: 28px !important;
    line-height: 1 !important;
    color: #c9a84c !important;
    -webkit-text-fill-color: #c9a84c !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    text-shadow: none !important;
  }
  .lss-arrow--next .lss-arrow-char {
    font-size: 0 !important;
    line-height: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .lss-arrow--next .lss-arrow-char::after {
    content: '∨' !important;
    font-size: 28px !important;
    line-height: 1 !important;
    color: #c9a84c !important;
    -webkit-text-fill-color: #c9a84c !important;
    background: none !important;
    -webkit-background-clip: unset !important;
    background-clip: unset !important;
    text-shadow: none !important;
  }
}

.lss-arrow.is-disabled {
  opacity: 0.2;
  pointer-events: none;
}

/* POINTS — en dehors de la section, en dessous */
.lss-dots {
  position: relative !important;
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  padding: 0;
  pointer-events: all;
  transform: none !important;
  left: auto !important;
  bottom: auto !important;
}

.lss-dot {
  width: 8px;
  height: 8px;
  border-radius: 50% !important;
  border: none !important;
  background: rgba(114, 55, 106, 0.7) !important;
  cursor: pointer;
  padding: 0 !important;
  box-shadow: none !important;
  transition: background 0.3s ease, transform 0.3s ease;
}

.lss-dot.is-active {
  background: #c9a84c !important;
  transform: scale(1.3);
}

.lss-dot:hover:not(.is-active) {
  background: rgba(201, 168, 76, 0.45);
}

/* Peek animation */
@keyframes lss-peek {
  0%   { transform: translateX(0); }
  30%  { transform: translateX(-18px); }
  70%  { transform: translateX(-18px); }
  100% { transform: translateX(0); }
}

#shopify-section-template--27232347685241__layered_slideshow_ctEGpx [role="tabpanel"]:nth-child(2) {
  animation: lss-peek 1.2s cubic-bezier(0.4, 0, 0.2, 1) 1.2s both;
}

@media screen and (max-width: 749px) {
  @keyframes lss-peek-mobile {
    0%   { transform: translateY(0); }
    30%  { transform: translateY(-14px); }
    70%  { transform: translateY(-14px); }
    100% { transform: translateY(0); }
  }

  #shopify-section-template--27232347685241__layered_slideshow_ctEGpx [role="tabpanel"]:nth-child(2) {
    animation: lss-peek-mobile 1.2s cubic-bezier(0.4, 0, 0.2, 1) 1.2s both;
  }
}







/* ============================= */
/* SÉPARATEUR ROSE — section_b8WWfX (EN HAUT) */
/* ============================= */

#shopify-section-template--27232347685241__section_b8WWfX::before {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  );
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}




/* ============================= */
/* PAGE COLLECTION — FIXES */
/* ============================= */

/* Cacher boutons "Ajouter" et "Choisir" sur les cards produits */
.product-grid__item quick-add-component,
.product-grid__item .quick-add__button,
.product-grid__item .quick-add,
.product-grid__item [id^='quick-add'],
.product-grid__item .card__cta {
  display: none !important;
}

/* Images arrondies 8px */
.product-grid__item .card-gallery,
.product-grid__item .product-card__image,
.product-grid__item .card-gallery img,
.product-grid__item .product-card__image img,
.product-grid__item .card-gallery slideshow-component,
.product-grid__item .card-gallery > *:first-child {
  border-radius: 8px !important;
  overflow: hidden !important;
}

/* Fix boutons illisibles — reset texte doré sur les boutons de filtres/tri */
.facets-block-wrapper button,
.facets-block-wrapper .button,
.sort-by button,
.sort-by select,
button[aria-label="Tout effacer"],
.active-facets button,
.active-facets .button {
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  box-shadow: none !important;
  padding: 8px 16px !important;
  border-radius: 8px !important;
}

/* Boutons "Tout effacer" et "Voir X articles" */
.active-facets__button-wrapper button,
button[data-facets-clear-all] {
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

/* Fix select Trier */
.product-grid-container select {
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.5) !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
}

/* ============================= */
/* COLLECTION — HOVER PRODUITS */
/* ============================= */

/* Agrandissement léger de l'image au hover */
.product-grid__item .card-gallery {
  overflow: hidden !important;
  border-radius: 8px !important;
  position: relative !important;
}

.product-grid__item .card-gallery img {
  transition: transform 0.45s ease !important;
  will-change: transform;
}

.product-grid__item:hover .card-gallery img {
  transform: scale(1.045) !important;
}

/* Shimmer blanc au hover */
.product-grid__item .card-gallery::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255, 255, 255, 0.18) 50%,
    transparent 100%
  ) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
  z-index: 2 !important;
}

.product-grid__item:hover .card-gallery::after {
  left: 140% !important;
}










/* ============================= */
/* PAGE PRODUIT — BOUTONS VARIANTES + CTA */
/* ============================= */

/* Boutons de variantes (Couleur, Épaisseur, Diamètre) */
.variant-picker .variant-option--buttons label,
.variant-picker label,
.variant-picker .variant-option label,
.product-details .variant-option--buttons label {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 10px 20px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(201, 168, 76, 0.5) !important;
  background: rgba(201, 168, 76, 0.05) !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-shadow: none !important;
  cursor: pointer !important;
  transition: border-color 0.25s ease, background 0.25s ease, box-shadow 0.25s ease !important;
  box-shadow: none !important;
}

/* Variante active/sélectionnée */
.variant-picker input:checked + label,
.variant-picker label[aria-pressed="true"],
.variant-picker .variant-option--buttons input:checked + label {
  border-color: rgba(201, 168, 76, 0.9) !important;
  background: rgba(201, 168, 76, 0.15) !important;
  box-shadow: 0 0 10px rgba(201, 168, 76, 0.35), 0 0 24px rgba(201, 168, 76, 0.15) !important;
  color: #ffe082 !important;
  -webkit-text-fill-color: #ffe082 !important;
}

/* Hover variante */
.variant-picker .variant-option--buttons label:hover {
  border-color: rgba(201, 168, 76, 0.75) !important;
  background: rgba(201, 168, 76, 0.1) !important;
  color: #ffe082 !important;
  -webkit-text-fill-color: #ffe082 !important;
}

/* Variante indisponible (rayée) */
.variant-picker label.variant-option--unavailable,
.variant-picker .variant-option--buttons label:has(+ input:disabled) {
  opacity: 0.35 !important;
  border-style: dashed !important;
}

/* ============================= */
/* BOUTON AJOUTER AU PANIER / ÉPUISÉ */
/* ============================= */

.product-details .button.add-to-cart-button,
.product-details button[type="submit"],
.product-form__submit,
.add-to-cart-button {
  width: 100% !important;
  border-radius: 12px !important;
  padding: 16px 32px !important;
  background: linear-gradient(180deg, #1a1207 0%, #0e0a04 100%) !important;
  border: 1px solid rgba(201, 168, 76, 0.85) !important;
  color: #f2df9c !important;
  -webkit-text-fill-color: #f2df9c !important;
  box-shadow: inset 0 0 6px rgba(201, 168, 76, 0.2), 0 4px 14px rgba(0,0,0,0.5) !important;
  font-size: 1rem !important;
  letter-spacing: 0.06em !important;
}

/* Bouton désactivé / Épuisé */
.add-to-cart-button:disabled,
.add-to-cart-button[disabled],
.add-to-cart-button[aria-disabled="true"] {
  opacity: 1 !important;
  cursor: not-allowed !important;
  background: rgba(40, 20, 5, 0.7) !important;
  border: 1px solid rgba(201, 168, 76, 0.3) !important;
  color: rgba(201, 168, 76, 0.45) !important;
  -webkit-text-fill-color: rgba(201, 168, 76, 0.45) !important;
  box-shadow: none !important;
}

/* ============================= */
/* SÉPARATEURS ENTRE VARIANTES */
/* ============================= */

.product-details hr,
.variant-picker hr,
.product-details .divider {
  border: none !important;
  border-top: 1px solid rgba(201, 168, 76, 0.2) !important;
  margin: 12px 0 !important;
}

/* ============================= */
/* SÉLECTEUR QUANTITÉ */
/* ============================= */

.product-details .quantity-selector {
  border: 1px solid rgba(201, 168, 76, 0.5) !important;
  background: rgba(201, 168, 76, 0.05) !important;
  border-radius: 12px !important;
}

.product-details .quantity-selector input {
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

.product-details .quantity-minus,
.product-details .quantity-plus {
  color: #c9a84c !important;
}

.product-details .quantity-minus:hover,
.product-details .quantity-plus:hover {
  color: #ffe082 !important;
}




/* ============================= */
/* FIX IMAGE PRODUIT — RACINE DU PROBLÈME */
/* ============================= */

slideshow-slide,
.product-media-container,
media-gallery,
.product-media,
.product-media__image {
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
}

/* Fix spécifique pour les img — reset complet */
slideshow-slide img,
.product-media-container img,
.product-media img,
media-gallery img,
.product-media__image img,
.card-gallery img,
.product-card__image img,
.sticky-add-to-cart__image img {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}

/* ============================= */
/* FIX +/- QUANTITY — CUSTOM ELEMENT */
/* ============================= */

quantity-selector-component button,
quantity-selector-component button svg,
quantity-selector-component button svg *,
quantity-selector-component button path,
quantity-selector-component button line,
quantity-selector-component button rect {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  stroke: #c9a84c !important;
  fill: none !important;
  color: #c9a84c !important;
}

quantity-selector-component button:hover svg,
quantity-selector-component button:hover svg *,
quantity-selector-component button:hover path {
  stroke: #ffe082 !important;
}

/* Reset total du quantity-selector pour qu'il ne soit pas stylé comme un bouton CTA */
quantity-selector-component button,
quantity-selector-component button:hover {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
  transform: none !important;
  width: var(--minimum-touch-target) !important;
  height: var(--minimum-touch-target) !important;
}

/* ============================= */
/* FIX DÉFINITIF — IMAGE PRODUIT VISIBLE */
/* ============================= */

slideshow-slide img,
.product-media-container img,
.product-media img,
media-gallery img,
.product-media__image img,
.card-gallery img,
.product-card__image img,
.sticky-add-to-cart__image img {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
  opacity: 1 !important;
  visibility: visible !important;
  display: block !important;
}







/* ============================= */
/* PAGE PRODUIT — SÉLECTEUR QUANTITÉ CORRIGÉ */
/* ============================= */

/* Reset du conteneur global — supprime l'apparence "grande boîte fondue" */
.product-details .quantity-selector,
quantity-selector-component .quantity-selector {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 !important;
}

/* Chaque bouton — carré individuel avec bordure dorée */
quantity-selector-component .quantity-minus,
quantity-selector-component .quantity-plus,
.product-details .quantity-minus,
.product-details .quantity-plus {
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  background: rgba(201, 168, 76, 0.08) !important;
  box-shadow: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  cursor: pointer !important;
  transition: background 0.25s ease, border-color 0.25s ease !important;
  padding: 0 !important;
  transform: none !important;
}

quantity-selector-component .quantity-minus:hover,
quantity-selector-component .quantity-plus:hover,
.product-details .quantity-minus:hover,
.product-details .quantity-plus:hover {
  background: rgba(201, 168, 76, 0.18) !important;
  border-color: rgba(201, 168, 76, 1) !important;
  color: #ffe082 !important;
  -webkit-text-fill-color: #ffe082 !important;
  transform: none !important;
  box-shadow: 0 0 10px rgba(201, 168, 76, 0.3) !important;
}

/* SVG à l'intérieur des boutons */
quantity-selector-component .quantity-minus svg,
quantity-selector-component .quantity-plus svg,
.product-details .quantity-minus svg,
.product-details .quantity-plus svg {
  stroke: currentColor !important;
  fill: none !important;
  width: 16px !important;
  height: 16px !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
}

/* Chiffre au centre */
quantity-selector-component .quantity-selector input,
.product-details .quantity-selector input {
  background: transparent !important;
  border: none !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-align: center !important;
  width: 40px !important;
  font-size: 1rem !important;
  box-shadow: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
}

/* ============================= */
/* FIX IMAGE PRODUIT — VISIBILITÉ FORCÉE */
/* ============================= */

.product-media__image,
.product-media__image img,
.product-media div[data-media-id] img,
media-gallery img,
slideshow-slide img,
.product-media-container img {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
}
/* ============================= */
/* PAGE PRODUIT — IMAGE VISIBLE, PAS DE SHIMMER */
/* ============================= */

.product-media-container {
  position: relative !important;
  overflow: hidden !important;
  isolation: auto !important;
}

/* Aucun pseudo-élément sur le conteneur image produit */
.product-media-container::after,
.product-media-container::before {
  content: none !important;
  display: none !important;
}

/* Le div direct contenant l'img — reset */
.product-media div[data-media-id] {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* ============================= */
/* FIX BOUTON ZOOM — COUVRE L'IMAGE */
/* ============================= */

.product-media-container__zoom-button,
.product-media-container__zoom-button:hover,
.product-media-container__zoom-button:focus,
.product-media-container__zoom-button:active {
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  transform: none !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
  overflow: hidden !important;
}

.product-media-container__zoom-button::before,
.product-media-container__zoom-button::after {
  content: none !important;
  display: none !important;
}

/* ============================= */
/* FIX BOUTON ZOOM IMAGE PRODUIT */
/* ============================= */

.product-media-container__zoom-button,
.product-media-container__zoom-button:hover,
.product-media-container__zoom-button:focus,
.product-media-container__zoom-button:active,
button.product-media-container__zoom-button,
button.product-media-container__zoom-button:hover {
  background: transparent !important;
  background-image: none !important;
  background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  transform: none !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}

button.product-media-container__zoom-button::before,
button.product-media-container__zoom-button::after,
.product-media-container__zoom-button::before,
.product-media-container__zoom-button::after {
  content: none !important;
  display: none !important;
  background: none !important;
}

/* FIX CRITIQUE — conteneur image produit */
li.product-media-container,
.product-media-container,
.product-media-container *:not(img):not(button):not(span) {
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
}

/* L'img elle-même */
.product-media-container img,
.product-media__image {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  opacity: 1 !important;
  visibility: visible !important;
}


/* ============================= */
/* FIX IMAGE PRODUIT — VERSION FINALE */
/* ============================= */

.product-media__image,
.product-media__image img,
.product-media div[data-media-id] img,
media-gallery img,
slideshow-slide img,
.product-media-container img {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
}

.media-fit-contain :is(img, video, iframe, .deferred-media__poster-image) {
  width: 100% !important;
  height: 100% !important;
}

/* ============================= */
/* PAGE PRODUIT — IMAGE ARRONDIE */
/* ============================= */

.product-media-container {
  border-radius: 18px !important;
  overflow: hidden !important;
}


/* ============================= */
/* PRODUCT RECOMMENDATIONS — FIXES */
/* ============================= */

/* Cacher boutons ajouter/choisir */
product-recommendations quick-add-component,
product-recommendations .quick-add__button,
product-recommendations .quick-add,
product-recommendations [id^='quick-add'],
product-recommendations .card__cta {
  display: none !important;
}

/* Badge épuisé — fond blanc + contour violet + texte violet */
.product-badges__badge {
  background: #fff !important;
  background-image: none !important;
  border: 1.5px solid #7b3fa0 !important;
  color: #7b3fa0 !important;
  -webkit-text-fill-color: #7b3fa0 !important;
  text-shadow: none !important;
  border-radius: 8px !important;
  padding: 4px 10px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}


















/* ============================= */
/* LIGHTBOX PIERCINGS — FIX COMPLET */
/* ============================= */

/* Centrage parfait dans la fenêtre */
.ip-lightbox {
  position: fixed !important;
  inset: 0 !important;
  display: none;
  align-items: center !important;
  justify-content: center !important;
  z-index: 9999 !important;
}

.ip-lightbox.is-open {
  display: flex !important;
}

/* Reset total du contenu — annule le dégradé doré global */
.ip-lightbox__panel,
.ip-lightbox__panel *:not(.ip-btn) {
  background-clip: unset !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  color: unset !important;
  text-shadow: none !important;
  background-image: none !important;
}

/* Panel blanc */
.ip-lightbox__panel {
  background: #fff !important;
  color: #1a1207 !important;
}

/* Titre */
.ip-lightbox__title {
  color: #c79a2b !important;
  -webkit-text-fill-color: #c79a2b !important;
  background: none !important;
}

/* Prix */
.ip-lightbox__price {
  color: #6b4a1a !important;
  -webkit-text-fill-color: #6b4a1a !important;
  background: none !important;
  opacity: 1 !important;
}

/* Texte description */
.ip-lightbox__text {
  color: #3a2a10 !important;
  -webkit-text-fill-color: #3a2a10 !important;
  background: none !important;
  opacity: 0.8 !important;
}

/* ============================= */
/* BOUTONS LIGHTBOX — STYLE DORÉ + SHIMMER */
/* ============================= */

.ip-btn {
  position: relative !important;
  overflow: hidden !important;
  background: rgba(201, 168, 76, 0.08) !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  border-radius: 999px !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-shadow: none !important;
  padding: 10px 24px !important;
  font-weight: 500 !important;
  transition: background 0.35s ease, box-shadow 0.35s ease, transform 0.2s ease !important;
  box-shadow: none !important;
  cursor: pointer !important;
}

.ip-btn--primary {
  background: linear-gradient(180deg, #1a1207 0%, #0e0a04 100%) !important;
  border-color: rgba(201, 168, 76, 0.85) !important;
  color: #f2df9c !important;
  -webkit-text-fill-color: #f2df9c !important;
}

/* Shimmer boutons */
.ip-btn::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

.ip-btn:hover::before {
  left: 140% !important;
}

.ip-btn:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4) !important;
}

/* ============================= */
/* CROIX FERMER — STYLE + SHIMMER */
/* ============================= */

.ip-lightbox__close {
  position: absolute !important;
  top: 10px !important;
  right: 12px !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  background: rgba(201, 168, 76, 0.08) !important;
  background-image: none !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-shadow: none !important;
  cursor: pointer !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transition: background 0.35s ease, box-shadow 0.35s ease !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 18px !important;
}

.ip-lightbox__close::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

.ip-lightbox__close:hover {
  background: rgba(201, 168, 76, 0.18) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.35) !important;
  transform: none !important;
}

.ip-lightbox__close:hover::before {
  left: 140% !important;
}









/* ============================= */
/* LIGHTBOX PIERCINGS — FOND BORDEAUX + TEXTES CLAIRS */
/* ============================= */

/* Panel principal — fond bordeaux foncé */
.ip-lightbox__panel {
  background: rgba(46, 13, 32, 0.97) !important;
  color: #f2df9c !important;
  border: 1px solid rgba(201, 168, 76, 0.35) !important;
}

/* Reset héritage */
.ip-lightbox__panel,
.ip-lightbox__panel *:not(.ip-btn):not(.ip-btn *) {
  background-clip: unset !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
  background-image: none !important;
  text-shadow: none !important;
}

/* Titre — doré */
.ip-lightbox__title {
  color: #f2df9c !important;
  -webkit-text-fill-color: #f2df9c !important;
  background: none !important;
  font-size: 1.6rem !important;
  letter-spacing: 0.06em !important;
}

/* Prix */
.ip-lightbox__price {
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  background: none !important;
  opacity: 1 !important;
  font-size: 1rem !important;
  margin-bottom: 14px !important;
}

/* Texte description */
.ip-lightbox__text {
  color: rgba(242, 223, 156, 0.75) !important;
  -webkit-text-fill-color: rgba(242, 223, 156, 0.75) !important;
  background: none !important;
  opacity: 1 !important;
  line-height: 1.6 !important;
}

/* Zone média (image gauche) — fond noir profond */
.ip-lightbox__media {
  background: #0e0005 !important;
}

/* Bouton Prendre rendez-vous */
.ip-btn--primary {
  background: linear-gradient(180deg, #1a1207 0%, #0e0a04 100%) !important;
  border: 1px solid rgba(201, 168, 76, 0.85) !important;
  color: #f2df9c !important;
  -webkit-text-fill-color: #f2df9c !important;
}

/* Bouton Retour */
.ip-btn:not(.ip-btn--primary) {
  background: rgba(46, 13, 32, 0.6) !important;
  border: 1px solid rgba(201, 168, 76, 0.5) !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

/* Bouton fermer X */
.ip-lightbox__close {
  background: rgba(46, 13, 32, 0.85) !important;
  border: 1px solid rgba(201, 168, 76, 0.6) !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

.ip-lightbox__close:hover {
  background: rgba(70, 20, 50, 0.95) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.35) !important;
}

/* Backdrop légèrement plus opaque */
.ip-lightbox__backdrop {
  background: rgba(10, 0, 8, 0.72) !important;
}

/* ============================= */
/* LIGHTBOX — CONTOUR + BOUTONS NOIRS */
/* ============================= */

/* Contour panel plus épais */
.ip-lightbox__panel {
  background: rgba(46, 13, 32, 0.97) !important;
  border: 2px solid rgba(201, 168, 76, 0.7) !important;
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.15), 0 0 60px rgba(46, 13, 32, 0.6) !important;
}

/* Bouton Prendre rendez-vous — fond noir */
.ip-btn--primary {
  background: #000 !important;
  border: 2px solid rgba(201, 168, 76, 0.85) !important;
  color: #f2df9c !important;
  -webkit-text-fill-color: #f2df9c !important;
}

.ip-btn--primary:hover {
  background: #111 !important;
  box-shadow: 0 0 14px rgba(201, 168, 76, 0.4) !important;
}

/* Bouton Retour — fond noir */
.ip-btn:not(.ip-btn--primary) {
  background: #000 !important;
  border: 2px solid rgba(201, 168, 76, 0.5) !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

.ip-btn:not(.ip-btn--primary):hover {
  background: #111 !important;
  border-color: rgba(201, 168, 76, 0.85) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.35) !important;
}

/* Croix fermer — fond noir */
.ip-lightbox__close {
  background: #000 !important;
  border: 2px solid rgba(201, 168, 76, 0.6) !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
}

.ip-lightbox__close:hover {
  background: #111 !important;
  border-color: rgba(201, 168, 76, 0.9) !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.35) !important;
  transform: none !important;
}





/* Uniformisation contour — tous les boutons lightbox */
.ip-lightbox__actions .ip-btn--primary,
.ip-lightbox__actions .ip-btn:not(.ip-btn--primary) {
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
}

.ip-btn--primary {
  border-width: 1px !important;
}


/* Cacher bouton Retour lightbox — redondant avec la croix */
.ip-lightbox__actions .ip-btn:not(.ip-btn--primary) {
  display: none !important;
}








#shopify-section-template--27232347685241__section_MPg7Gx::before,
#shopify-section-template--27232347685241__section_MPg7Gx::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  );
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}





@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_MPg7Gx,
  #shopify-section-template--27232347685241__section_MPg7Gx * {
    display: none !important;
    visibility: hidden !important;
  }
}



@media screen and (min-width: 750px) {
  #shopify-section-template--27232347685241__section_QWwR9t {
    display: none !important;
  }
}














/* ============================= */
/* SECTION template--27381324546425__section_U7tqhc */
/* ============================= */

/* Lignes séparatrices haut ET bas */
#shopify-section-template--27381324546425__section_U7tqhc::before,
#shopify-section-template--27381324546425__section_U7tqhc::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}

/* Masquer sur mobile */
@media screen and (max-width: 749px) {
  #shopify-section-template--27381324546425__section_U7tqhc {
    display: none !important;
  }
}


/* ============================= */
/* SECTION template--27396256301433__section_eGUemP */
/* ============================= */

#shopify-section-template--27396256301433__section_eGUemP::before,{
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}

@media screen and (max-width: 749px) {
  #shopify-section-template--27396256301433__section_eGUemP {
    display: none !important;
  }
}


/* ============================= */
/* SECTION template--27380842660217__section_jAVTdz */
/* ============================= */

#shopify-section-template--27380842660217__section_jAVTdz::before,
#shopify-section-template--27380842660217__section_jAVTdz::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}

@media screen and (max-width: 749px) {
  #shopify-section-template--27380842660217__section_jAVTdz {
    display: none !important;
  }
}


/* Masquer les 3 sections mobile sur desktop */
@media screen and (min-width: 750px) {
  #shopify-section-template--27381324546425__section_e4QaVn,{
    display: none !important;
  }
}







/* Lignes séparatrices sections mobiles */
#shopify-section-template--27381324546425__section_e4QaVn::before,
#shopify-section-template--27381324546425__section_e4QaVn::after,
#shopify-section-template--27396256301433__section_eGUemP::after,
#shopify-section-template--27380842660217__section_jAVTdz::before,
#shopify-section-template--27380842660217__section_jAVTdz::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}


/* Section mobile FAQ — masquer sur desktop */
@media screen and (min-width: 750px) {
  #shopify-section-template--27380842660217__section_fqaQmA {
    display: none !important;
  }
}

/* Lignes séparatrices */
#shopify-section-template--27380842660217__section_fqaQmA::before,
#shopify-section-template--27380842660217__section_fqaQmA::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}





/* Section desktop uniquement + séparateur bas */
@media screen and (max-width: 749px) {
  #shopify-section-template--27396256301433__section_dwKWXb {
    display: none !important;
  }
}

#shopify-section-template--27396256301433__section_dwKWXb::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}




/* Section mobile uniquement */
@media screen and (min-width: 750px) {
  #shopify-section-template--27396256301433__section_fqQRgr {
    display: none !important;
  }
}

/* Séparateur bas */
#shopify-section-template--27396256301433__section_fqQRgr::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}



/* Séparateurs haut ET bas — section QWwR9t mobile uniquement */
@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_QWwR9t::before,
  #shopify-section-template--27232347685241__section_QWwR9t::after {
    content: '';
    display: block;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
    box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
    position: relative;
    z-index: 10;
  }
}




/* ============================= */
/* section_qj6xcH — desktop uniquement + séparateurs haut/bas */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_qj6xcH {
    display: none !important;
  }
}

#shopify-section-template--27232347685241__section_qj6xcH::before,
#shopify-section-template--27232347685241__section_qj6xcH::after {
  content: '';
  display: block;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
  position: relative;
  z-index: 10;
}

/* ============================= */
/* section_yxnc3H — mobile uniquement + séparateurs haut/bas */
/* ============================= */

@media screen and (min-width: 750px) {
  #shopify-section-template--27232347685241__section_yxnc3H {
    display: none !important;
  }
}

@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_yxnc3H::before,
  #shopify-section-template--27232347685241__section_yxnc3H::after {
    content: '';
    display: block;
    height: 2px;
    background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent);
    box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35);
    position: relative;
    z-index: 10;
  }
}





















/* ============================= */
/* section_VAeYpd — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_VAeYpd h1,
  #shopify-section-template--27232347685241__section_VAeYpd h2,
  #shopify-section-template--27232347685241__section_VAeYpd h3 {
    font-size: 2.6rem !important;
    line-height: 1.3 !important;
  }
}

/* ============================= */
/* section_AUF3Uc — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_AUF3Uc h1,
  #shopify-section-template--27232347685241__section_AUF3Uc h2,
  #shopify-section-template--27232347685241__section_AUF3Uc h3 {
    font-size: 1.6rem !important;
    line-height: 1.3 !important;
  }
}

/* ============================= */
/* section_PCrLwW — mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {

  /* Réduire gap entre image et texte */
  #shopify-section-template--27232347685241__section_PCrLwW .section-content-wrapper {
    gap: 1px !important;
  }

  /* Réduire marge en bas (après le bouton) */
  #shopify-section-template--27232347685241__section_PCrLwW .spacing-style {
    padding-block-end: 1px !important;
  }

}













/* ============================= */
/* section_6ELVCa — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_6ELVCa {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_6ELVCa::before,
#shopify-section-template--27232347685241__section_6ELVCa::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_6ELVCa::before {
  top: 0 !important;
}

#shopify-section-template--27232347685241__section_6ELVCa::after {
  bottom: 0 !important;
}


/* section_6ELVCa — desktop uniquement */
@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_6ELVCa {
    display: none !important;
  }
}

/* section_DqUrfe — mobile uniquement + séparateurs */
@media screen and (min-width: 750px) {
  #shopify-section-template--27232347685241__section_DqUrfe {
    display: none !important;
  }
}

@media screen and (max-width: 749px) {
  #shopify-section-template--27232347685241__section_DqUrfe::before,
  #shopify-section-template--27232347685241__section_DqUrfe::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    left: 0 !important;
    width: 100% !important;
    height: 2px !important;
    background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
    box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
    z-index: 10 !important;
  }
  #shopify-section-template--27232347685241__section_DqUrfe {
    position: relative !important;
  }
  #shopify-section-template--27232347685241__section_DqUrfe::before { top: 0 !important; }
  #shopify-section-template--27232347685241__section_DqUrfe::after { bottom: 0 !important; }
}



/* ============================= */
/* GALLERY SLIDER — FIX LARGEUR MOBILE */
/* ============================= */

@media (max-width: 749px) {

  .gallery-slider__inner,
  .gallery-slider__main,
  .gallery-slider__stage,
  .gallery-slider .slides-wrapper {
    width: 100% !important;
    max-width: 100vw !important;
    overflow: hidden !important;
  }

  .gallery-slider .nav {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    font-size: 22px !important;
    padding: 7px 11px !important;
    z-index: 10 !important;
    width: auto !important;
  }

  .gallery-slider .nav.prev {
    left: 8px !important;
    right: auto !important;
  }

  .gallery-slider .nav.next {
    right: 8px !important;
    left: auto !important;
  }

  .gallery-slider .nav:hover {
    transform: translateY(-50%) !important;
  }

}



























@media screen and (max-width: 749px) {
  #shopify-section-template--27479441015161__section_Phy836 h1,
  #shopify-section-template--27479441015161__section_Phy836 h2,
  #shopify-section-template--27479441015161__section_Phy836 h3 {
    font-size: 2.7rem !important;
    line-height: 1.3 !important;
  }
}


















@media screen and (max-width: 749px) {
  #shopify-section-template--27232347718009__section_Phy836 h1,
  #shopify-section-template--27232347718009__section_Phy836 h2,
  #shopify-section-template--27232347718009__section_Phy836 h3 {
    font-size: 2.7rem !important;
    line-height: 1.3 !important;
  }
}






/* ============================= */
/* section_Phy836 — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27381324546425__section_Phy836 h1,
  #shopify-section-template--27381324546425__section_Phy836 h2,
  #shopify-section-template--27381324546425__section_Phy836 h3 {
    font-size: 2.6rem !important;
    line-height: 1.3 !important;
  }
}




/* ============================= */
/* section_Phy836 — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27390256710009__section_Phy836 h1,
  #shopify-section-template--27390256710009__section_Phy836 h2,
  #shopify-section-template--27390256710009__section_Phy836 h3 {
    font-size: 2.2rem !important;
    line-height: 1.3 !important;
  }
}








<style>
.gallery-slider {
  padding: var(--gs-space-desktop) 0;
  position: relative;
  background: #110011;
}
.gallery-slider__inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px;
}
.gallery-slider__title {
  font-size: {{ section.settings.title_size }}px;
  margin: 0 0 12px;
}
.gallery-slider__text {
  font-size: {{ section.settings.text_size }}px;
  margin: 0 0 32px;
  max-width: 640px;
}

/* SLIDER */
.gallery-slider__main {
  display: flex;
  justify-content: center;
}

.gallery-slider__stage {
  position: relative;
  width: 100%;
  max-width: var(--gs-max);
}

.slides-wrapper {
  overflow: hidden;
}
.slides {
  display: flex;
  transition: transform .4s ease;
}
.slide {
  min-width: 100%;
  display: flex;
  justify-content: center;
}

/* IMAGE */
.media-box {
  width: 100%;
  max-width: var(--gs-max);
  border-radius: 16px;
  overflow: hidden;
  background: #000;
}
.media-box.ratio-square    { aspect-ratio: 1/1; }
.media-box.ratio-vertical  { aspect-ratio: 3/4; }
.media-box.ratio-horizontal{ aspect-ratio: 4/3; }
.media-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* NAV */
.gallery-slider .nav {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  background: rgba(180, 130, 20, 0.15) !important;
  background-image: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  font-size: 32px !important;
  padding: 10px 14px !important;
  cursor: pointer !important;
  z-index: 1 !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  text-shadow: none !important;
  box-shadow: none !important;
  line-height: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: auto !important;
  height: auto !important;
  min-width: unset !important;
  min-height: unset !important;
  transition: background 0.35s ease, box-shadow 0.35s ease !important;
}

.gallery-slider .nav::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.3) 50%, transparent 100%) !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  transform: skewX(-20deg) !important;
  transition: left 0.6s ease !important;
  pointer-events: none !important;
}

.gallery-slider .nav:hover {
  background: rgba(180, 130, 20, 0.35) !important;
  background-image: none !important;
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.4), 0 0 28px rgba(201, 168, 76, 0.15) !important;
  transform: translateY(-50%) !important;
  color: #ffe082 !important;
  -webkit-text-fill-color: #ffe082 !important;
}

.gallery-slider .nav:hover::before {
  left: 140% !important;
}

.gallery-slider .nav.prev { left: -200px !important; }
.gallery-slider .nav.next { right: -200px !important; }

/* THUMBS */
.gallery-slider__thumbs {
  display: flex;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  overflow-x: auto;
}

.gallery-slider .thumb {
  border: none !important;
  background: none !important;
  background-image: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  cursor: pointer !important;
  opacity: 1 !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  transition: none !important;
  min-width: unset !important;
  min-height: unset !important;
  width: auto !important;
  height: auto !important;
  display: block !important;
  transform: none !important;
}

.gallery-slider .thumb::before {
  content: none !important;
  display: none !important;
}

.gallery-slider .thumb::after {
  content: none !important;
  display: none !important;
}

.gallery-slider .thumb img {
  width: 76px;
  border-radius: 8px;
  display: block;
  filter: brightness(0.45) saturate(0.7);
  transform: scale(1);
  transition: filter 0.28s ease, transform 0.28s ease;
  pointer-events: none;
}

.gallery-slider .thumb:hover img,
.gallery-slider .thumb.active img {
  filter: brightness(1) saturate(1);
  transform: scale(1.07);
}

/* MOBILE */
@media (max-width: 768px) {
  .gallery-slider {
    padding: var(--gs-space-mobile) 0;
  }
  .gallery-slider__inner {
    padding: 0 18px;
  }
  .gallery-slider .nav {
    font-size: 26px !important;
    padding: 8px 12px !important;
  }
  .gallery-slider .thumb img {
    width: 88px;
  }
}
</style>

:root {
  --gs-space-desktop: 80px;
  --gs-space-mobile: 60px;
}
















/* ============================= */
/* section_fjzWqc — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_fjzWqc {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_fjzWqc::before,
#shopify-section-template--27381324546425__section_fjzWqc::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_fjzWqc::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_fjzWqc::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_zFAN63 — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_zFAN63 {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_zFAN63::before,
#shopify-section-template--27381324546425__section_zFAN63::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_zFAN63::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_zFAN63::after {
  bottom: 0 !important;
}





/* ============================= */
/* section_JVfVLX — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_JVfVLX {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_JVfVLX::before,
#shopify-section-template--27381324546425__section_JVfVLX::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_JVfVLX::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_JVfVLX::after {
  bottom: 0 !important;
}





/* ============================= */
/* section_kxa8bf — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_kxa8bf {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_kxa8bf::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_bRzB3j::before {
  top: 0 !important;
}



/* ============================= */
/* section_kCmjRW — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_kCmjRW {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_kCmjRW::before,
#shopify-section-template--27381324546425__section_kCmjRW::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_kCmjRW::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_kCmjRW::after {
  bottom: 0 !important;
}



/* ============================= */
/* section_jQp9pT — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_jQp9pT {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_jQp9pT::before,
#shopify-section-template--27381324546425__section_jQp9pT::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_jQp9pT::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_jQp9pT::after {
  bottom: 0 !important;
}



/* ============================= */
/* section_yWAKaf — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27381324546425__section_yWAKaf {
  position: relative !important;
}

#shopify-section-template--27381324546425__section_yWAKaf::before,
#shopify-section-template--27381324546425__section_yWAKaf::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27381324546425__section_yWAKaf::before {
  top: 0 !important;
}

#shopify-section-template--27381324546425__section_yWAKaf::after {
  bottom: 0 !important;
}





/* ============================= */
/* section_e4QaVn — carousel mobile FIX */
/* ============================= */

/* Fix virgule parasite — desktop masqué correctement */
@media screen and (min-width: 750px) {
  #shopify-section-template--27381324546425__section_e4QaVn {
    display: none !important;
  }
}

/* Sur mobile — forcer l'affichage carousel */
@media screen and (max-width: 749px) {
  #shopify-section-template--27381324546425__section_e4QaVn {
    display: block !important;
  }

  #shopify-section-template--27381324546425__section_e4QaVn .resource-list--carousel-mobile {
    display: block !important;
  }

  #shopify-section-template--27381324546425__section_e4QaVn slideshow-slides {
    display: flex !important;
    overflow-x: scroll !important;
    scroll-snap-type: x mandatory !important;
    scrollbar-width: none !important;
  }

  #shopify-section-template--27381324546425__section_e4QaVn slideshow-slide {
    scroll-snap-align: start !important;
    flex-shrink: 0 !important;
  }

  /* Masquer la grille desktop dans cette section */
  #shopify-section-template--27381324546425__section_e4QaVn .resource-list--grid {
    display: none !important;
  }
}







/* ============================= */
/* section_q8C9Ce — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27390256710009__section_q8C9Ce {
  position: relative !important;
}

#shopify-section-template--27390256710009__section_q8C9Ce::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27390256710009__section_q8C9Ce::after {
  bottom: 0 !important;
}






/* ============================= */
/* section_ga4twt — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347718009__section_ga4twt {
  position: relative !important;
}

#shopify-section-template--27232347718009__section_ga4twt::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347718009__section_ga4twt::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_pXYhbj — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27363944268153__section_pXYhbj {
  position: relative !important;
}

#shopify-section-template--27363944268153__section_pXYhbj::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27363944268153__section_pXYhbj::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_9wpCng — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27479441015161__section_9wpCng {
  position: relative !important;
}

#shopify-section-template--27479441015161__section_9wpCng::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27479441015161__section_9wpCng::after {
  bottom: 0 !important;
}










/* ============================= */
/* section_kmypUY — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_kmypUY {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_kmypUY::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_kmypUY::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_WYF7nc — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27396256301433__section_WYF7nc {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_WYF7nc::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27396256301433__section_WYF7nc::after {
  bottom: 0 !important;
}





/* ============================= */
/* section_Phy836 — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27396256301433__section_Phy836 h1,
  #shopify-section-template--27396256301433__section_Phy836 h2,
  #shopify-section-template--27396256301433__section_Phy836 h3 {
    font-size: 2.6rem !important;
    line-height: 1.3 !important;
  }
}




/* ============================= */
/* section_M9bf7d — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27396256301433__section_M9bf7d {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_M9bf7d::before,
#shopify-section-template--27396256301433__section_M9bf7d::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27396256301433__section_M9bf7d::before {
  top: 0 !important;
}

#shopify-section-template--27396256301433__section_M9bf7d::after {
  bottom: 0 !important;
}



/* ============================= */
/* section_3mParc — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27396256301433__section_3mParc {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_3mParc::before,
#shopify-section-template--27396256301433__section_3mParc::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27396256301433__section_3mParc::before {
  top: 0 !important;
}

#shopify-section-template--27396256301433__section_3mParc::after {
  bottom: 0 !important;
}





/* ============================= */
/* section_xnkU7K — titre réduit sur mobile uniquement */
/* ============================= */

@media screen and (max-width: 749px) {
  #shopify-section-template--27396256301433__section_xnkU7K h1,
  #shopify-section-template--27396256301433__section_xnkU7K h2,
  #shopify-section-template--27396256301433__section_xnkU7K h3 {
    font-size: 2rem !important;
    line-height: 1.3 !important;
  }
}








/* ============================= */
/* section_MDgrQi — séparateur haut UNIQUEMENT */
/* ============================= */

#shopify-section-template--27396256301433__section_MDgrQi {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_MDgrQi::before {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  ) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55),
              0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}



/* ============================= */
/* section_twREU6 — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27396256301433__section_twREU6 {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_twREU6::before,
#shopify-section-template--27396256301433__section_twREU6::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27396256301433__section_twREU6::before {
  top: 0 !important;
}

#shopify-section-template--27396256301433__section_twREU6::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_hgae3g — séparateur bas uniquement */
/* ============================= */

#shopify-section-template--27396256301433__section_hgae3g {
  position: relative !important;
}

#shopify-section-template--27396256301433__section_hgae3g::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  ) !important;
  box-shadow: 
    0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}





/* ============================= */
/* section_7Yaieg — séparateur bas uniquement */
/* ============================= */

#shopify-section-template--27232347586937__section_7Yaieg {
  position: relative !important;
}

#shopify-section-template--27232347586937__section_7Yaieg::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  ) !important;
  box-shadow: 
    0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}








/* ============================= */
/* section_main — séparateur bas uniquement */
/* ============================= */

#shopify-section-template--27232347423097__main {
  position: relative !important;
}

#shopify-section-template--27232347423097__main::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 75, 191, 0.2) 25%,
    #ffd2f5 50%,
    rgba(255, 75, 191, 0.2) 75%,
    transparent
  ) !important;
  box-shadow: 
    0 0 18px rgba(255, 75, 191, 0.55),
    0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}






/* ============================= */
/* section_product_recommendations_qggXJq — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347783545__product_recommendations_qggXJq {
  position: relative !important;
}

#shopify-section-template--27232347783545__product_recommendations_qggXJq::before,
#shopify-section-template--27232347783545__product_recommendations_qggXJq::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347783545__product_recommendations_qggXJq::before {
  top: 0 !important;
}

#shopify-section-template--27232347783545__product_recommendations_qggXJq::after {
  bottom: 0 !important;
}








/* ============================= */
/* FIX ARRONDI IMAGE PRODUIT — SOLUTION FINALE */
/* ============================= */

media-gallery {
  --media-radius: 18px !important;
}

media-gallery slideshow-component,
media-gallery slideshow-container,
media-gallery slideshow-slides {
  border-radius: 18px !important;
  overflow: hidden !important;
}

media-gallery slideshow-slide,
media-gallery li.product-media-container {
  border-radius: 18px !important;
  overflow: hidden !important;
  clip-path: inset(0 round 18px) !important;
}













/* Fond du menu mobile */
.menu-drawer,
.header__menu-drawer,
.drawer {
  background-color: #110011 !important; /* ton fond */
}

/* Couleur des liens */
.menu-drawer a,
.header__menu-drawer a,
.drawer a {
  color: #ffffff !important;
}

/* Hover */
.menu-drawer a:hover,
.drawer a:hover {
  color: #ff4bbf !important;
}







/* Supprimer l'outline de focus au tap sur mobile */
@media (any-pointer: coarse) {
  *:focus,
  *:focus-visible {
    outline: none !important;
  }
}

/* Alternative plus large si ça persiste */
button:focus,
a:focus,
button:focus-visible,
a:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  -webkit-tap-highlight-color: transparent !important;
}

/* Supprimer le flash bleu/gris au tap sur iOS/Android */
* {
  -webkit-tap-highlight-color: transparent !important;
}










/* ============================= */
/* FIX SÉPARATEURS + DRAWER — FINAL */
/* ============================= */

/* Séparateurs en dessous de tout */
[id^="shopify-section-"]::before,
[id^="shopify-section-"]::after {
  z-index: -1 !important;
}

/* Header — position relative SEULEMENT sur header-group, pas sur header/header-component */
#header-group {
  position: relative !important;
  z-index: var(--layer-sticky) !important;
}

/* Drawer — au-dessus */
header-drawer,
.menu-drawer-container {
  z-index: var(--layer-raised) !important;
}

/* Backdrop — EN DESSOUS des liens */
.menu-drawer__backdrop {
  z-index: 1 !important;
}

/* Contenu drawer (liens) — AU-DESSUS du backdrop */
[data-header-drawer].menu-drawer {
  z-index: 2 !important;
  position: relative !important;
}









/* ============================= */
/* DRAWER MOBILE — FIX DÉFINITIF */
/* ============================= */

/* 1. Masquer complètement le summary hamburger quand drawer ouvert */
details[open] > summary.header__icon--menu {
  display: none !important;
}

/* 2. Reset — supprimer tout ce que j'avais mis avant */
details[open] summary.header__icon--menu {
  position: static !important;
  width: auto !important;
  height: auto !important;
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  z-index: auto !important;
  top: auto !important;
  right: auto !important;
}

/* 3. La vraie croix est dans le slot du drawer — cibler le bouton interne */
[data-header-drawer] .drawer__close,
.menu-drawer .drawer__close,
[data-header-drawer] button[aria-label*="ermer"],
[data-header-drawer] button[aria-label*="lose"] {
  position: absolute !important;
  top: 12px !important;
  right: 12px !important;
  left: auto !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(201, 168, 76, 0.75) !important;
  background: rgba(201, 168, 76, 0.08) !important;
  background-image: none !important;
  color: #c9a84c !important;
  -webkit-text-fill-color: #c9a84c !important;
  text-shadow: none !important;
  box-shadow: none !important;
  cursor: pointer !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background 0.35s ease, box-shadow 0.35s ease !important;
  transform: none !important;
  padding: 0 !important;
  z-index: 10 !important;
}

/* 4. Fix bande blanche — le drawer couvre tout */
[data-header-drawer].menu-drawer {
  top: 0 !important;
  padding-top: 0 !important;
  background-color: #110011 !important;
}

/* 5. Header caché derrière le drawer quand ouvert */
details[open] ~ * .header-section,
.menu-drawer-container[open] ~ header {
  z-index: 0 !important;
}

/* ============================= */
/* DRAWER MOBILE — LIEN ACTIF EN ÉVIDENCE */
/* ============================= */

/* Assombrir tous les liens par défaut */
[data-header-drawer] a,
.menu-drawer a {
  opacity: 0.45 !important;
  transition: opacity 0.25s ease !important;
}

/* Lien actif (page courante) — pleine luminosité */
[data-header-drawer] a[aria-current="page"],
[data-header-drawer] a.active,
[data-header-drawer] a[class*="active"],
.menu-drawer a[aria-current="page"],
.menu-drawer a.active {
  opacity: 1 !important;
  -webkit-text-fill-color: #f2df9c !important;
}

/* Hover — redonner la luminosité */
[data-header-drawer] a:hover,
.menu-drawer a:hover {
  opacity: 1 !important;
  -webkit-text-fill-color: #ffe082 !important;
}

/* ============================= */
/* DRAWER MOBILE — ESPACEMENT + HOVER LIENS */
/* ============================= */

/* Marge en haut du contenu du drawer */
[data-header-drawer].menu-drawer,
.menu-drawer {
  padding-top: 70px !important;
}

/* Hover sur les liens — effet doré avec shimmer */
[data-header-drawer] a,
.menu-drawer a {
  position: relative !important;
  display: inline-block !important;
  overflow: hidden !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  transition: opacity 0.25s ease, background 0.3s ease, padding-left 0.25s ease !important;
}

/* Shimmer au hover */
[data-header-drawer] a::before,
.menu-drawer a::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 60% !important;
  height: 100% !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255, 220, 100, 0.22) 50%, transparent 100%) !important;
  transform: skewX(-20deg) !important;
  transition: left 0.55s ease !important;
  pointer-events: none !important;
}

[data-header-drawer] a:hover,
.menu-drawer a:hover {
  opacity: 1 !important;
  background: rgba(201, 168, 76, 0.1) !important;
  padding-left: 18px !important;
  -webkit-text-fill-color: #ffe082 !important;
}

[data-header-drawer] a:hover::before,
.menu-drawer a:hover::before {
  left: 140% !important;
}
















/* ============================= */
/* FIX BANDE BLANCHE HAUT MOBILE — CIBLAGE DIRECT */
/* ============================= */

@media screen and (max-width: 749px) {

  /* Le shopify-section-group du header */
  .shopify-section-group-header-group,
  #shopify-section-group-header-group {
    background: #110011 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  /* Annuler tout margin-top sur la première section */
  .content-for-layout > .shopify-section:first-child,
  .content-for-layout > *:first-child {
    margin-top: 0 !important;
    padding-top: 0 !important;
  }

  /* Le body lui-même */
  body, html {
    background-color: #110011 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

}


/* ============================= */
/* FIX SUPPRESSION BANDE SKIP-TO-CONTENT */
/* ============================= */

.skip-to-content-link,
a.skip-to-content-link,
a.skip-to-content-link.button-secondary {
  display: none !important;
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
}




/* ============================= */
/* FIX SKIP-TO-CONTENT — SUPPRESSION TOTALE */
/* ============================= */

a[href="#MainContent"],
a.skip-to-content-link,
.skip-to-content-link {
  display: none !important;
  visibility: hidden !important;
  position: fixed !important;
  top: -9999px !important;
  left: -9999px !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  clip: rect(0,0,0,0) !important;
}




/* ============================= */
/* section_QWwR9t — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_QWwR9t {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_QWwR9t::before,
#shopify-section-template--27232347685241__section_QWwR9t::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_QWwR9t::before {
  top: 0 !important;
}

#shopify-section-template--27232347685241__section_QWwR9t::after {
  bottom: 0 !important;
}






/* ============================= */
/* section_mhkLkU — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_mhkLkU {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_mhkLkU::before,
#shopify-section-template--27232347685241__section_mhkLkU::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_mhkLkU::before {
  top: 0 !important;
}

#shopify-section-template--27232347685241__section_mhkLkU::after {
  bottom: 0 !important;
}






/* ============================= */
/* section_yxnc3H — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_yxnc3H {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_yxnc3H::before,
#shopify-section-template--27232347685241__section_yxnc3H::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_yxnc3H::before {
  top: 0 !important;
}

#shopify-section-template--27232347685241__section_yxnc3H::after {
  bottom: 0 !important;
}




/* ============================= */
/* section_gyEtNe — séparateurs haut et bas FORCÉS */
/* ============================= */

#shopify-section-template--27232347685241__section_gyEtNe {
  position: relative !important;
}

#shopify-section-template--27232347685241__section_gyEtNe::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  left: 0 !important;
  width: 100% !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(255, 75, 191, 0.2) 25%, #ffd2f5 50%, rgba(255, 75, 191, 0.2) 75%, transparent) !important;
  box-shadow: 0 0 18px rgba(255, 75, 191, 0.55), 0 0 42px rgba(170, 70, 255, 0.35) !important;
  z-index: 10 !important;
}

#shopify-section-template--27232347685241__section_gyEtNe::after {
  bottom: 0 !important;
}