/** Shopify CDN: Minification failed

Line 4773:29 Expected identifier but found "!"
Line 6229:3 Unexpected "/"

**/
* {
  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%;
  
  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%);
  }
}



/* =========================================================
   PERSONALISATION styles (Shopify product page)
   Works as "best-effort" across common option/personalisation apps
   ========================================================= */

/* 1) Try to catch the personalisation/options block in common apps */
:where(
  .product__info-container,
  .product__info-wrapper,
  .product-form,
  .product__form,
  .product__content,
  .main-product,
  .shopify-section
)
:where(
  /* common option apps / blocks */
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .product-option,
  .options,
  .option,
  .line-item-property,
  .properties,
  .property,
  .custom-field,
  .customization,
  .personalisation,
  .personalization
){
  --p-bg: rgba(255,255,255,.65);
  --p-border: rgba(0,0,0,.12);
  --p-border-strong: rgba(0,0,0,.22);
  --p-text: rgba(0,0,0,.78);
  --p-muted: rgba(0,0,0,.55);
  --p-radius: 14px;
  --p-input-radius: 10px;
  --p-shadow: 0 12px 28px rgba(0,0,0,.08);
  --p-focus: 0 0 0 3px rgba(0,0,0,.12);
}

/* 2) Card container look (applies to option blocks) */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
){
  background: var(--p-bg);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid var(--p-border);
  border-radius: var(--p-radius);
  box-shadow: var(--p-shadow);
  padding: 18px;
  margin-top: 14px;
}

/* 3) Headings inside option blocks */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(h2,h3,h4,.title,.heading,.gpo-title,.option-title){
  margin: 0 0 12px;
  color: var(--p-text);
  font-weight: 650;
  letter-spacing: .2px;
}

/* 4) Layout: make fields look aligned (grid) */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(form,.gpo-form,.options-form,.product-form__input){
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 14px;
  align-items: start;
}

/* Fallback: if app doesn't wrap fields in a form, still align blocks */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(.option-set,.option-row,.gpo-field,.field,.form__field,.line-item-property){
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 14px;
}

/* 5) Labels */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(label,.label,.gpo-label,.option-label){
  display: inline-flex;
  gap: 10px;
  align-items: center;
  color: var(--p-text);
  font-size: 14px;
  line-height: 1.2;
}

/* 6) Inputs / textarea / select */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="text"],input[type="number"],input[type="email"],textarea,select){
  width: 100%;
  border: 1px solid var(--p-border-strong);
  border-radius: var(--p-input-radius);
  padding: 12px 14px;
  font-size: 15px;
  color: var(--p-text);
  background: rgba(255,255,255,.88);
  outline: none;
  box-shadow: none;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}

:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(textarea){
  min-height: 92px;
  resize: vertical;
}

:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="text"],input[type="number"],input[type="email"],textarea)::placeholder{
  color: var(--p-muted);
}

:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="text"],input[type="number"],input[type="email"],textarea,select):focus{
  border-color: rgba(0,0,0,.45);
  box-shadow: var(--p-focus);
  background: #fff;
}

/* 7) Nice select arrow */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(select){
  appearance: none;
  -webkit-appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(0,0,0,.55) 50%),
    linear-gradient(135deg, rgba(0,0,0,.55) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 42px;
}

/* 8) Radios (Yes/No) */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="radio"]){
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(0,0,0,.35);
  background: rgba(255,255,255,.92);
  display: inline-grid;
  place-content: center;
  cursor: pointer;
  transition: transform .12s ease, border-color .18s ease, box-shadow .18s ease;
}

:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="radio"])::before{
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 999px;
  transform: scale(0);
  transition: transform .14s ease;
  background: #c40000; /* red dot like your screenshot */
}

:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="radio"]:checked){
  border-color: rgba(0,0,0,.45);
  box-shadow: 0 0 0 3px rgba(196,0,0,.10);
}
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(input[type="radio"]:checked)::before{
  transform: scale(1);
}

/* 9) Required star */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(.required,.form-required,.req,.gpo-required){
  color: #b00020;
}

/* 10) Make long fields full-width if app uses common wrappers */
:where(
  .bold_options,
  .bold-options,
  .w3-product-options,
  .w3po,
  .gpo-container,
  .gpo-app,
  .product-options,
  .options,
  .properties,
  .customization,
  .personalisation,
  .personalization
) :where(.field--full,.full,.full-width,.span-2,.gpo-field--wide){
  grid-column: 1 / -1;
}

/* 11) Mobile: single column */
@media (max-width: 720px){
  :where(
    .bold_options,
    .bold-options,
    .w3-product-options,
    .w3po,
    .gpo-container,
    .gpo-app,
    .product-options,
    .options,
    .properties,
    .customization,
    .personalisation,
    .personalization
  ) :where(form,.gpo-form,.options-form,.product-form__input,.option-set,.option-row,.gpo-field,.field,.line-item-property){
    grid-template-columns: 1fr;
  }
}

.youtube-icon {
  width: 10px;
  height: 10px;
}

/* === FORCE arrows visible & black (almost any slider) === */

/* Dawn / Shopify slider buttons */
.slider-button,
.slider-button .icon,
.slider-button svg,
.slider-button svg *,
.product__media .slider-button,
.product__media-wrapper .slider-button {
  opacity: 1 !important;
  visibility: visible !important;
}

.slider-button .icon,
.slider-button svg,
.slider-button svg * {
  color: #000 !important;
  fill: #000 !important;
  stroke: #000 !important;
}

/* Swiper */
.swiper-button-prev,
.swiper-button-next,
.swiper-button-prev:after,
.swiper-button-next:after {
  opacity: 1 !important;
  visibility: visible !important;
  color: #000 !important;
}

/* Flickity */
.flickity-button,
.flickity-button-icon {
  opacity: 1 !important;
  visibility: visible !important;
  fill: #000 !important;
  color: #000 !important;
}

/* Splide */
.splide__arrow,
.splide__arrow svg,
.splide__arrow svg * {
  opacity: 1 !important;
  visibility: visible !important;
  color: #000 !important;
  fill: #000 !important;
  stroke: #000 !important;
}

/* Частая причина "пропали": фильтры/смешивание */
.slider-button,
.swiper-button-prev,
.swiper-button-next,
.flickity-button,
.splide__arrow {
  filter: none !important;
  mix-blend-mode: normal !important;
  /* z-index: 50 !important; */
}

/* Чтобы на прозрачном PNG не терялись — подложка (можешь убрать если не надо) */
.slider-button,
.swiper-button-prev,
.swiper-button-next,
.flickity-button,
.splide__arrow {
  background: rgba(255,255,255,0.65) !important;
  border-radius: 999px !important;
}

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

.text-block--ANm4vclhXdEU2QjUvN__text_bxeAVq  .metafield-rich_text_field ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.text-block--ANm4vclhXdEU2QjUvN__text_bxeAVq .metafield-rich_text_field li {
  position: relative;
  margin: 0;
  padding: 18px 22px 18px 54px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 2px;
  color: #ffffff;
  line-height: 1.5;
  background: transparent;
}

.text-block--ANm4vclhXdEU2QjUvN__text_bxeAVq .metafield-rich_text_field li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  width: 26px;
  height: 1px;
  background: rgba(255, 255, 255, 0.75);
  transform: translateY(-50%);
}

.text-block--ANm4vclhXdEU2QjUvN__text_bxeAVq  .metafield-rich_text_field strong {
  font-weight: 600;
  color: #ffffff;
}

.text-block--AU0FqQXgxQlloUnJQZ__text_VrkgCD .metafield-rich_text_field ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.text-block--AU0FqQXgxQlloUnJQZ__text_VrkgCD .metafield-rich_text_field li {
  position: relative;
  margin: 0;
  padding: 18px 22px 18px 54px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  border-radius: 2px;
  color: #ffffff;
  line-height: 1.5;
  background: transparent;
}

.text-block--AU0FqQXgxQlloUnJQZ__text_VrkgCD .metafield-rich_text_field li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  width: 26px;
  height: 1px;
  background: rgba(255, 255, 255, 0.75);
  transform: translateY(-50%);
}

.text-block--AU0FqQXgxQlloUnJQZ__text_VrkgCD .metafield-rich_text_field strong {
  font-weight: 600;
  color: #ffffff;
}
/*-----------------------*/

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field {
  width: 100%;
}

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field ul {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 16px;
}

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field li {
  margin: 0;
  padding: 22px 20px;
  min-height: 110px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 18px;
  background: #fff;
  color: inherit;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 500;
}

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field p {
  margin: 0;
  font-size: 18px;
  line-height: 1.5;
  color: inherit;
}

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field p br {
  display: none;
}

@media screen and (max-width: 989px) {
  .text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field ul {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media screen and (max-width: 749px) {
  .text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field ul {
    grid-template-columns: 1fr;
  }

  .text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field li {
    min-height: auto;
    padding: 18px 16px;
    font-size: 18px;
    border-radius: 14px;
  }

  .text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field p {
    font-size: 16px;
  }
  

}

.text-block--AdGwvTEpvRzRpaGc1b__text_WV88p3  .metafield-rich_text_field p {
  margin: 20px 0;
  padding: 18px 20px;

  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 18px;
  background: #fff;
  font-size: 18px;
  line-height: 1.5;
  color: inherit;
}



.text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field {
  width: 100%;
}

.text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field ul {
  margin: 0 0 18px;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 16px;
}

.text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field li {
  margin: 0;
  padding: 22px 20px;
  min-height: 110px;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 18px;
  background: #fff;
  color: inherit;
  font-size: 22px;
  line-height: 1.25;
  font-weight: 500;
}

.text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field p {
  margin: 20px 0;
  padding: 18px 20px;
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: 18px;
  background: #fff;
  font-size: 18px;
  line-height: 1.5;
  color: inherit;
}

.text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field p br {
  display: none;
}

@media screen and (max-width: 989px) {
  .text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field ul {
    grid-template-columns: repeat(2, minmax(180px, 1fr));
  }
}

@media screen and (max-width: 749px) {
  .text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field ul {
    grid-template-columns: 1fr;
  }

  .text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field li {
    min-height: auto;
    padding: 18px 16px;
    font-size: 18px;
    border-radius: 14px;
  }

  .text-block--AM2xxOStuREtvbzBCR__text_7RkUPG .metafield-rich_text_field p {
    font-size: 16px;
  }
}


/*----scroll-----*/
#dimensions,
#description,
#delivery {
  scroll-margin-top: 180px;
}

@media screen and (min-width: 750px) {
  #features {
    scroll-margin-top: 500px;
  }
}
/*---------------*/
@media screen and (max-width: 749px) {
  .feefo-section {
    display: none !important;
  }
}
.feefo-section {
  background-color: #EBECF2; !important;
}


/*--------menu-------*/


@media screen and (min-width: 990px) {
  /* Родитель пункта меню */
  .header-menu .menu-list__list-item {
    position: relative !important;
    overflow: visible !important;
  }

  .header-menu .menu-list,
  .header-menu nav,
  .header-menu .header-menu__inner {
    overflow: visible !important;
  }

  /* Внешняя обертка dropdown */
  .header-menu .menu-list__submenu {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: 50% !important;
    transform: translateX(-50%) translateY(10px) !important;
    width: max-content !important;
    min-width: 0 !important;
    max-width: max-content !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
    /* z-index: 9999 !important; */

    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition:
      opacity 0.28s ease,
      transform 0.32s cubic-bezier(0.22, 1, 0.36, 1),
      visibility 0.28s ease !important;
  }

  .header-menu .menu-list__submenu-inner {
    display: inline-block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  /* Открытие по hover/focus */
  .header-menu .menu-list__list-item:hover > .menu-list__submenu,
  .header-menu .menu-list__list-item:focus-within > .menu-list__submenu {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
    transform: translateX(-50%) translateY(0) !important;
  }

  /* Сам dropdown */
  .header-menu .mega-menu,
  .header-menu .mega-menu.section,
  .header-menu .mega-menu.section--full-width,
  .header-menu .mega-menu.section--full-width-margin {
    width: 240px !important;
    min-width: 240px !important;
    max-width: 240px !important;
    margin: 0 !important;
    padding: 8px !important;
    background: rgba(255, 255, 255, 0.98) !important;
    border: 1px solid rgba(22, 33, 62, 0.08) !important;
    border-radius: 16px !important;
    box-shadow:
      0 10px 30px rgba(16, 24, 40, 0.08),
      0 2px 8px rgba(16, 24, 40, 0.05) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    overflow: hidden !important;
  }

  /* Убираем механику mega menu */
  .header-menu .mega-menu__grid,
  .header-menu .mega-menu__list,
  .header-menu .mega-menu__column,
  .header-menu .mega-menu__column--span-1 {
    display: block !important;
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .header-menu .mega-menu__column > div {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
  }

  .header-menu .mega-menu__column > div + div .mega-menu__link {
    border-top: 1px solid rgba(22, 33, 62, 0.06) !important;
  }

  /* Ссылки */
  .header-menu .mega-menu__link {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 46px !important;
    padding: 12px 14px !important;
    margin: 0 !important;
    border-radius: 10px !important;
    color: #222633 !important;
    text-decoration: none !important;
    background: transparent !important;
    line-height: 1.35 !important;
    transition:
      background 0.22s ease,
      color 0.22s ease,
      transform 0.22s ease,
      padding-left 0.22s ease !important;
  }

  .header-menu .mega-menu__link-title {
    display: block !important;
    white-space: normal !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
  }

  /* Hover стиль в стилистике сайта */
  .header-menu .mega-menu__link:hover,
  .header-menu .mega-menu__link:focus-visible {
    background: linear-gradient(90deg, rgba(32, 88, 174, 0.08), rgba(255, 77, 90, 0.08)) !important;
    color: #2058ae !important;
    transform: translateX(3px) !important;
    padding-left: 17px !important;
    outline: none !important;
  }

  /* Маленький акцент-сайдбар слева при hover */
  .header-menu .mega-menu__link::before {
    content: "" !important;
    position: absolute !important;
    left: 0 !important;
    top: 10px !important;
    bottom: 10px !important;
    width: 3px !important;
    border-radius: 999px !important;
    background: linear-gradient(180deg, #2058ae, #ff4d5a) !important;
    opacity: 0 !important;
    transform: scaleY(0.65) !important;
    transition:
      opacity 0.22s ease,
      transform 0.22s ease !important;
  }

  .header-menu .mega-menu__link:hover::before,
  .header-menu .mega-menu__link:focus-visible::before {
    opacity: 1 !important;
    transform: scaleY(1) !important;
  }

  /* Верхнее меню тоже слегка улучшим */
  .header-menu .menu-list__link {
    position: relative !important;
    transition: color 0.22s ease !important;
  }

  .header-menu .menu-list__link:hover,
  .header-menu .menu-list__link[aria-expanded="true"] {
    color: #2058ae !important;
  }

  /* Тонкая анимационная линия под верхним пунктом */
  .header-menu .menu-list__link::after {
    content: "" !important;
    position: absolute !important;
    left: 50% !important;
    bottom: -6px !important;
    width: 0 !important;
    height: 2px !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, #2058ae, #ff4d5a) !important;
    transform: translateX(-50%) !important;
    transition: width 0.24s ease !important;
  }

  .header-menu .menu-list__list-item:hover > .menu-list__link::after,
  .header-menu .menu-list__list-item:focus-within > .menu-list__link::after {
    width: 70% !important;
  }
}
/*----footer-----*/
/* #shopify-section-sections--27722028056908__footer,
#shopify-section-sections--27722028056908__footer .section,
#shopify-section-sections--27722028056908__footer .section-background,
#shopify-section-sections--27722028056908__footer .footer-content {
  background: linear-gradient(135deg, #2b5d78 0%, #2f6f8b 38%, #3f95b0 70%, #62c5d8 100%) !important;
} */

/* .shopify-section-group-footer-group {
  background: linear-gradient(to right, #4380BA 0%, #6A90B3 100%) !important;
} */



/* .shopify-section-group-footer-group {
  background: linear-gradient(135deg, #3F6F9A 0%, #7FA6C4 100%) !important; Good one 
} */


/* .shopify-section-group-footer-group {
  background: linear-gradient(to top, #3F6F9A 0%, #7FA6C4 100%) !important; vertical 
} */

.shopify-section-group-footer-group {
  background: linear-gradient(
    to top,
    #3F6F9A 0%,
    #5F8FB5 55%,
    #7FA6C4 100%
  ) !important;
}

.shopify-section-group-footer-group .section,
.shopify-section-group-footer-group .section-background,
.shopify-section-group-footer-group .footer-content,
.shopify-section-group-footer-group .group-block {
  background: transparent !important;
}

/*---- header - search  -----*/
/*---- header - search  -----*/

.header__row--top .header__columns {
  display: grid;
  grid-template-columns: auto minmax(420px, 620px) auto;
  align-items: center;
  gap: 28px;
}

.header__row--top .header__column--left,
.header__row--top .header__column--center,
.header__row--top .header__column--right {
  display: flex;
  align-items: center;
}

.header__row--top .header__column--left {
  justify-content: flex-start;
  gap: 12px;
}

.header__row--top .header__column--center {
  justify-content: center;
  min-width: 0;
}

.header__row--top .header__column--right {
  justify-content: flex-end;
  gap: 18px;
  white-space: nowrap;
}

.custom-header-search {
  width: 100%;
}

.custom-header-search__form {
  position: relative;
  width: 100%;
  display: block;
}

.custom-header-search__input {
  width: 100%;
  min-width: 0;
  height: 48px;
  padding: 0 112px 0 16px;
  border: 1px solid #d6d6d6;
  border-radius: 12px;
  background: #ffffff;
  color: #1a1a1a;
  font-size: 15px;
  appearance: none;
  -webkit-appearance: none;
  box-shadow: none;
}

.custom-header-search__input::placeholder {
  color: #7a7a7a;
}

.custom-header-search__input:focus {
  outline: none;
  border-color: #aeb8c2;
  box-shadow: none;
}

.custom-header-search__button,
.custom-header-search__form button,
.custom-header-search__form button:hover,
.custom-header-search__form button:focus,
.custom-header-search__form button:active {
  position: absolute;
  top: 50%;
  right: 6px;
  transform: translateY(-50%);
  height: 36px !important;
  min-height: 36px !important;
  padding: 0 14px !important;
  border: 0 !important;
  border-radius: 8px !important;
  background: transparent !important;
  background-image: none !important;
  color: #2f587c !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  white-space: nowrap;
  cursor: pointer;
  box-shadow: none !important;
  appearance: none;
  -webkit-appearance: none;
}

.custom-header-search__form button:hover {
  background: #f3f5f7 !important;
  color: #2f587c !important;
}

.header__row--bottom .search-action {
  display: none !important;
}

@media screen and (max-width: 1200px) {
  .header__row--top .header__columns {
    grid-template-columns: auto minmax(300px, 500px) auto;
    gap: 20px;
  }
}

@media screen and (max-width: 990px) {
  .header__row--top .header__columns {
    grid-template-columns: auto minmax(220px, 360px) auto;
    gap: 14px;
  }

  .custom-header-search__input {
    height: 44px;
    padding-right: 96px;
  }
}

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

.custom-header-search {
  position: relative;
  width: 100%;
}

.custom-header-search__form {
  position: relative;
}

.custom-header-search__results {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  right: 0;
  background: #ffffff;
  border: 1px solid #d9dee5;
  border-radius: 18px;
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.12);
  overflow: hidden;
  z-index: 50;
  display: none;
}

.custom-header-search__results.is-active {
  display: block;
}

.custom-header-search__results-inner {
  max-height: 420px;
  overflow-y: auto;
}

.custom-header-search__result-item {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  text-decoration: none;
  color: inherit;
  border-top: 1px solid #f0f2f5;
  background: #fff;
  transition: background 0.2s ease;
}

.custom-header-search__result-item:first-child {
  border-top: 0;
}

.custom-header-search__result-item:hover {
  background: #f6f9fc;
}

.custom-header-search__result-image {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  object-fit: cover;
  background: #f3f3f3;
}

.custom-header-search__result-title {
  font-size: 14px;
  line-height: 1.35;
  color: #1f2d3d;
}

.custom-header-search__result-price {
  margin-top: 4px;
  font-size: 13px;
  color: #5f6f82;
}

.custom-header-search__empty,
.custom-header-search__loading {
  padding: 16px 18px;
  font-size: 14px;
  color: #5f6f82;
  background: #fff;
}

.header__columns {
  padding: 5px 0;
}


/* ---------- phone ------------ */

.header-top-right-extras {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.header-tel {
  flex: 0 1 auto;
  min-width: 0;
}

.header-tel a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: #1f1f1f;
  white-space: nowrap;
  min-width: 0;
}

.header-tel__icon {
  width: 32px;
  height: 32px;
  min-width: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #1f6eae;
  border: 1.5px solid currentColor;
  transition: all 0.2s ease;
}

.header-tel__icon svg {
  width: 15px;
  height: 15px;
}

.header-tel__text {
  font-size: 15px;
  line-height: 1;
  font-weight: 500;
  color: #1f1f1f;
  white-space: nowrap;
}

.header-tel a:hover .header-tel__icon {
  background: rgba(31, 110, 174, 0.08);
  transform: translateY(-1px);
}

.header-tel a:hover .header-tel__text {
  color: #1f6eae;
}

/* если места мало — скрываем номер, оставляем иконку */
@media screen and (max-width: 1180px) {
  .header-tel__text {
    display: none;
  }
}

/* на мобилке тоже только иконка */
@media screen and (max-width: 749px) {
  .header-tel__text {
    display: none;
  }

  .header-tel__icon {
    width: 30px;
    height: 30px;
    min-width: 30px;
  }
}

/* ===== DESKTOP HEADER RIGHT SIDE FIX ===== */
.header__row--top .header__column--right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  min-width: 0;
  flex-wrap: nowrap;
}

.header-top-right-extras {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
  min-width: 0;
}

.header-tel {
  display: flex;
  align-items: center;
  min-width: 0;
}

.header-tel a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  white-space: nowrap;
  color: #222222;
}

.header-tel__icon {
  width: 32px;
  height: 32px;
  min-width: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: #1f6eae;
  border: 1.5px solid currentColor;
  background: transparent;
}

.header-tel__icon svg {
  width: 15px;
  height: 15px;
}

.header-tel__text {
  font-size: 15px;
  line-height: 1;
  font-weight: 500;
  color: #222222;
}

.header-tel a:hover .header-tel__icon {
  background: rgba(31, 110, 174, 0.08);
}

.header-tel a:hover .header-tel__text {
  color: #1f6eae;
}

/* если ширины мало — скрываем текст, оставляем иконку */
@media screen and (max-width: 1180px) {
  .header-tel__text {
    display: none;
  }
}

/* ===== MOBILE RESET ===== */
@media screen and (max-width: 749px) {
  .header-top-right-extras,
  .header-tel,
  .header-tel__text {
    display: none !important;
  }

  .header__row--top .header__column--right {
    gap: 10px;
  }

  .header__row--top .header__column--left,
  .header__row--top .header__column--right,
  .header__row--top .header__column--center {
    min-width: 0;
  }

  .header__row--top .header__columns {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }

  .header__row--top .header-logo {
    max-width: 160px;
  }

  .header__row--top .header-logo img,
  .header__row--top .header-logo__image {
    max-width: 100%;
    height: auto;
  }
}

/* ===== RIGHT SIDE ===== */
.header__row--top .header__column--right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  flex-wrap: nowrap;
  min-width: 0;
}

.header-top-right-extras {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

.header-tel {
  display: flex;
  align-items: center;
}

.header-tel a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  white-space: nowrap;
  color: #222222;
}

.header-tel__icon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1.5px solid #1f6eae;
  color: #1f6eae;
  background: transparent;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.header-tel__icon svg {
  width: 15px;
  height: 15px;
}

.header-tel__text {
  font-size: 15px;
  line-height: 1;
  font-weight: 500;
  color: #222222;
}

.header-tel a:hover .header-tel__icon {
  background: rgba(31, 110, 174, 0.08);
}

.header-tel a:hover .header-tel__text {
  color: #1f6eae;
}

/* tablet: только иконка */
@media screen and (max-width: 1180px) {
  .header-tel__text {
    display: none;
  }
}

/* mobile: иконка телефона + иконка поиска остаются */
@media screen and (max-width: 749px) {
  .header-top-right-extras,
  .header-tel {
    display: flex !important;
    align-items: center;
  }

  .header-tel__text {
    display: none !important;
  }

  .header-tel a {
    gap: 0;
  }

  .header-tel__icon {
    width: 32px;
    height: 32px;
    min-width: 32px;
  }

  .header__row--top .header__column--right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
  }

  /* поиск на мобилке не скрывать */
  .header__row--top .search-action,
  .header__row--top search-button {
    display: flex !important;
    align-items: center;
  }
}

@media screen and (max-width: 749px) {
  /* правый блок */
  .header__row--top .header__column--right {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
  }

  /* телефон на мобилке: только иконка */
  .header-top-right-extras,
  .header-tel {
    display: flex !important;
    align-items: center !important;
  }

  .header-tel__text {
    display: none !important;
  }

  .header-tel a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
  }

  .header-tel__icon {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
  }

  /* ПОИСК НА МОБИЛКЕ ОСТАЕТСЯ */
  .header__row--top .search-action,
  .header__row--top search-button,
  .header__row--mobile .search-action,
  .header__row--mobile search-button {
    display: flex !important;
    align-items: center !important;
  }

  /* если где-то раньше поиск скрывался */
  .search-action.mobile\\:hidden,
  search-button.mobile\\:hidden {
    display: flex !important;
  }
}

@media screen and (max-width: 749px) {
  /* показываем телефон, поиск и корзину */
  .header__column--right {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
  }

  search-button.search-action,
  .header__column--right .search-action {
    display: flex !important;
    align-items: center !important;
  }

  /* СКРЫТЬ десктопный аккаунт */
  anchored-popover-component.account-popover,
  .account-popover {
    display: none !important;
  }

  /* ПОКАЗАТЬ мобильный аккаунт */
  dialog-component.account-drawer,
  .account-drawer {
    display: block !important;
  }
}

/* -------------- bottom text  -------------- */
a {
  text-decoration: none;
}

a:hover {
  text-decoration: underline;
}

a:only-of-type {
  text-decoration: underline;
}

a:not(:hover) {
  text-decoration: none;
}





/* -------------- bottom text end -------------- */



/* -------------- bottom text end two -------------- */
/* Stable image swatches */
variant-picker fieldset.variant-option {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  overflow: visible !important;
}

variant-picker fieldset.variant-option legend {
  width: 100% !important;
  flex: 0 0 100% !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;

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

  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
  overflow: hidden !important;

  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready input {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 3 !important;
  margin: 0 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__text {
  display: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__pill.lb-swatch-image {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;

  display: block !important;
  padding: 0 !important;
  margin: 0 !important;

  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background-color: #fff !important;
  background-image: var(--lb-swatch-img) !important;
  background-size: 78% auto !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;

  overflow: hidden !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  transform: none !important;

  flex: 0 0 48px !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__pill::before,
variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__pill::after {
  display: none !important;
  content: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready input:checked 
  ~ .variant-option__button-label__pill {
  border: 1px solid #cfcfcf !important;
  box-shadow: inset 0 0 0 3px #0b75b7 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready:hover .variant-option__button-label__pill {
  border-color: #0b75b7 !important;
}


/* Hide swatch text permanently */
variant-picker .variant-option__button-label__text {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  overflow: hidden !important;
}

/* Title line like: Colour : Black */
variant-picker fieldset.variant-option legend {
  display: block !important;
  width: 100% !important;
  margin-bottom: 8px !important;
  font-weight: 700 !important;
}

variant-picker:not(.lb-swatches-loaded) .variant-option__button-label__text {
  display: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready {
  flex: 0 0 48px !important;
}


variant-picker fieldset.variant-option {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  align-items: center !important;
  min-height: 72px !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready {
  width: 48px !important;
  height: 48px !important;
  flex: 0 0 48px !important;
  padding: 0 !important;
  margin: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  background: transparent !important;
  border: 0 !important;
  transform: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready input {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  z-index: 3 !important;
  cursor: pointer !important;
}

variant-picker .variant-option__button-label__text {
  display: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__pill.lb-swatch-image {
  width: 48px !important;
  height: 48px !important;
  flex: 0 0 48px !important;
  box-sizing: border-box !important;

  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background-color: #fff !important;
  background-image: var(--lb-swatch-img) !important;
  background-size: 74% auto !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;

  overflow: hidden !important;
  transition: box-shadow .15s ease, border-color .15s ease !important;
  transform: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready input:checked 
  ~ .variant-option__button-label__pill {
  border-color: #cfcfcf !important;
  box-shadow: inset 0 0 0 3px #0b75b7 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready:hover 
  .variant-option__button-label__pill {
  border-color: #0b75b7 !important;
}

variant-picker .variant-option__button-label__pill::before,
variant-picker .variant-option__button-label__pill::after {
  display: none !important;
  content: none !important;
}

/* fallback: no image = text */
variant-picker .variant-option__button-label.lb-swatch-fallback {
  width: auto !important;
  min-width: 48px !important;
  max-width: none !important;
}

variant-picker .variant-option__button-label.lb-swatch-fallback .variant-option__button-label__pill {
  width: auto !important;
  min-width: 48px !important;
  max-width: 120px !important;
  padding: 0 12px !important;

  border-radius: 999px !important;
  background-image: none !important;
  background: #f5f5f5 !important;

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

variant-picker .variant-option__button-label.lb-swatch-fallback .lb-swatch-text {
  display: block !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  color: #222 !important;
  white-space: nowrap !important;
}

variant-picker .variant-option__button-label.lb-swatch-fallback .variant-option__button-label__text {
  display: none !important;
}

/* ===== LB4Y stable image/text swatches ===== */

variant-picker fieldset.variant-option {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 8px 0 18px !important;
  border: 0 !important;
}

variant-picker fieldset.variant-option legend {
  flex: 0 0 100% !important;
  width: 100% !important;
  margin: 0 0 6px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

/* Common label */
variant-picker .variant-option__button-label.lb-swatch-ready {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none !important;
  overflow: visible !important;
}

/* Invisible clickable input */
variant-picker .variant-option__button-label.lb-swatch-ready input {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 5 !important;
  margin: 0 !important;
}

/* ---------- Image swatches ---------- */

variant-picker .variant-option__button-label.lb-swatch-image-label {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;
  flex: 0 0 48px !important;
  padding: 0 !important;
  border: 0 !important;
}

variant-picker .lb-swatch-image-label .variant-option__button-label__text {
  display: none !important;
  visibility: hidden !important;
  opacity: 0 !important;
}

variant-picker .lb-swatch-image-label .variant-option__button-label__pill {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;

  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;

  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background-color: #fff !important;
  background-image: var(--lb-swatch-img) !important;
  background-size: 74% auto !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;

  overflow: hidden !important;
  box-shadow: none !important;
  transform: none !important;
  transition: box-shadow 0.15s ease, border-color 0.15s ease !important;
}

/* ---------- Text fallback swatches ---------- */

variant-picker .variant-option__button-label.lb-swatch-fallback {
  width: auto !important;
  height: 38px !important;
  min-width: 48px !important;
  max-width: none !important;
  flex: 0 0 auto !important;

  padding: 0 14px !important;
  border-radius: 999px !important;
  border: 1px solid #cfcfcf !important;
  background: #f5f5f5 !important;
}

variant-picker .lb-swatch-fallback .variant-option__button-label__pill {
  display: none !important;
}

variant-picker .lb-swatch-fallback .variant-option__button-label__text {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  visibility: visible !important;
  opacity: 1 !important;
  width: auto !important;
  height: auto !important;
  overflow: visible !important;

  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  color: #222 !important;
}

/* Remove theme overlays */
variant-picker .variant-option__button-label__pill::before,
variant-picker .variant-option__button-label__pill::after {
  display: none !important;
  content: none !important;
}

/* Hover */
variant-picker .lb-swatch-image-label:hover .variant-option__button-label__pill,
variant-picker .lb-swatch-fallback:hover {
  border-color: #0b75b7 !important;
}

/* Selected image swatch — no layout shift */
variant-picker .lb-swatch-image-label input:checked ~ .variant-option__button-label__pill {
  border-color: #cfcfcf !important;
  /* box-shadow: inset 0 0 0 3px #0b75b7 !important; */
}

/* Selected text fallback */
variant-picker .lb-swatch-fallback:has(input:checked) {
  border-color: #0b75b7 !important;
  box-shadow: inset 0 0 0 2px #0b75b7 !important;
}

/* Hide old text before JS finishes only for image-ready loaded state */
variant-picker.lb-swatches-loaded .lb-swatch-image-label .variant-option__button-label__text {
  display: none !important;
}
/* ===== Stable round swatches: image or text ===== */

variant-picker fieldset.variant-option {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 8px 0 18px !important;
  border: 0 !important;
}

variant-picker fieldset.variant-option legend {
  flex: 0 0 100% !important;
  width: 100% !important;
  margin: 0 0 8px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;
  flex: 0 0 48px !important;

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

  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  position: relative !important;
  overflow: visible !important;
  transform: none !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready input {
  position: absolute !important;
  inset: 0 !important;
  width: 48px !important;
  height: 48px !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 5 !important;
  margin: 0 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__pill {
  width: 48px !important;
  height: 48px !important;
  min-width: 48px !important;
  min-height: 48px !important;
  max-width: 48px !important;
  max-height: 48px !important;

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

  padding: 0 !important;
  margin: 0 !important;
  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background-color: #fff !important;
  background-image: var(--lb-swatch-img, none) !important;
  background-size: contain !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;

  overflow: hidden !important;
  box-sizing: border-box !important;
  box-shadow: none !important;
  transform: none !important;
  transition: box-shadow .15s ease, border-color .15s ease !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready .variant-option__button-label__text {
  display: none !important;
}

/* No image: show text inside the same round swatch */
variant-picker .variant-option__button-label.lb-swatch-fallback .variant-option__button-label__pill {
  background-image: none !important;
  background: #f5f5f5 !important;
}

variant-picker .variant-option__button-label.lb-swatch-fallback .variant-option__button-label__text {
  display: flex !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 2 !important;

  align-items: center !important;
  justify-content: center !important;

  width: 48px !important;
  height: 48px !important;
  padding: 5px !important;

  font-size: 9px !important;
  font-weight: 700 !important;
  line-height: 1.05 !important;
  text-align: center !important;
  color: #222 !important;

  overflow: hidden !important;
  white-space: normal !important;
  word-break: normal !important;
}

/* remove theme decoration */
variant-picker .variant-option__button-label__pill::before,
variant-picker .variant-option__button-label__pill::after {
  display: none !important;
  content: none !important;
}

/* selected without movement */
variant-picker .variant-option__button-label.lb-swatch-ready input:checked 
  ~ .variant-option__button-label__pill {
  border-color: #cfcfcf !important;
  box-shadow: inset 0 0 0 3px #0b75b7 !important;
}

variant-picker .variant-option__button-label.lb-swatch-ready:hover 
  .variant-option__button-label__pill {
  border-color: #0b75b7 !important;
}

/* ===== CLEAN SWATCH FIX ===== */

/* убираем ВСЕ рамки темы */
variant-picker .variant-option__button-label,
variant-picker .variant-option__button-label__pill {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* основной круг */
variant-picker .lb-swatch-ready .variant-option__button-label__pill {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;

  background: #fff !important;
  background-image: var(--lb-swatch-img, none) !important;
  background-size: contain !important;
  background-position: center !important;
  background-repeat: no-repeat !important;

  box-sizing: border-box !important;
}

/* ОДНА нормальная рамка */
variant-picker .lb-swatch-ready {
  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
}

/* hover */
variant-picker .lb-swatch-ready:hover {
  border-color: #0b75b7 !important;
}

/* выбранный вариант — один аккуратный outline */
variant-picker .lb-swatch-ready:has(input:checked) {
  border: 2px solid #0b75b7 !important;
}

/* убрать внутренние кольца */
variant-picker .lb-swatch-ready input:checked ~ * {
  box-shadow: none !important;
}

/* fallback (без картинки) */
variant-picker .lb-swatch-fallback .variant-option__button-label__pill {
  background: #f5f5f5 !important;
}

/* текст внутри круга */
variant-picker .lb-swatch-fallback .variant-option__button-label__text {
  position: absolute !important;
  inset: 0 !important;

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

  font-size: 9px !important;
  font-weight: 700 !important;
  text-align: center !important;
  padding: 6px !important;
}
/* 
/* отключаем рамки темы ТОЛЬКО для swatches */
variant-picker .lb-swatch-ready {
  --options-border-width: 0px !important;
  --variant-picker-button-border-width: 0px !important;
} */

/* обычные swatches */
variant-picker .lb-swatch-ready {
  --options-border-width: var(--variant-picker-button-border-width);
}

/* выбранный swatch */
variant-picker .lb-swatch-ready:has(input:checked) {
  --options-border-width: 0px !important;
  --variant-picker-button-border-width: 0px !important;

  border: 2px solid #0b75b7 !important;
  box-shadow: none !important;
}

/* sold out / unavailable swatches */
variant-picker .lb-swatch-ready input[data-option-available="false"] 
  ~ .variant-option__button-label__pill {
  opacity: 0.35 !important;
  filter: grayscale(1) !important;
}

variant-picker .lb-swatch-ready:has(input[data-option-available="false"]) {
  pointer-events: none !important;
  opacity: 0.55 !important;
}

/* diagonal line for unavailable */
variant-picker .lb-swatch-ready:has(input[data-option-available="false"])::after {
  content: "" !important;
  position: absolute !important;
  left: 8px !important;
  right: 8px !important;
  top: 50% !important;
  height: 1.5px !important;
  background: #999 !important;
  transform: rotate(-35deg) !important;
  z-index: 10 !important;
  pointer-events: none !important;
}

/* remove selected border completely */
variant-picker .lb-swatch-ready:has(input:checked) {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;

  --options-border-width: 0px !important;
  --variant-picker-button-border-width: 0px !important;
}

/* remove inner selected ring */
variant-picker .lb-swatch-ready input:checked 
  ~ .variant-option__button-label__pill {
  border: none !important;
  box-shadow: none !important;
  outline: none !important;
}

/* prevent theme selected styles */
variant-picker .variant-option__button-label:has(input:checked),
variant-picker .variant-option__button-label input:checked,
variant-picker .variant-option__button-label input:checked ~ * {
  box-shadow: none !important;
  outline: none !important;
}

/* unavailable variants */
variant-picker .lb-swatch-ready:has(input[data-option-available="false"]) {
  opacity: 0.55 !important;
  position: relative !important;
}

/* diagonal strike line */
variant-picker .lb-swatch-ready:has(input[data-option-available="false"])::after {
  content: "" !important;

  position: absolute !important;
  top: 50% !important;
  left: 6px !important;
  right: 6px !important;

  height: 1.5px !important;
  background: #666 !important;

  transform: rotate(-35deg) !important;
  transform-origin: center !important;

  z-index: 20 !important;
  pointer-events: none !important;
}

/* image unavailable */
variant-picker .lb-swatch-ready:has(input[data-option-available="false"]) 
.variant-option__button-label__pill {
  filter: grayscale(1) !important;
}

/* text unavailable */
variant-picker .lb-swatch-ready:has(input[data-option-available="false"]) 
.variant-option__button-label__text {
  color: #777 !important;
}

/* unavailable swatches */
variant-picker .lb-swatch-unavailable {
  opacity: 0.45 !important;
  position: relative !important;
}

variant-picker .lb-swatch-unavailable::after {
  content: "" !important;
  position: absolute !important;
  left: 4px !important;
  right: 4px !important;
  top: 50% !important;
  height: 2px !important;
  background: #777 !important;
  transform: rotate(-35deg) !important;
  z-index: 30 !important;
  pointer-events: none !important;
}

variant-picker .lb-swatch-unavailable .variant-option__button-label__pill {
  filter: grayscale(1) !important;
}

variant-picker .lb-swatch-unavailable .variant-option__button-label__text {
  color: #777 !important;
}

/* unavailable swatches - visible but still clickable */
variant-picker .lb-swatch-unavailable {
  position: relative !important;
  opacity: 0.55 !important;
  pointer-events: auto !important;
}

variant-picker .lb-swatch-unavailable input {
  pointer-events: auto !important;
  cursor: pointer !important;
}

variant-picker .lb-swatch-soldout-line {
  position: absolute !important;
  left: 4px !important;
  right: 4px !important;
  top: 50% !important;
  height: 2px !important;
  background: #555 !important;
  transform: rotate(-35deg) !important;
  z-index: 20 !important;
  pointer-events: none !important;
  display: block !important;
}

variant-picker .lb-swatch-unavailable .variant-option__button-label__pill {
  filter: grayscale(1) !important;
}

variant-picker .lb-swatch-unavailable .variant-option__button-label__text {
  color: #777 !important;
}

/* sold out swatches */
variant-picker .lb-swatch-unavailable {
  position: relative !important;

  opacity: 1 !important;

  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background: #f2f2f2 !important;

  overflow: hidden !important;
}

/* same background for inner circle */
variant-picker .lb-swatch-unavailable .variant-option__button-label__pill {
  background-color: #f2f2f2 !important;
  filter: grayscale(1) brightness(0.96) !important;
}

/* sold out slash */
variant-picker .lb-swatch-unavailable .lb-swatch-soldout-line {
  position: absolute !important;

  left: 6px !important;
  right: 6px !important;
  top: 50% !important;

  height: 1.5px !important;
  background: #777 !important;

  transform: rotate(-35deg) !important;

  z-index: 20 !important;
  pointer-events: none !important;
}

/* sold out text */
variant-picker .lb-swatch-unavailable .variant-option__button-label__text {
  color: #666 !important;
}

/* SOLD OUT fallback/text swatches */
variant-picker label.variant-option__button-label.lb-swatch-ready.lb-swatch-unavailable,
variant-picker label.variant-option__button-label.lb-swatch-fallback.lb-swatch-unavailable {
  opacity: 1 !important;
  background: #f2f2f2 !important;
  border: 1px solid #cfcfcf !important;
  border-radius: 50% !important;
  box-shadow: none !important;
  overflow: hidden !important;
}

/* text inside sold out */
variant-picker label.lb-swatch-unavailable .variant-option__button-label__text {
  color: #777 !important;
  opacity: 1 !important;
}

/* sold out line */
variant-picker label.lb-swatch-unavailable .lb-swatch-soldout-line {
  display: block !important;
  position: absolute !important;
  left: 5px !important;
  right: 5px !important;
  top: 50% !important;
  height: 2px !important;
  background: #777 !important;
  transform: rotate(-35deg) !important;
  z-index: 999 !important;
  pointer-events: none !important;
}

/* keep clickable */
variant-picker label.lb-swatch-unavailable input {
  pointer-events: auto !important;
  cursor: pointer !important;
}

/* selected unavailable swatch */
variant-picker label.lb-swatch-unavailable:has(input:checked) {
  border: 2px solid #0b75b7 !important;
  background: #f2f2f2 !important;
  opacity: 1 !important;
}

/* inner selected ring */
variant-picker label.lb-swatch-unavailable:has(input:checked)::before {
  content: "" !important;

  position: absolute !important;
  inset: 3px !important;

  border: 1px solid #0b75b7 !important;
  border-radius: 50% !important;

  z-index: 5 !important;
  pointer-events: none !important;
}

/* Product grid swatches */
.product-card .variant-option--swatches,
.product-card fieldset.variant-option--swatches {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-top: 8px !important;
}

.product-card .variant-option__swatch {
  list-style: none !important;
}

.product-card .variant-option__button-label--has-swatch {
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.product-card .variant-option__button-label--has-swatch .swatch {
  width: 28px !important;
  height: 28px !important;
  display: block !important;
  border-radius: 50% !important;
  border: 1px solid #cfcfcf !important;
  background-color: #fff !important;
  background-size: contain !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  overflow: hidden !important;
}

.product-card .variant-option__button-label--has-swatch:hover .swatch {
  border-color: #0b75b7 !important;
}

.product-card .swatch--text-fallback {
  font-size: 7px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  text-align: center !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 3px !important;
}

@media screen and (min-width: 990px) {
  dialog[open].zoom-dialog,
  dialog[open] zoom-dialog {
    display: block !important;
  }

  dialog[open] .product-media-container {
    width: fit-content !important;
    max-width: 90vw !important;
    max-height: 88vh !important;
    margin: 0 auto !important;
  }

  dialog[open] .product-media-container img {
    width: auto !important;
    height: auto !important;
    max-width: 90vw !important;
    max-height: 88vh !important;
    object-fit: contain !important;
  }
}

@media screen and (max-width: 749px) {
  .sticky-add-to-cart__bar {
    display: none !important;
  }
}

.header__submenu,
.mega-menu__content {
  margin-top: 0 !important;
}

details[open] > .header__submenu::before,
details[open] > .mega-menu__content::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -18px;
  height: 18px;
}

.header__inline-menu details {
  position: relative;
}

.header__submenu,
.mega-menu__content {
  pointer-events: auto;
}


.header__submenu {
  margin-top: 0 !important;
}

.header__submenu::before {
  content: "";
  position: absolute;
  top: -16px;
  left: 0;
  right: 0;
  height: 16px;
}

.header__inline-menu details,
.header__inline-menu .menu-drawer__menu-item,
.header__inline-menu li {
  position: relative;
}

.header__inline-menu details::after {
  content: "";
  position: absolute;
  left: -20px;
  right: -20px;
  top: 100%;
  height: 40px;
  z-index: 3;
}

.header__submenu,
.mega-menu__content {
  z-index: 4;
}
.header__inline-menu details::after {
  left: -80px;
  right: -80px;
}

.header__inline-menu details::after {
  content: "";
  position: absolute;
  left: -120px;
  right: -120px;
  top: 100%;
  height: 120px;
  z-index: 3;
}
.menu-list__submenu-inner {
  transform: translateY(-12px) !important;
  z-index: 999 !important;
}
.menu-list__link a {
  padding-bottom: 0px;
}