/** Shopify CDN: Minification failed

Line 4459:0 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%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.card-gallery {
  position: relative;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  animation-duration: 0.6s;
}

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

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

  animation-duration: 0.8s;
}

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

  5% {
    opacity: 1;
  }

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

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

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

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

  50% {
    opacity: 1;
  }

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

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













.hero-title, .hero-subtitle {
  color: #fff;
  animation: neonGlow 4s ease-in-out infinite;
}

@keyframes neonGlow {
  0% {
    text-shadow:
      0 0 5px #ffffff,
      0 0 10px #c084fc,
      0 0 20px #a855f7;
  }
  50% {
    text-shadow:
      0 0 15px #ffffff,
      0 0 25px #c084fc,
      0 0 40px #7e22ce;
  }
  100% {
    text-shadow:
      0 0 5px #ffffff,
      0 0 10px #c084fc,
      0 0 20px #a855f7;
  }
}
.hero-subtitle {
  margin-bottom: 40px; /* adds space for the button */
}

.hero-button {
  display: inline-block;
  position: relative;
  z-index: 10;
}
.hero-overlay {
  position: relative;
  z-index: 5;
  min-height: 380px;
  padding: 80px 16px 120px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

/* Big glowing title */
.hero-title {
  font-size: clamp(32px, 6vw, 64px);
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 16px;
  animation: neonGlow 4s ease-in-out infinite;
}

/* Subtitle under it */
.hero-subtitle {
  color: #f5f3ff;
  font-size: 16px;
  max-width: 480px;
  margin: 0 auto 32px;
  text-shadow:
    0 0 8px #c084fc,
    0 0 18px #a855f7,
    0 0 30px #7e22ce;
}

/* Shop Now button */
.hero-button {
  display: inline-block;
  padding: 12px 32px;
  border-radius: 999px;
  background: #ffffff;
  color: #000000;
  font-weight: 600;
  text-decoration: none;
  position: relative;
  z-index: 10;
  box-shadow:
    0 0 10px rgba(192, 132, 252, 0.8),
    0 0 24px rgba(168, 85, 247, 0.7);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.hero-button:hover {
  transform: scale(1.08) translateY(-2px);
  box-shadow:
    0 0 16px rgba(192, 132, 252, 1),
    0 0 32px rgba(168, 85, 247, 0.9),
    0 0 50px rgba(126, 34, 206, 0.6);
}
.hero-button {
  transition: all 0.25s ease;
}


/* Glow animation for title */
@keyframes neonGlow {
  0% {
    text-shadow:
      0 0 5px #ffffff,
      0 0 10px #c084fc,
      0 0 20px #a855f7;
  }
  50% {
    text-shadow:
      0 0 15px #ffffff,
      0 0 25px #c084fc,
      0 0 40px #7e22ce;
  }
  100% {
    text-shadow:
      0 0 5px #ffffff,
      0 0 10px #c084fc,
      0 0 20px #a855f7;
  }
}











/* === All Collection grid === */
.er-collections-wrapper {
  padding: 60px 16px 80px;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
}

.er-collections-heading {
  font-size: clamp(28px, 4vw, 40px);
  color: #ffffff;
  margin-bottom: 8px;
}

.er-collections-subheading {
  color: #cbd5f5;
  margin-bottom: 32px;
  font-size: 14px;
}

.er-collections-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}

/* 2 per row on tablet */
@media (max-width: 900px) {
  .er-collections-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 1 per row on phone */
@media (max-width: 600px) {
  .er-collections-grid {
    grid-template-columns: 1fr;
  }
}


/* Card */
.er-collection-card {
  position: relative;
  background: radial-gradient(circle at top, #261439 0, #05010a 60%);
  border-radius: 22px;
  overflow: hidden;
  text-decoration: none;
  border: 1px solid rgba(192, 132, 252, 0.28);
  box-shadow:
    0 12px 28px rgba(0, 0, 0, 0.95);
  transform: translateY(0) scale(1);
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

/* soft glow layer on hover */
.er-collection-card::before {
  content: "";
  position: absolute;
  inset: -40%;
  background: radial-gradient(circle at top,
    rgba(168, 85, 247, 0.35),
    transparent 60%);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}


.er-collection-image {
  width: 100%;
  padding-top: 100%; /* bigger image */
  background-size: cover;
  background-position: center;
}

.er-collection-info {
  padding: 20px 22px 28px; /* more space */
}


.er-collection-info h2 {
  color: #ffffff;
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.02em;
  margin: 0 0 6px;
}

.er-collection-info p {
  color: #cbd5f5;
  font-size: 13px;
  opacity: 0.9;
  margin: 0;
}


.er-collection-info p {
  color: #cbd5f5;
  font-size: 13px;
  margin: 0;
}

/* Hover animation */
.er-collection-card:hover {
  transform: translateY(-8px) scale(1.04);
  border-color: rgba(192, 132, 252, 0.9);
  box-shadow:
    0 0 18px rgba(192, 132, 252, 0.85),
    0 0 40px rgba(126, 34, 206, 0.7);
}

.er-collection-card:hover::before {
  opacity: 1;
}











.er-collections-heading {
  font-size: clamp(34px, 5vw, 46px);
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  margin-bottom: 12px;

  /* soft neon glow */
  text-shadow:
    0 0 8px rgba(255,255,255,0.8),
    0 0 16px rgba(192,132,252, 0.8),
    0 0 32px rgba(168,85,247,0.7);
}

.er-collections-subheading {
  font-size: 15px;
  color: #dcdcff;
  opacity: 0.9;
  text-align: center;
  margin-bottom: 40px;
}


/* ==== EliteReps FAQ Section (details version) ==== */

.er-faq {
  max-width: 900px;
  margin: 60px auto 40px;
  padding: 0 16px;
}

.er-faq-heading {
  text-align: center;
  font-size: clamp(26px, 4vw, 34px);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 6px;
  text-shadow:
    0 0 6px rgba(255, 255, 255, 0.9),
    0 0 14px rgba(192, 132, 252, 0.9);
}

.er-faq-subheading {
  text-align: center;
  font-size: 14px;
  color: #d0d4ff;
  opacity: 0.9;
  margin-bottom: 24px;
}

.er-faq-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* FAQ item */
.er-faq-item {
  border-radius: 16px;
  background: radial-gradient(circle at top left, #241236, #050109 60%);
  border: 1px solid rgba(192,132,252,0.3);
  padding: 0;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(0,0,0,0.9);
}

/* remove default triangle */
.er-faq-item summary {
  list-style: none;
}

.er-faq-item summary::-webkit-details-marker {
  display: none;
}

/* question row */
.er-faq-item summary {
  cursor: pointer;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 15px;
  font-weight: 500;
  color: #ffffff;
  transition:
    background 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease;
  position: relative;
}

/* plus icon */
.er-faq-item summary::after {
  content: "+";
  font-size: 20px;
  line-height: 1;
  color: #ffffff;
  transition: transform 0.25s ease, color 0.25s ease;
}

/* answer area */
.er-faq-answer {
  padding: 0 18px 16px;
  border-top: 1px solid rgba(192,132,252,0.25);
}

.er-faq-answer p {
  margin: 10px 0 0;
  color: #dcdfff;
  font-size: 14px;
  line-height: 1.6;
}

/* open state */
.er-faq-item[open] summary {
  background: radial-gradient(circle at top, #3b1c5c, #050109 60%);
  box-shadow:
    0 0 14px rgba(192,132,252,0.9),
    0 0 28px rgba(126,34,206,0.7);
}

.er-faq-item[open] summary::after {
  transform: rotate(45deg); /* + becomes x */
  color: #fbbf24;
}











<div class="er-faq">
  <h2 class="er-faq-heading">Frequently Asked Questions</h2>
  <p class="er-faq-subheading">Your top questions answered.</p>

  <div class="er-faq-list">

    <!-- Q1 -->
    <button class="er-faq-item">
      <span class="er-faq-question">What is your return policy?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        We offer returns within <strong>7 days</strong> of delivery. Items must be unused, unworn, and in their original packaging. 
        We provide <strong>store credit</strong> after your return is inspected. Items that are worn, damaged, or missing parts 
        may not be approved. This gives you flexibility to shop again while keeping our prices affordable.
      </p>
    </div>

    <!-- Q2 -->
    <button class="er-faq-item">
      <span class="er-faq-question">Are any purchases final sale?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        Yes. Items marked as <strong>final sale, clearance, or heavily discounted</strong> cannot be returned or exchanged. 
        These products are offered at special low pricing, which means they are not eligible for refunds or credits.
      </p>
    </div>

    <!-- Q3 -->
    <button class="er-faq-item">
      <span class="er-faq-question">When will I get my order?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        Orders typically take <strong>1–3 days</strong> to process. Shipping takes <strong>5–10 days</strong> within Canada/USA 
        and <strong>7–15 days</strong> internationally. During busy seasons, shipping times may vary. You will receive a tracking 
        number once your order ships so you can follow it step-by-step.
      </p>
    </div>

    <!-- Q4 -->
    <button class="er-faq-item">
      <span class="er-faq-question">Where are your products manufactured?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        Our products are sourced from <strong>reliable global manufacturers</strong> who specialize in premium fashion and tech accessories. 
        Every item is checked for quality before being shipped to ensure you get the best value possible. 
      </p>
    </div>

    <!-- Q5 -->
    <button class="er-faq-item">
      <span class="er-faq-question">How much does shipping cost?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        Shipping fees are automatically calculated at checkout based on your location and order weight. 
        We also offer <strong>free shipping</strong> on select products and promotional deals throughout the year to help you save more.
      </p>
    </div>

    <!-- Q6 -->
    <button class="er-faq-item">
      <span class="er-faq-question">Can I cancel or change my order?</span>
      <span class="er-faq-icon">+</span>
    </button>
    <div class="er-faq-answer">
      <p>
        You can cancel or update your order within <strong>12 hours</strong> after placing it. After that, your order may already be 
        processing or shipped. If you need urgent changes, contact us and we will do our best to help.
      </p>
    </div>

  </div>
</div>







/* ===== FAQ Contact Block ===== */

.er-faq-contact {
  margin-top: 50px;
  text-align: center;
  padding: 40px 20px;
  background: radial-gradient(circle at center, #2a1742, #05010a 70%);
  border-radius: 22px;
  border: 1px solid rgba(192,132,252,0.35);
  box-shadow:
    0 0 18px rgba(192,132,252,0.25),
    0 12px 40px rgba(0,0,0,0.8);
  animation: er-faq-fade-in 0.7s ease-out forwards;
}

.er-faq-contact-title {
  font-size: clamp(24px, 4vw, 30px);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 10px;
  text-shadow:
    0 0 6px rgba(255,255,255,0.8),
    0 0 14px rgba(192,132,252,0.65);
}

.er-faq-contact-text {
  max-width: 600px;
  margin: 0 auto 24px;
  font-size: 15px;
  color: #ddd6ff;
  line-height: 1.6;
}

.er-faq-contact-btn {
  display: inline-block;
  padding: 12px 32px;
  font-size: 15px;
  color: #000000;
  background: #ffffff;
  border-radius: 999px;
  font-weight: 600;
  text-decoration: none;
  transition: all 0.22s ease;
  box-shadow:
    0 0 12px rgba(192,132,252,0.8),
    0 0 30px rgba(168,85,247,0.6);
}

.er-faq-contact-btn:hover {
  transform: scale(1.07) translateY(-2px);
  box-shadow:
    0 0 20px rgba(192,132,252,1),
    0 0 40px rgba(168,85,247,0.9);
}

/* ===== EliteReps Contact Section ===== */

.er-contact-box {
  max-width: 650px;
  margin: 40px auto;
  padding: 20px 25px;
  text-align: center;
  background: radial-gradient(circle at center, #2a1742, #050109 70%);
  border: 1px solid rgba(192,132,252,0.35);
  border-radius: 20px;
  box-shadow:
    0 0 18px rgba(192,132,252,0.25),
    0 12px 40px rgba(0,0,0,0.8);
}

.er-contact-heading {
  font-size: clamp(28px, 5vw, 36px);
  font-weight: 700;
  color: #ffffff;
  margin-bottom: 15px;
  text-shadow:
    0 0 6px rgba(255,255,255,0.9),
    0 0 14px rgba(192,132,252,0.8);
}

.er-contact-text {
  font-size: 16px;
  color: #e0e0ff;
  line-height: 1.6;
  margin-bottom: 18px;
}

.er-contact-item {
  font-size: 17px;
  color: #ffffff;
  margin: 10px 0;
}

.er-contact-item a {
  color: #c084fc;
  text-decoration: underline;
  transition: 0.2s;
}

.er-contact-item a:hover {
  color: #ffffff;
  text-shadow: 0 0 10px #c084fc;
}



/* ===== GLASS NEON CONTACT CARD ===== */

.er-contact-glass {
  max-width: 650px;
  margin: 60px auto;
  padding: 35px 28px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(192,132,252,0.35);
  border-radius: 24px;
  backdrop-filter: blur(12px);
  box-shadow: 
    0 0 25px rgba(168,85,247,0.3),
    0 0 60px rgba(0,0,0,0.9);
  animation: fadeUp 0.7s ease-out;
}

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

.er-contact-glass-title {
  font-size: clamp(30px, 6vw, 38px);
  font-weight: 700;
  text-align: center;
  color: #ffffff;
  margin-bottom: 10px;
  text-shadow: 
    0 0 10px rgba(192,132,252,0.9),
    0 0 25px rgba(126,34,206,0.8);
}

.er-contact-glass-sub {
  text-align: center;
  color: #dcdcff;
  font-size: 15px;
  max-width: 520px;
  margin: 0 auto 22px;
  line-height: 1.6;
}

.er-contact-glass-info {
  text-align: center;
  font-size: 16px;
  color: #fff;
  margin-bottom: 20px;
}

.er-contact-glass-info a {
  color: #c084fc;
  text-decoration: underline;
}

.er-contact-glass-line {
  width: 80%;
  height: 1px;
  background: rgba(192,132,252,0.3);
  margin: 20px auto 25px;
}

.er-contact-glass-form {
  margin-top: 10px;
}

.er-field {
  margin-bottom: 18px;
}

.er-field label {
  display: block;
  color: #e0e0ff;
  font-size: 14px;
  margin-bottom: 6px;
}

.er-field input,
.er-field textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid rgba(192,132,252,0.4);
  background: rgba(0,0,0,0.5);
  color: #fff;
  font-size: 15px;
  outline: none;
  transition: 0.2s;
}

.er-field input:focus,
.er-field textarea:focus {
  border-color: rgba(192,132,252,1);
  box-shadow: 0 0 15px rgba(168,85,247,0.7);
}

.er-glass-btn {
  width: 100%;
  padding: 12px 0;
  font-size: 16px;
  font-weight: 600;
  border-radius: 999px;
  background: #ffffff;
  color: #000000;
  border: none;
  cursor: pointer;
  transition: 0.25s;
  box-shadow: 
    0 0 15px rgba(192,132,252,0.8),
    0 0 35px rgba(168,85,247,0.7);
}

.er-glass-btn:hover {
  transform: scale(1.04);
  box-shadow:
    0 0 20px rgba(192,132,252,1),
    0 0 45px rgba(168,85,247,1);
}

.er-contact-success {
  padding: 10px;
  background: rgba(22,163,74,0.25);
  border: 1px solid rgba(22,163,74,0.7);
  border-radius: 10px;
  color: #bbf7d0;
  margin-bottom: 15px;
  text-align: center;
}
























    







































/* ===========================
   ELITEREPS – HEADER CSS (UPDATED)
=========================== */

body {
  background: #000;
}

/* Hide original theme header */
.shopify-section-header .header,
.header-wrapper .header {
  display: none !important;
}

/* Bubble Header Container */
.elite-bubble-header {
  position: fixed;
  top: 16px; /* slightly smaller */
  left: 50%;
  transform: translateX(-50%);
  width: 94%;
  max-width: 1180px;
  z-index: 100;
}

.elite-bubble-header__inner {
  width: 100%;
  padding: 8px 26px; /* reduced height */
  border-radius: 999px;

  background:
    radial-gradient(circle at top left, rgba(164, 107, 255, 0.32), transparent 60%),
    #050013;

  border: 1px solid rgba(190, 140, 255, 0.7);

  box-shadow:
    0 0 14px rgba(164, 107, 255, 0.55),
    0 0 28px rgba(41, 15, 70, 0.85);

  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;

  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    padding 0.25s ease;
}

/* Smaller on scroll */




/* ===========================
   SCROLL STATE (CLEAN + SMOOTH)
=========================== */

.elite-bubble-header__inner--scrolled {
  padding: 6px 22px; /* slightly smaller */
  
  /* tiny shrink + lift */
  transform: translateY(-4px) scale(0.955);

  /* softer glow when scrolled */
  box-shadow:
    0 0 10px rgba(164, 107, 255, 0.45),
    0 0 22px rgba(41, 15, 70, 0.85);

  border-color: rgba(185, 130, 255, 0.55);

  /* smooth animation */
  transition:
    padding 0.25s ease,
    transform 0.28s ease,
    box-shadow 0.28s ease,
    border-color 0.25s ease;
}
/* Slight tighten when scrolled */
.elite-bubble-header__inner--scrolled .elite-bubble-header__nav a {
  opacity: 0.9;
  letter-spacing: 0.015em;
}

.elite-bubble-header__inner--scrolled .elite-bubble-header__icon {
  transform: translateY(-1px);
}


.elite-bubble-header__inner--scrolled:hover {
  transform: translateY(-4px) scale(1.02); /* a bit bigger when scrolled */
}


.elite-bubble-header__inner:hover {
  box-shadow:
    0 0 18px rgba(176, 126, 255, 0.85),
    0 0 36px rgba(90, 0, 150, 0.85);
  transform: scale(1.05); /* 🔥 makes bubble bigger on hover */
}

/* ===========================
   LOGO
=========================== */

.elite-bubble-header__logo-text {
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  text-decoration: none;

  text-shadow:
    0 0 8px rgba(255, 255, 255, 1),
    0 0 20px rgba(180, 125, 255, 1);

  transition: transform 0.25s ease, text-shadow 0.25s ease;
}

.elite-bubble-header__logo-text:hover {
  transform: translateY(-2px);
  text-shadow:
    0 0 10px rgba(255, 255, 255, 1),
    0 0 28px rgba(195, 150, 255, 1);
}

/* ===========================
   CENTER NAVIGATION
=========================== */

.elite-bubble-header__nav {
  display: flex;
  align-items: center;
  gap: 1.9rem;
  justify-content: center;
  flex: 1;
}

.elite-bubble-header__nav a {
  font-size: 1rem;
  font-weight: 400;
  color: #eae2ff;
  text-decoration: none;
  position: relative;
  transition: 0.2s ease;
  padding-bottom: 3px;
}

.elite-bubble-header__nav a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0%;
  height: 2px;
  background: linear-gradient(90deg, #c77dff, #7b2cff);
  border-radius: 10px;
  transition: width 0.25s ease;
}

.elite-bubble-header__nav a:hover {
  color: #fff;
  transform: translateY(-1px);
}

.elite-bubble-header__nav a:hover::after {
  width: 100%;
}

/* ===========================
   RIGHT ICONS (reduced glow)
=========================== */

.elite-bubble-header__right {
  display: flex;
  align-items: center;
  gap: 1.1rem;
}

.elite-bubble-header__icon {
  font-size: 1.65rem;
  color: #ffffff;
  text-decoration: none;

  text-shadow:
    0 0 6px rgba(180, 150, 255, 0.7),
    0 0 12px rgba(140, 90, 255, 0.7);

  transition:
    transform 0.25s ease,
    text-shadow 0.25s ease;
}

/* reduced shine */
.elite-bubble-header__icon:hover {
  transform: translateY(-2px);
  text-shadow:
    0 0 10px rgba(255, 255, 255, 0.9),
    0 0 18px rgba(180, 120, 255, 0.85);
}

.elite-bubble-header__icon:active {
  transform: translateY(-1px) scale(0.96);
}

/* Mobile adjustments */
@media (max-width: 780px) {
  .elite-bubble-header__inner {
    flex-direction: column;
    padding: 14px 20px;
    gap: 10px;
  }

  .elite-bubble-header__right {
    align-self: flex-end;
  }

  .elite-bubble-header__nav {
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
  }
}




/* GLOBAL BACKGROUND FIX — do NOT touch section spacing */
body {
  background-color: #000000 !important;
}

/* Keep all homepage sections transparent */
.shopify-section {
  background: transparent !important;
}

/* Fix weird white blocks inside some sections */
.page-width,
.content-container {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}








/* === Need More Help – buttons === */
.er-help-actions {
  display: flex;
  justify-content: center;
  gap: 18px;
  margin-top: 28px;
}

/* Base button style (both buttons) */
.er-help-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;           /* 🔥 longer buttons */
  padding: 10px 32px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.02em;
  border: none;
  outline: none;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    color 0.18s ease,
    border-color 0.18s ease;
}

/* Primary = white pill like your other button */
.er-help-btn--primary {
  background: #ffffff;
  color: #050009;
  box-shadow:
    0 0 10px rgba(203, 170, 255, 0.9),
    0 0 26px rgba(121, 40, 255, 0.7);
}

.er-help-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 0 16px rgba(203, 170, 255, 1),
    0 0 34px rgba(121, 40, 255, 0.9);
}

/* Secondary = outlined/glass button */
.er-help-btn--secondary {
  background: rgba(255, 255, 255, 0.02);
  color: #f6e8ff;
  border: 1px solid rgba(203, 170, 255, 0.9);
  box-shadow:
    0 0 10px rgba(87, 27, 196, 0.45);
}

.er-help-btn--secondary:hover {
  transform: translateY(-2px);
  background: rgba(203, 170, 255, 0.18);
  box-shadow:
    0 0 16px rgba(203, 170, 255, 0.9),
    0 0 30px rgba(87, 27, 196, 0.85);
}









/* ===========================
   ELITE REPS – HELP CALLOUT
   =========================== */

.er-help-section {
  padding: 32px 14px 60px;
  display: flex;
  justify-content: center;
}

/* MAIN CARD */
.er-help-box {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 52px 36px;
  border-radius: 26px;

  background:
    radial-gradient(circle at top, #2a1248 0, #070012 55%);
  border: 1px solid rgba(177, 119, 255, 0.6);

  box-shadow:
    0 0 30px rgba(160, 90, 255, 0.4),
    0 20px 40px rgba(0, 0, 0, 0.85);

  position: relative;
  overflow: hidden;
  text-align: center;
  color: #ffffff;
  opacity: 0;
  transform: translateY(14px);
  animation: er-help-fade-in 0.7s ease-out forwards;
}

/* outer mist / glow */
.er-help-box::before {
  content: "";
  position: absolute;
  inset: -40%;
  background:
    radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.12), transparent 55%),
    radial-gradient(circle at 80% 10%, rgba(171, 119, 255, 0.22), transparent 60%);
  opacity: 0.7;
  pointer-events: none;
}

/* small halo under card */
.er-help-box::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -32px;
  width: 120%;
  height: 70px;
  transform: translateX(-50%);
  background: radial-gradient(ellipse at center,
    rgba(180, 120, 255, 0.55),
    transparent 70%);
  opacity: 0.75;
}

/* NEED SUPPORT TAG */
.er-help-top-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 18px;
  border-radius: 999px;
  background: rgba(26, 10, 46, 0.85);
  border: 1px solid rgba(196, 144, 255, 0.8);
  box-shadow: 0 0 18px rgba(190, 140, 255, 0.7);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #f6eaff;
  margin: -8px auto 10px;  /* pulls up a bit */
}

.er-help-top-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: radial-gradient(circle at 30% 30%, #ffffff, #a5f3ff 55%, #0ea5e9);
  box-shadow:
    0 0 10px rgba(56, 189, 248, 1),
    0 0 20px rgba(56, 189, 248, 0.6);
}

/* TITLE */
.er-help-title {
  margin-top: -4px;               /* moves the heading a bit UP */
  margin-bottom: 10px;
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff;
  text-shadow:
    0 0 10px rgba(255, 255, 255, 0.9),
    0 0 25px rgba(193, 144, 255, 0.9),
    0 0 40px rgba(153, 92, 255, 0.9);
  animation: er-help-title-glow 2.6s ease-in-out infinite alternate;
}

/* BODY TEXT */
.er-help-text {
  margin-top: -2px;              /* pulls paragraph UP */
  margin-bottom: 28px;
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
  font-size: 14px;
  line-height: 1.6;
  color: #e3ddff;
  opacity: 0.94;
}

/* BUTTON WRAPPER */
.er-help-buttons {
  display: flex;
  justify-content: center;
  gap: 18px;
  margin-top: 4px;
}

/* PRIMARY BUTTON – WHITE (matches product style) */
.er-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 40px;
  border-radius: 999px;
  background: #ffffff;
  color: #000000;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid #ffffffcc;
  box-shadow:
    0 0 12px rgba(255, 255, 255, 0.6),
    0 0 26px rgba(190, 140, 255, 0.7);
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    color 0.18s ease;
}

.er-btn-primary:hover {
  background: #f2f2f2;
  transform: translateY(-2px);
  box-shadow:
    0 0 18px rgba(255, 255, 255, 0.9),
    0 0 35px rgba(190, 140, 255, 0.9);
}

/* SECONDARY BUTTON – OUTLINE */
.er-btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 40px;
  border-radius: 999px;
  border: 2px solid rgba(185, 133, 255, 0.9);
  color: #e9ddff;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  background: transparent;
  box-shadow: 0 0 16px rgba(153, 92, 255, 0.4);
  transition:
    background 0.18s ease,
    color 0.18s ease,
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.er-btn-secondary:hover {
  background: rgba(169, 118, 255, 0.18);
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 0 24px rgba(169, 118, 255, 0.8);
}

/* ANIMATIONS */
@keyframes er-help-fade-in {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes er-help-title-glow {
  from {
    text-shadow:
      0 0 6px rgba(255, 255, 255, 0.9),
      0 0 16px rgba(193, 144, 255, 0.7),
      0 0 26px rgba(153, 92, 255, 0.7);
  }
  to {
    text-shadow:
      0 0 10px rgba(255, 255, 255, 1),
      0 0 28px rgba(193, 144, 255, 0.95),
      0 0 42px rgba(153, 92, 255, 0.95);
  }
}

/* MOBILE */
@media (max-width: 768px) {
  .er-help-box {
    padding: 30px 18px 30px;
    border-radius: 22px;
  }

  .er-help-title {
    font-size: 28px;
  }

  .er-help-text {
    font-size: 13px;
  }

  .er-help-buttons {
    flex-direction: column;
    gap: 10px;
  }

  .er-btn-primary,
  .er-btn-secondary {
    width: 100%;
  }
}






















/* === ELITEREPS FIX: PRODUCT TITLE + PRICE NEON STYLE === */

/* Big neon product heading */
.product__info-wrapper .product__title {
  display: inline-block;
  position: relative;
  font-size: 2.3rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  margin-bottom: 10px;

  color: #ffffff !important;
  text-shadow:
    0 0 10px rgba(199, 125, 255, 0.9),
    0 0 28px rgba(124, 44, 255, 0.9);

  animation: eliterepsTitleIntro2 0.7s ease-out both;
}

/* Neon underline under heading */
.product__info-wrapper .product__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #ffffff, #c77dff, #7b2cff);
  box-shadow:
    0 0 12px rgba(199, 125, 255, 1),
    0 0 26px rgba(124, 44, 255, 1);
  border-radius: 999px;
}

/* Price – neon + small hover pulse */
.product__info-wrapper .price {
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 700;
  color: #f8e9ff !important;
  text-shadow:
    0 0 12px rgba(199, 125, 255, 0.9),
    0 0 22px rgba(124, 44, 255, 0.8);
  margin: 6px 0 12px;
  transition: transform 0.18s ease, text-shadow 0.18s ease;
}

.product__info-wrapper .price:hover {
  transform: scale(1.03);
  text-shadow:
    0 0 18px rgba(199, 125, 255, 1),
    0 0 32px rgba(124, 44, 255, 1);
}

/* Intro animation for heading */
@keyframes eliterepsTitleIntro2 {
  0% {
    opacity: 0;
    transform: translateY(8px);
    letter-spacing: 0.25em;
    filter: blur(2px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    letter-spacing: 0.10em;
    filter: blur(0);
  }
}

































/* Layout width */
.product {
  max-width: 1200px;
  margin: 0 auto;
  padding: 32px 16px 64px;
}

/* Make image + info align nicely */
.product__media-wrapper,
.product__info-wrapper {
  align-self: flex-start;
}

/* Right side info card (glass neon) */
.product__info-wrapper {
  background: radial-gradient(circle at top left, rgba(124, 44, 255, 0.35), rgba(5, 0, 20, 0.98));
  border-radius: 24px;
  padding: 24px 22px;
  border: 1px solid rgba(199, 125, 255, 0.75);
  backdrop-filter: blur(18px);
  box-shadow:
    0 0 25px rgba(199, 125, 255, 0.9),
    0 0 80px rgba(124, 44, 255, 0.9);
}

/* === PRODUCT TITLE – NEON GRADIENT + ANIMATION === */

.product__title {
  display: inline-block;
  position: relative;
  font-size: clamp(2.1rem, 3.2vw, 2.9rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-bottom: 10px;

  background: linear-gradient(120deg, #ffffff, #f3e6ff, #c77dff, #7b2cff, #ffffff);
  background-size: 260% 260%;
  -webkit-background-clip: text;
  color: transparent;

  animation:
    eliterepsTitleIntro 0.8s ease-out forwards,
    eliterepsTitleGlow 3s ease-in-out 0.8s infinite alternate;
}

/* Animated underline under title */
.product__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -8px;
  height: 2px;
  width: 0;
  background: radial-gradient(circle, #ffffff, #c77dff, #7b2cff);
  box-shadow:
    0 0 10px rgba(199, 125, 255, 1),
    0 0 22px rgba(124, 44, 255, 1);
  border-radius: 999px;
  animation: eliterepsTitleUnderline 0.7s ease-out 0.3s forwards;
}

/* Hover shimmer on title */
.product__title:hover {
  background-position: 100% 0;
}

/* === PRICE – NEON + PULSE ON HOVER === */

.price__regular,
.price-item--regular,
.price-item--sale {
  display: inline-block;
  font-size: 1.6rem;
  font-weight: 700;
  color: #d6b6ff;
  text-shadow: 0 0 16px rgba(199, 125, 255, 0.9);
  margin-bottom: 12px;
  transition: transform 0.2s ease, text-shadow 0.2s ease;
}

.price__regular:hover,
.price-item--regular:hover,
.price-item--sale:hover {
  animation: eliterepsPricePulse 0.9s ease-out infinite;
}

/* === TRUST BADGES (FAST SHIPPING / SECURE / TRUSTED) === */

.elitereps-trust-line {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  margin: 10px 0 10px;
}

.elitereps-trust-line span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 6px 14px;
  min-height: 32px;
  background: rgba(16, 2, 40, 0.95);
  border-radius: 999px;
  border: 1px solid rgba(199, 125, 255, 0.75);
  color: #f4dcff;
  box-shadow:
    0 0 10px rgba(199, 125, 255, 0.7),
    inset 0 0 12px rgba(124, 44, 255, 0.4);
  white-space: nowrap;
  font-size: 0.9rem;
}

/* === BULLET LIST UNDER BADGES === */

.elitereps-key-points {
  margin: 12px 0 20px 0;
  padding-top: 12px;
  border-top: 1px solid rgba(199, 125, 255, 0.4); /* neon divider */
}

.elitereps-key-points li {
  font-size: 1rem;
  line-height: 1.55;
  margin-bottom: 10px;
  color: #f3eaff;
  padding-left: 24px;
  position: relative;
  opacity: 0; /* animate in */
  animation: eliterepsBulletIn 0.6s ease-out forwards;
}

.elitereps-key-points li::before {
  content: "✦";
  position: absolute;
  left: 0;
  top: 1px;
  color: #c77dff;
  text-shadow: 0 0 10px rgba(199, 125, 255, 1);
  font-size: 1.05rem;
}

/* stagger bullet timing */
.elitereps-key-points li:nth-child(1) { animation-delay: 0.12s; }
.elitereps-key-points li:nth-child(2) { animation-delay: 0.22s; }
.elitereps-key-points li:nth-child(3) { animation-delay: 0.32s; }
.elitereps-key-points li:nth-child(4) { animation-delay: 0.42s; }
.elitereps-key-points li:nth-child(5) { animation-delay: 0.52s; }

/* === VARIANT BUTTONS (COLOR / SIZE) === */

.product-form__input input[type="radio"] + label,
.product-form__input .select {
  background: rgba(5, 0, 20, 0.9);
  border-radius: 999px;
  border: 1px solid rgba(199, 125, 255, 0.65);
  color: #f5f5f5;
}

/* Selected variant */
.product-form__input input[type="radio"]:checked + label {
  background: radial-gradient(circle at top left, #c77dff, #7b2cff);
  color: #050007;
  box-shadow: 0 0 18px rgba(199, 125, 255, 1);
}

/* === BUTTONS (ADD TO CART / BUY NOW) === */

.product-form__buttons .button,
.shopify-payment-button__button {
  background: linear-gradient(135deg, #7b2cff, #c77dff);
  border-radius: 999px;
  border: none;
  color: #050007;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 14px 18px;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 0.95),
    0 0 60px rgba(124, 44, 255, 0.95);
  transform: translateY(0);
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease;
}

.product-form__buttons .button:hover,
.shopify-payment-button__button:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow:
    0 0 30px rgba(199, 125, 255, 1),
    0 0 80px rgba(124, 44, 255, 1);
  filter: brightness(1.07);
}

/* === DESCRIPTION / ACCORDIONS === */

.product__accordion,
.product__description {
  background: rgba(5, 0, 20, 0.9);
  border-radius: 20px;
  border: 1px solid rgba(199, 125, 255, 0.45);
  padding: 18px 18px 16px;
  margin-top: 24px;
}

.product__description h2,
.product__description h3 {
  color: #ffffff;
  text-shadow: 0 0 12px rgba(199, 125, 255, 0.9);
  margin-bottom: 6px;
}

/* === PRODUCT IMAGES === */

.product__media img,
.product__media-wrapper img {
  border-radius: 22px;
}

/* === ANIMATIONS === */

@keyframes eliterepsTitleIntro {
  0% {
    opacity: 0;
    transform: translateY(10px);
    letter-spacing: 0.3em;
    filter: blur(2px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    letter-spacing: 0.14em;
    filter: blur(0);
  }
}

@keyframes eliterepsTitleGlow {
  0% {
    text-shadow:
      0 0 8px rgba(199, 125, 255, 0.7),
      0 0 16px rgba(124, 44, 255, 0.6);
  }
  100% {
    text-shadow:
      0 0 14px rgba(199, 125, 255, 1),
      0 0 28px rgba(124, 44, 255, 1);
  }
}

@keyframes eliterepsTitleUnderline {
  0% {
    width: 0;
    opacity: 0;
  }
  100% {
    width: 100%;
    opacity: 1;
  }
}

@keyframes eliterepsBulletIn {
  0% {
    opacity: 0;
    transform: translateX(-6px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes eliterepsPricePulse {
  0% {
    transform: scale(1);
    text-shadow: 0 0 12px rgba(199, 125, 255, 0.9);
  }
  50% {
    transform: scale(1.04);
    text-shadow:
      0 0 20px rgba(199, 125, 255, 1),
      0 0 36px rgba(124, 44, 255, 1);
  }
  100% {
    transform: scale(1);
    text-shadow: 0 0 12px rgba(199, 125, 255, 0.9);
  }
}










/* === ELITEREPS – PRODUCT HEADING + PRICE SHINE === */

/* Shiny neon product title */
.product__title {
  display: inline-block;
  position: relative;
  font-size: clamp(2.1rem, 3vw, 2.8rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 12px !important;

  /* soft white → pink/purple shine */
  background: linear-gradient(
    90deg,
    #ffffff 0%,
    #f6e9ff 35%,
    #e3c8ff 70%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  color: transparent !important;

  /* subtle neon glow */
  text-shadow:
    0 0 8px rgba(199, 125, 255, 0.7),
    0 0 16px rgba(124, 44, 255, 0.6);

  /* shimmer + fade-in */
  background-size: 300% 300%;
  animation:
    eliteTitleFadeIn 0.6s ease-out forwards,
    eliteTitleShimmer 5s ease-in-out infinite;
}

/* Underline under heading */
.product__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #ffffff, #d6aaff, #7b2cff);
  border-radius: 999px;
  box-shadow:
    0 0 6px rgba(199, 125, 255, 0.7),
    0 0 16px rgba(124, 44, 255, 0.8);
}

/* Neon price with small hover pulse */
.price {
  display: inline-block;
  font-size: 1.5rem;
  font-weight: 700;
  color: #f8e9ff !important;
  text-shadow:
    0 0 12px rgba(199, 125, 255, 0.9),
    0 0 22px rgba(124, 44, 255, 0.85);
  margin: 6px 0 18px;
  transition: transform 0.18s ease, text-shadow 0.18s ease;
}

.price:hover {
  transform: scale(1.03);
  text-shadow:
    0 0 18px rgba(199, 125, 255, 1),
    0 0 32px rgba(124, 44, 255, 1);
}

/* Animations */
@keyframes eliteTitleFadeIn {
  0% {
    opacity: 0;
    transform: translateY(6px);
    filter: blur(3px);
    letter-spacing: 0.30em;
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
    letter-spacing: 0.12em;
  }
}

@keyframes eliteTitleShimmer {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}











































/* === ELITEREPS SHINY NEON PRODUCT HEADING (UNIVERSAL SELECTORS) === */

.product__info-wrapper h1,
.product__info-wrapper .product__title,
h1.product__title,
h1.product-title,
.product__title,
.product-title {
  display: inline-block;
  position: relative;
  font-size: clamp(1.9rem, 2.6vw, 2.6rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 14px !important;

  /* shiny gradient */
  background: linear-gradient(
    90deg,
    #ffffff 0%,
    #f4d9ff 35%,
    #d6aaff 65%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  color: transparent !important;

  /* glow */
  text-shadow:
    0 0 8px rgba(199, 125, 255, 0.7),
    0 0 18px rgba(124, 44, 255, 0.6);

  /* shimmer + fade */
  background-size: 300% 300%;
  animation:
    eliteFadeIn 0.6s ease-out forwards,
    eliteShimmer 4s ease-in-out infinite;
}

/* Underline */
.product__info-wrapper h1::after,
.product__title::after,
.product-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #ffffff, #d6aaff, #7b2cff);
  border-radius: 999px;
  box-shadow:
    0 0 6px rgba(199, 125, 255, 0.7),
    0 0 16px rgba(124, 44, 255, 0.8);
}

/* Price (smaller, neon) */
.price,
.product__info-wrapper .price-item--regular,
.product__info-wrapper .price-item--sale {
  font-size: 1.2rem !important;
  font-weight: 700;
  color: #f1d7ff !important;
  display: inline-block;
  margin-bottom: 18px !important;
  text-shadow:
    0 0 12px rgba(199, 125, 255, 1),
    0 0 26px rgba(124, 44, 255, 0.9);
  transition: transform 0.2s ease;
}

.price:hover {
  transform: scale(1.04);
}

/* ANIMATIONS */
@keyframes eliteFadeIn {
  from { opacity:0; transform: translateY(6px); filter: blur(3px); }
  to { opacity:1; transform: translateY(0); filter: blur(0); }
}

@keyframes eliteShimmer {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}






























/* === ELITEREPS CUSTOM PRODUCT HEADING + PRICE === */

/* Shiny neon product title (our custom h1) */
.elite-product-title {
  display: inline-block;
  position: relative;
  font-size: clamp(2rem, 2.6vw, 2.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  margin-bottom: 12px;

  /* shiny white → light purple text */
  background: linear-gradient(
    90deg,
    #ffffff 0%,
    #f6e9ff 35%,
    #e3c8ff 70%,
    #ffffff 100%
  );
  -webkit-background-clip: text;
  color: transparent;

  /* soft purple glow */
  text-shadow:
    0 0 8px rgba(199, 125, 255, 0.7),
    0 0 16px rgba(124, 44, 255, 0.6);

  /* slow shimmer + fade in */
  background-size: 300% 300%;
  animation:
    eliteTitleFadeIn 0.6s ease-out forwards,
    eliteTitleShimmer 5s ease-in-out infinite;
}

/* Thin neon underline */
.elite-product-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -6px;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #ffffff, #d6aaff, #7b2cff);
  border-radius: 999px;
  box-shadow:
    0 0 6px rgba(199, 125, 255, 0.7),
    0 0 16px rgba(124, 44, 255, 0.8);
}

/* Make price a bit smaller but neon */
.price {
  display: inline-block;
  font-size: 1.2rem !important;   /* smaller than before */
  font-weight: 700;
  color: #f1d7ff !important;
  margin: 6px 0 18px;
  text-shadow:
    0 0 10px rgba(199, 125, 255, 0.9),
    0 0 22px rgba(124, 44, 255, 0.85);
  transition: transform 0.18s ease;
}

.price:hover {
  transform: scale(1.03);
}

/* animations for heading */
@keyframes eliteTitleFadeIn {
  0% {
    opacity: 0;
    transform: translateY(6px);
    filter: blur(3px);
    letter-spacing: 0.25em;
  }
  100% {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
    letter-spacing: 0.10em;
  }
}

@keyframes eliteTitleShimmer {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}














/* === ELITEREPS – HOODIE OPTIONS AREA (COLOR / SIZE / ATC) – FINAL === */

/* Labels: "Color", "Size" */
.product-form .form__label,
.product-form__input .form__label {
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: #f6e9ff !important;
  opacity: 0.9 !important;
  margin-bottom: 6px !important;
}

/* Space between each option group (color, size) */
.product-form__input {
  margin-bottom: 18px !important;
}

/* Universal styling for size pills (2XL, XL, L, M, etc.) */
.product-form__input input[type="radio"] + * {
  background: rgba(5, 0, 20, 0.95) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(199, 125, 255, 0.7) !important;
  color: #f5f5f5 !important;
  padding: 9px 22px !important;
  min-width: 64px !important;
  text-align: center !important;
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  box-shadow:
    0 0 10px rgba(5, 0, 20, 0.8),
    0 0 16px rgba(10, 0, 30, 0.7) !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease,
              background 0.15s ease, border-color 0.15s ease !important;
}

/* Selected size pill */
.product-form__input input[type="radio"]:checked + * {
  background: radial-gradient(circle at top left, #c77dff, #7b2cff) !important;
  border-color: rgba(255, 255, 255, 0.95) !important;
  color: #050007 !important;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 1),
    0 0 36px rgba(124, 44, 255, 0.9) !important;
  transform: translateY(-1px) !important;
}

/* Hover state */
.product-form__input input[type="radio"] + *:hover {
  box-shadow:
    0 0 18px rgba(199, 125, 255, 0.9),
    0 0 32px rgba(124, 44, 255, 0.8) !important;
}

/* Quantity wrapper */
.quantity,
.product-form .quantity {
  border-radius: 999px !important;
  overflow: hidden !important;
  background: rgba(5, 0, 20, 0.98) !important;
  border: 1px solid rgba(199, 125, 255, 0.7) !important;
  box-shadow:
    0 0 12px rgba(199, 125, 255, 0.8),
    0 0 22px rgba(124, 44, 255, 0.7) !important;
}

.quantity__button,
.quantity__input {
  background: transparent !important;
  color: #f5f5f5 !important;
}

/* Add to cart – purple neon pill */
.product-form button[name="add"],
.product-form__submit button,
.product-form__submit .button {
  background: linear-gradient(135deg, #7b2cff, #c77dff) !important;
  border-radius: 999px !important;
  border: none !important;
  color: #050007 !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 14px 18px !important;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 0.95),
    0 0 60px rgba(124, 44, 255, 0.95) !important;
  transform: translateY(0) !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease !important;
}

.product-form button[name="add"]:hover,
.product-form__submit button:hover,
.product-form__submit .button:hover {
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow:
    0 0 30px rgba(199, 125, 255, 1),
    0 0 80px rgba(124, 44, 255, 1) !important;
  filter: brightness(1.05) !important;
}

/* PayPal – rounded + glow, keep yellow */
.shopify-payment-button__button,
.shopify-payment-button__button--unbranded {
  border-radius: 999px !important;
  box-shadow:
    0 0 14px rgba(199, 125, 255, 0.8),
    0 0 26px rgba(124, 44, 255, 0.7) !important;
}


/* === ELITEREPS – SIZE PILLS (HOODIES, TEES, ETC.) === */

/* Base size pill look */
label.variant-option__button-label {
  display: inline-flex;
}

.variant-option__button-label__pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 22px;
  min-width: 64px;
  border-radius: 999px;
  border: 1px solid rgba(199, 125, 255, 0.7);
  background: rgba(5, 0, 20, 0.95);
  color: #f5f5f5;
  font-size: 0.9rem;
  font-weight: 500;
  text-align: center;
  box-shadow:
    0 0 10px rgba(5, 0, 20, 0.8),
    0 0 16px rgba(10, 0, 30, 0.7);
  cursor: pointer;
  transition:
    transform 0.15s ease,
    box-shadow 0.15s ease,
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease;
}

/* Hover state */
.variant-option__button-label__pill:hover {
  box-shadow:
    0 0 18px rgba(199, 125, 255, 0.9),
    0 0 32px rgba(124, 44, 255, 0.8);
}

/* Selected size pill (when the hidden input is checked) */
label.variant-option__button-label input:checked
+ .variant-option__button-label__pill {
  background: radial-gradient(circle at top left, #c77dff, #7b2cff);
  border-color: rgba(255, 255, 255, 0.95);
  color: #050007;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 1),
    0 0 36px rgba(124, 44, 255, 0.9);
  transform: translateY(-1px);
}































/* =/* === ELITEREPS – YOU MAY ALSO LIKE / RECOMMENDED PRODUCTS – FLOAT + SOFT GLOW === */

/* Section container */
.product-recommendations,
.related-products {
  max-width: 1200px;
  margin: 40px auto 56px;
  padding: 0 16px;
}

/* Heading */
.product-recommendations h2,
.related-products h2 {
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #f6e9ff;
  margin-bottom: 22px;
  text-shadow:
    0 0 10px rgba(199, 125, 255, 0.9),
    0 0 22px rgba(124, 44, 255, 0.9);
}

/* Grid spacing */
.product-recommendations .grid,
.related-products .grid {
  gap: 22px;
}

/* Product cards – glass + subtle glow */
.product-recommendations .card,
.related-products .card,
.product-recommendations .card-wrapper,
.related-products .card-wrapper {
  background: radial-gradient(circle at top left,
              rgba(124, 44, 255, 0.14),
              rgba(5, 0, 25, 0.96));
  border-radius: 22px;
  border: 1px solid rgba(199, 125, 255, 0.45);
  padding: 12px 12px 18px;
  box-shadow:
    0 0 14px rgba(199, 125, 255, 0.35),
    0 0 30px rgba(124, 44, 255, 0.4);
  overflow: hidden;
  transition:
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

/* Hover – levitate animation + stronger glow */
.product-recommendations .card:hover,
.related-products .card:hover,
.product-recommendations .card-wrapper:hover,
.related-products .card-wrapper:hover {
  border-color: rgba(255, 255, 255, 0.9);
  box-shadow:
    0 0 24px rgba(199, 125, 255, 0.95),
    0 0 54px rgba(124, 44, 255, 0.95);
  animation: eliteRecoFloat 1.4s ease-in-out infinite;
}

/* Float animation */
@keyframes eliteRecoFloat {
  0%   { transform: translateY(-4px); }
  50%  { transform: translateY(-9px); }
  100% { transform: translateY(-4px); }
}

/* Images rounded */
.product-recommendations img,
.related-products img {
  border-radius: 18px;
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  margin-bottom: 10px;
}

/* Product title – shiny but not huge */
.product-recommendations .card__heading,
.related-products .card__heading,
.product-recommendations .card-information__text,
.related-products .card-information__text {
  display: block;
  font-size: 0.9rem;
  font-weight: 500;
  color: #f7f0ff;
  margin-bottom: 6px;
  text-shadow:
    0 0 6px rgba(199, 125, 255, 0.7),
    0 0 14px rgba(124, 44, 255, 0.6);
}

/* Price styled like a softer BUY NOW pill */
.product-recommendations .price,
.related-products .price {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 22px;
  margin-top: 2px;
  border-radius: 999px;
  background: linear-gradient(135deg, #8a44ff, #c77dff);
  color: #050007 !important;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-shadow: none;
  box-shadow:
    0 0 10px rgba(199, 125, 255, 0.7),
    0 0 24px rgba(124, 44, 255, 0.75);
}

/* small pulse only when card hovered */
.product-recommendations .card:hover .price,
.related-products .card:hover .price {
  animation: eliteRecoPricePulse 0.9s ease-in-out infinite;
}

/* “BUY NOW •” before price */
.product-recommendations .price::before,
.related-products .price::before {
  content: "BUY NOW • ";
  font-weight: 600;
}

/* Price pulse (softer) */
@keyframes eliteRecoPricePulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.03); }
  100% { transform: scale(1); }
}















































/* === ELITEREPS – HOODIE OPTIONS AREA UPGRADE (FOR ALL PRODUCTS) === */

/* Labels: "Color", "Size" */
.product-form .form__label,
.product-form__input .form__label {
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: #f6e9ff !important;
  opacity: 0.9 !important;
  margin-bottom: 6px !important;
}

/* Space between color / size groups */
.product-form__input {
  margin-bottom: 18px !important;
}

/* SIZE PILLS (2XL / XL / L / M) */
.product-form__input input[type="radio"] + label,
.product-form__input input[type="radio"] + span {
  background: rgba(5, 0, 20, 0.95) !important;
  border-radius: 999px !important;
  border: 1px solid rgba(199, 125, 255, 0.7) !important;
  color: #f5f5f5 !important;
  padding: 9px 22px !important;
  min-width: 64px !important;
  text-align: center !important;
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  box-shadow:
    0 0 10px rgba(5, 0, 20, 0.8),
    0 0 16px rgba(10, 0, 30, 0.7) !important;
  transition: transform 0.15s ease, box-shadow 0.15s ease,
              background 0.15s ease, border-color 0.15s ease !important;
}

/* Selected size pill */
.product-form__input input[type="radio"]:checked + label,
.product-form__input input[type="radio"]:checked + span {
  background: radial-gradient(circle at top left, #c77dff, #7b2cff) !important;
  border-color: rgba(255, 255, 255, 0.95) !important;
  color: #050007 !important;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 1),
    0 0 36px rgba(124, 44, 255, 0.9) !important;
  transform: translateY(-1px) !important;
}

/* Hover state */
.product-form__input input[type="radio"] + label:hover,
.product-form__input input[type="radio"] + span:hover {
  box-shadow:
    0 0 18px rgba(199, 125, 255, 0.9),
    0 0 32px rgba(124, 44, 255, 0.8) !important;
}

/* QUANTITY WRAP */
.quantity,
.product-form .quantity {
  border-radius: 999px !important;
  overflow: hidden !important;
  background: rgba(5, 0, 20, 0.98) !important;
  border: 1px solid rgba(199, 125, 255, 0.7) !important;
  box-shadow:
    0 0 12px rgba(199, 125, 255, 0.8),
    0 0 22px rgba(124, 44, 255, 0.7) !important;
}

.quantity__button,
.quantity__input {
  background: transparent !important;
  color: #f5f5f5 !important;
}

/* ADD TO CART – purple neon pill */
.product-form button[name="add"],
.product-form__submit button,
.product-form__submit .button {
  background: linear-gradient(135deg, #7b2cff, #c77dff) !important;
  border-radius: 999px !important;
  border: none !important;
  color: #050007 !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 14px 18px !important;
  box-shadow:
    0 0 20px rgba(199, 125, 255, 0.95),
    0 0 60px rgba(124, 44, 255, 0.95) !important;
  transform: translateY(0) !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, filter 0.18s ease !important;
}

.product-form button[name="add"]:hover,
.product-form__submit button:hover,
.product-form__submit .button:hover {
  transform: translateY(-2px) scale(1.02) !important;
  box-shadow:
    0 0 30px rgba(199, 125, 255, 1),
    0 0 80px rgba(124, 44, 255, 1) !important;
  filter: brightness(1.05) !important;
}

/* PAYPAL – rounded + glow, keep yellow */
.shopify-payment-button__button,
.shopify-payment-button__button--unbranded {
  border-radius: 999px !important;
  box-shadow:
    0 0 14px rgba(199, 125, 255, 0.8),
    0 0 26px rgba(124, 44, 255, 0.7) !important;
}





































/* === EliteReps – Home collection picker === */

.elite-home-collections {
  padding: 32px 0 40px;
}

.elite-home-collections__title {
  margin: 0 0 18px;
  font-size: 1.1rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  text-align: left;
  color: #ffffff;
  text-shadow:
    0 0 12px rgba(255, 255, 255, 0.9),
    0 0 26px rgba(189, 140, 255, 0.95),
    0 0 46px rgba(137, 82, 255, 0.9);
}

/* 3 across like Shopify, but cleaner & smaller */
.elite-home-collections__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 900px) {
  .elite-home-collections__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .elite-home-collections__grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* Card */
.elite-home-collections__card {
  position: relative;
  display: block;
  border-radius: 18px;
  overflow: hidden;
  background: radial-gradient(circle at top left, #3f1c77, #080311);
  box-shadow:
    0 0 0 1px rgba(230, 214, 255, 0.35),
    0 14px 28px rgba(0, 0, 0, 0.75),
    0 0 32px rgba(155, 104, 255, 0.75);
  transform: translateY(0) scale(1);
  transition:
    transform 0.22s ease-out,
    box-shadow 0.22s ease-out,
    filter 0.22s ease-out;
}

/* Hover float + more glow */
.elite-home-collections__card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow:
    0 0 0 1px rgba(255, 245, 255, 0.9),
    0 20px 46px rgba(0, 0, 0, 0.9),
    0 0 60px rgba(195, 140, 255, 1);
  filter: brightness(1.06);
}

/* Image */
.elite-home-collections__image-wrap {
  position: relative;
  width: 100%;
  height: 100%;
}

.elite-home-collections__image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Label pill */
.elite-home-collections__label {
  position: absolute;
  left: 12px;
  bottom: 12px;
  padding: 6px 12px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 500;
  background: rgba(10, 5, 25, 0.9);
  color: #fdf8ff;
  border: 1px solid rgba(230, 210, 255, 0.95);
  box-shadow:
    0 0 10px rgba(180, 126, 255, 0.95),
    0 0 22px rgba(148, 91, 255, 0.9);
  backdrop-filter: blur(7px);
  text-transform: capitalize;
}

/* Placeholder if no image */
.elite-home-collections__placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 180px;
  font-size: 0.9rem;
  color: #e5d8ff;
}































/* === EliteReps Shoes vs Other Site (with images) === */

.elite-shoes-compare {
  width: 100%;
  margin-top: 40px;
  padding: 28px;
  border-radius: 22px;
  background: rgba(10, 5, 25, 0.88);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(210, 150, 255, 0.45);
  box-shadow: 0 0 40px rgba(150, 80, 255, 0.6);
  overflow-x: auto;
}

.elite-shoes-compare__title {
  margin-bottom: 20px;
  font-size: 1.1rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #fff;
  text-shadow: 0 0 20px #c07bff;
}

/* ROWS */
.elite-shoes-compare__row {
  display: grid;
  grid-template-columns: 180px 1fr 1fr;
  padding: 16px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.elite-shoes-compare__row:last-child {
  border-bottom: none;
}

/* LEFT COLUMN LABELS */
.elite-shoes-compare__label {
  font-weight: 700;
  color: #ffffff;
}

/* IMAGE BOX */
.elite-shoes-compare__img-box {
  width: 100%;
  height: 180px;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(180, 120, 255, 0.5);
  box-shadow: 0 0 20px rgba(170, 100, 255, 0.7);
  margin-bottom: 10px;
}

.elite-shoes-compare__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* BRAND NAME */
.elite-shoes-compare__brand-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: white;
  margin-bottom: 4px;
  text-shadow: 0 0 10px #c07bff;
}

/* TAGS */
.elite-shoes-compare__brand-tag {
  display: inline-block;
  padding: 5px 12px;
  border-radius: 999px;
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  background: rgba(140, 80, 255, 0.3);
  border: 1px solid rgba(190, 150, 255, 0.8);
  color: #fff;
}

.elite-shoes-compare__brand-tag--other {
  background: rgba(90, 90, 90, 0.35);
  border-color: rgba(150, 150, 150, 0.8);
}

/* VALUES */
.elite-shoes-compare__value {
  font-weight: 600;
  color: #fff;
}

/* MOBILE */
@media (max-width: 700px) {
  .elite-shoes-compare__row {
    grid-template-columns: 130px 1fr;
    row-gap: 16px;
  }
}

































































/* === EliteReps “Difference + Graph” (WOW) === */
.elite-diff{
  --a1:#a855ff;
  --a2:#22d3ee;
  margin: 44px 0;
  padding: 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 15% 5%, rgba(168,85,255,.35), transparent 45%),
    radial-gradient(circle at 85% 10%, rgba(34,211,238,.22), transparent 40%),
    radial-gradient(circle at 50% 120%, rgba(0,0,0,.65), #05000c 55%);
  border: 1px solid rgba(210,150,255,.45);
  box-shadow: 0 0 45px rgba(150,80,255,.65), 0 0 95px rgba(0,0,0,.9);
  overflow: hidden;
  position: relative;
}

.elite-diff::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: conic-gradient(from 180deg, transparent, rgba(255,255,255,.08), transparent);
  animation: eliteDiffSpin 10s linear infinite;
  opacity:.5;
  pointer-events:none;
}
@keyframes eliteDiffSpin { to { transform: rotate(360deg); } }

.elite-diff__top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 14px;
  position:relative;
  z-index:2;
  margin-bottom: 16px;
}

.elite-diff__kicker{
  color:#e9ddff;
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  opacity:.9;
}

.elite-diff__title{
  color:#fff;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size: 1.05rem;
  margin-top: 6px;
  text-shadow: 0 0 14px rgba(200,150,255,.85);
}

.elite-diff__tabs{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  min-width: 420px;
}

.elite-diff__tab{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(200,170,255,.45);
  background: rgba(12,6,28,.6);
  padding: 12px 14px;
  cursor:pointer;
  overflow:hidden;
  box-shadow: 0 0 18px rgba(120,70,255,.35);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.elite-diff__tabGlow{
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(circle at 20% 0%, rgba(255,255,255,.18), transparent 45%),
    linear-gradient(90deg, rgba(168,85,255,.35), rgba(34,211,238,.25));
  filter: blur(10px);
  opacity:.25;
  transition: opacity .22s ease;
  pointer-events:none;
}

.elite-diff__tabText{
  position:relative;
  z-index:2;
  display:block;
  color:#f6f0ff;
}

.elite-diff__tabTitle{
  display:block;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:800;
}

.elite-diff__tabSub{
  display:block;
  margin-top: 4px;
  font-size:.78rem;
  opacity:.82;
}

.elite-diff__tab:hover{
  transform: translateY(-6px);
  box-shadow: 0 0 26px rgba(190,120,255,.85), 0 0 60px rgba(34,211,238,.35);
}
.elite-diff__tab:hover .elite-diff__tabGlow{ opacity:.55; }

.elite-diff__tab--active{
  transform: translateY(-10px) scale(1.015);
  border-color: rgba(255,255,255,.9);
  box-shadow: 0 0 34px rgba(200,150,255,1), 0 0 80px rgba(168,85,255,.55);
  animation: eliteDiffPulse 2.4s ease-in-out infinite;
}
@keyframes eliteDiffPulse{
  0%,100%{ filter: brightness(1); }
  50%{ filter: brightness(1.08); }
}

/* layout grid */
.elite-diff__grid{
  display:grid;
  grid-template-columns: 1.05fr 1.35fr;
  gap: 16px;
  position:relative;
  z-index:2;
}

.elite-diff__card{
  border-radius: 22px;
  border: 1px solid rgba(210,150,255,.28);
  background: rgba(10,5,20,.55);
  box-shadow: inset 0 0 18px rgba(0,0,0,.55);
  padding: 16px 16px 14px;
}

.elite-diff__cardTitle{
  color:#fff;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9rem;
  margin-bottom: 12px;
  text-shadow: 0 0 14px rgba(200,150,255,.85);
}

.elite-diff__list{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.elite-diff__li{
  display:flex;
  gap: 10px;
  color:#eaddff;
  line-height:1.25rem;
  opacity:0;
  transform: translateY(6px);
  animation: eliteDiffIn .55s ease forwards;
}
@keyframes eliteDiffIn{
  to{ opacity:1; transform: translateY(0); }
}

.elite-diff__spark{
  color: #fff;
  text-shadow: 0 0 14px rgba(200,150,255,1);
  flex: 0 0 auto;
  margin-top: 1px;
}

.elite-diff__note{
  margin-top: 12px;
  font-size: .82rem;
  color:#d7c7ff;
  opacity:.9;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px dashed rgba(210,150,255,.35);
  background: rgba(10,5,20,.35);
}

/* graph */
.elite-diff__graphHead{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 10px;
}

.elite-diff__graphTitle{
  color:#fff;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9rem;
  text-shadow: 0 0 14px rgba(200,150,255,.85);
}

.elite-diff__legend{
  display:flex;
  align-items:center;
  gap: 10px;
  color:#eaddff;
  font-size:.82rem;
  opacity:.9;
}

.elite-diff__dot{
  width:10px; height:10px; border-radius:999px; display:inline-block;
}
.elite-diff__dot--a{ background: linear-gradient(90deg, var(--a1), var(--a2)); box-shadow: 0 0 12px rgba(200,150,255,.9); }
.elite-diff__dot--b{ background: rgba(255,255,255,.25); }

.elite-diff__rows{ display:flex; flex-direction:column; gap: 12px; }

.elite-diff__row{
  display:grid;
  grid-template-columns: 190px 1fr 88px;
  align-items:center;
  gap: 10px;
}

.elite-diff__label{
  color:#eaddff;
  font-size:.9rem;
}

.elite-diff__bars{
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.elite-diff__bar{
  height: 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  overflow:hidden;
  box-shadow: inset 0 0 8px rgba(0,0,0,.65);
}

.elite-diff__bar--a{
  background: rgba(20,12,40,.75);
}

.elite-diff__fill{
  height:100%;
  width:0%;
  border-radius:inherit;
  transition: width .75s cubic-bezier(.2,.7,.2,1);
}

.elite-diff__fill--a{
  background:
    linear-gradient(120deg, rgba(255,255,255,.55), transparent 40%),
    linear-gradient(90deg, var(--a1), var(--a2));
  background-size: 220% 100%, 100% 100%;
  animation: eliteDiffShimmer 2.2s ease-in-out infinite;
  box-shadow: 0 0 18px rgba(200,150,255,.8);
}

.elite-diff__fill--b{
  background: rgba(255,255,255,.22);
}

@keyframes eliteDiffShimmer{
  0%,100%{ background-position: 120% 0, 0 0; }
  50%{ background-position: -20% 0, 0 0; }
}

.elite-diff__vals{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap: 6px;
  font-weight:700;
  color:#fff;
}

.elite-diff__val--a{ text-shadow: 0 0 12px rgba(200,150,255,.85); }
.elite-diff__val--b{ opacity:.75; font-weight:600; }

/* mobile */
@media (max-width: 980px){
  .elite-diff__top{ flex-direction:column; align-items:stretch; }
  .elite-diff__tabs{ min-width: 0; }
  .elite-diff__grid{ grid-template-columns: 1fr; }
  .elite-diff__row{ grid-template-columns: 1fr; }
  .elite-diff__vals{ flex-direction:row; justify-content:space-between; }
}




































































/* ===== Elite compare v3 (simple WOW + not confusing) ===== */

.elite-compare3{
  margin: 44px 0;
  padding: 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 15% 8%, rgba(168,85,255,.28), transparent 45%),
    radial-gradient(circle at 85% 12%, rgba(255,255,255,.08), transparent 45%),
    radial-gradient(circle at 50% 120%, rgba(0,0,0,.65), #05000c 55%);
  border: 1px solid rgba(210,150,255,.42);
  box-shadow: 0 0 45px rgba(150,80,255,.60), 0 0 95px rgba(0,0,0,.90);
  position: relative;
  overflow: hidden;
}

.elite-compare3::before{
  content:"";
  position:absolute;
  inset:-40%;
  background: conic-gradient(from 180deg, transparent, rgba(255,255,255,.05), transparent);
  animation: eliteC3Spin 18s linear infinite;
  opacity:.16;
  pointer-events:none;
}
@keyframes eliteC3Spin { to{ transform: rotate(360deg);} }

.elite-compare3__top{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 14px;
  position:relative;
  z-index:2;
  margin-bottom: 14px;
}

.elite-compare3__kicker{
  color:#e9ddff;
  font-size:.8rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  opacity:.9;
}

.elite-compare3__title{
  color:#fff;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size: 1.05rem;
  margin-top: 6px;
  text-shadow: 0 0 14px rgba(200,150,255,.78);
}

.elite-compare3__tabs{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  min-width: 420px;
}

.elite-compare3__tab{
  position:relative;
  border-radius:18px;
  border:1px solid rgba(200,170,255,.38);
  background: rgba(12,6,28,.56);
  padding: 12px 14px;
  cursor:pointer;
  overflow:hidden;
  box-shadow: 0 0 18px rgba(120,70,255,.30);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  text-align:left;
}

.elite-compare3__shine{
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(circle at 20% 0%, rgba(255,255,255,.16), transparent 45%),
    linear-gradient(90deg, rgba(168,85,255,.20), rgba(192,132,252,.14));
  filter: blur(10px);
  opacity:.16;
  transition: opacity .22s ease;
  pointer-events:none;
}

.elite-compare3__tabTitle{
  display:block;
  font-size:.82rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:850;
  color:#fff;
  position:relative;
  z-index:2;
}

.elite-compare3__tabSub{
  display:block;
  margin-top: 4px;
  font-size:.78rem;
  opacity:.82;
  color:#f2eaff;
  position:relative;
  z-index:2;
}

.elite-compare3__tab:hover{
  transform: translateY(-6px);
  box-shadow: 0 0 24px rgba(190,120,255,.70), 0 0 55px rgba(168,85,255,.32);
}
.elite-compare3__tab:hover .elite-compare3__shine{ opacity:.28; }

.elite-compare3__tab.is-active{
  transform: translateY(-10px) scale(1.012);
  border-color: rgba(255,255,255,.72);
  box-shadow: 0 0 30px rgba(200,150,255,.90), 0 0 75px rgba(168,85,255,.30);
}

/* facts block */
.elite-compare3__facts{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  position:relative;
  z-index:2;
  margin: 12px 0 14px;
}

.elite-compare3__factsCol{
  border-radius: 22px;
  border: 1px solid rgba(210,150,255,.18);
  background: rgba(10,5,20,.48);
  box-shadow: inset 0 0 18px rgba(0,0,0,.55);
  padding: 14px 14px 12px;
}

.elite-compare3__factsTitle{
  color:#fff;
  font-weight:850;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.86rem;
  margin-bottom: 10px;
  text-shadow: 0 0 14px rgba(200,150,255,.70);
}

.elite-compare3__factsList{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.elite-compare3__factsList li{
  display:flex;
  gap: 10px;
  color:#eaddff;
  line-height:1.22rem;
  opacity:0;
  transform: translateY(6px);
  animation: eliteC3In .55s ease forwards;
}
@keyframes eliteC3In{ to{ opacity:1; transform: translateY(0);} }

.elite-compare3__spark{
  color:#fff;
  text-shadow: 0 0 14px rgba(200,150,255,1);
  flex: 0 0 auto;
  margin-top: 1px;
}

/* graph */
.elite-compare3__graphCard{
  border-radius: 22px;
  border: 1px solid rgba(210,150,255,.22);
  background: rgba(10,5,20,.52);
  box-shadow: inset 0 0 18px rgba(0,0,0,.55);
  padding: 16px 16px 14px;
  position:relative;
  z-index:2;
}

.elite-compare3__graphTitle{
  color:#fff;
  font-weight:850;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9rem;
  margin-bottom: 12px;
  text-shadow: 0 0 14px rgba(200,150,255,.70);
}

.elite-compare3__rows{
  display:flex;
  flex-direction:column;
  gap: 12px;
}

.elite-compare3__row{
  display:grid;
  grid-template-columns: 210px 1fr 140px;
  gap: 12px;
  align-items:center;
}

.elite-compare3__label{
  color: rgba(245,240,255,0.92);
  font-weight: 650;
  font-size:.9rem;
}

.elite-compare3__bar{
  height: 18px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.08);
  overflow:hidden;
  box-shadow: inset 0 0 10px rgba(0,0,0,.70);
}

.elite-compare3__fill{
  height:100%;
  width:0%;
  border-radius:inherit;
  transition: width .85s cubic-bezier(.2,.75,.2,1);
  position:relative;
}

/* Elite only (purple) */
.elite-compare3__fill.elite{
  background: linear-gradient(90deg, #7c3aed, #c084fc);
  box-shadow: 0 0 18px rgba(180,120,255,0.55);
}
.elite-compare3__fill.elite::after{
  content:"";
  position:absolute;
  top:0;
  left:-40%;
  width:40%;
  height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.35), transparent);
  filter: blur(1px);
  animation: eliteC3Sweep 1.9s ease-in-out infinite;
  opacity: 0.75;
}

/* Typical only (clean grey) */
.elite-compare3__fill.typical{
  background: linear-gradient(90deg, rgba(255,255,255,0.22), rgba(255,255,255,0.12));
  opacity: 0.85;
}

@keyframes eliteC3Sweep{
  0% { transform: translateX(0); }
  100% { transform: translateX(260%); }
}

.elite-compare3__val{
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap: 6px;
}

.elite-compare3__val .tag{
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  opacity: 0.75;
  color:#eaddff;
}

.elite-compare3__val .num{
  font-weight:900;
  font-size: 1rem;
  color:#fff;
}
.elite-compare3__fill.elite ~ .elite-compare3__val .num{
  text-shadow: 0 0 12px rgba(200,150,255,.75);
}

/* price compare box under */
.elite-compare3__priceCompare{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
  position:relative;
  z-index:2;
}

.elite-compare3__priceCol{
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}

.elite-compare3__priceCol.elite{
  border-color: rgba(190,150,255,0.22);
  box-shadow: 0 0 18px rgba(180,120,255,0.22);
}

.elite-compare3__priceCol .t{
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.85;
  color: #f2eaff;
}
.elite-compare3__priceCol .p{
  margin-top: 6px;
  font-weight: 900;
  color: #fff;
  text-shadow: 0 0 10px rgba(200,150,255,0.55);
}
.elite-compare3__priceCol .p .small{
  font-weight: 700;
  opacity: 0.75;
  font-size: 0.82rem;
}
.elite-compare3__priceCol .s{
  margin-top: 4px;
  font-size: 0.85rem;
  opacity: 0.85;
  color: #eaddff;
}

/* mobile */
@media (max-width: 980px){
  .elite-compare3__top{ flex-direction:column; align-items:stretch; }
  .elite-compare3__tabs{ min-width: 0; }
  .elite-compare3__facts{ grid-template-columns: 1fr; }
  .elite-compare3__row{ grid-template-columns: 1fr; gap: 8px; }
  .elite-compare3__val{ flex-direction:row; justify-content:space-between; align-items:center; }
  .elite-compare3__priceCompare{ grid-template-columns: 1fr; }
}


/* --- size refinement: make comparison section tighter --- */

.elite-compare3{
  padding: 18px;              /* was 24 */
  border-radius: 22px;        /* was 28 */
}

.elite-compare3__title{
  font-size: 0.95rem;         /* was 1.05 */
}

.elite-compare3__factsTitle,
.elite-compare3__graphTitle{
  font-size: 0.82rem;
}

.elite-compare3__factsList li{
  font-size: 0.9rem;
  line-height: 1.15rem;
}

.elite-compare3__row{
  grid-template-columns: 180px 1fr 120px; /* tighter */
}

.elite-compare3__bar{
  height: 16px;               /* was 18 */
}

.elite-compare3__val .num{
  font-size: 0.95rem;
}

.elite-compare3__priceCol{
  padding: 10px 12px;         /* was 12px 14px */
}

.elite-compare3__priceCol .p{
  font-size: 0.95rem;
}




/* ===== Elite Compare3: smaller overall + bigger nicer tabs ===== */

/* whole section smaller */
.elite-compare3{
  padding: 18px !important;        /* smaller */
  border-radius: 22px !important;
  margin: 28px 0 !important;
}

.elite-compare3__top{
  margin-bottom: 10px !important;
  gap: 12px !important;
}

.elite-compare3__title{
  font-size: .95rem !important;
}

.elite-compare3__kicker{
  font-size: .74rem !important;
}

/* facts area smaller */
.elite-compare3__facts{
  gap: 12px !important;
  margin: 10px 0 12px !important;
}

.elite-compare3__factsCol{
  padding: 12px 12px 10px !important;
  border-radius: 18px !important;
}

.elite-compare3__factsTitle{
  font-size: .78rem !important;
  margin-bottom: 8px !important;
}

.elite-compare3__factsList{
  gap: 7px !important;
}

.elite-compare3__factsList li{
  font-size: .88rem !important;
  line-height: 1.12rem !important;
}

/* graph smaller */
.elite-compare3__graphCard{
  padding: 14px 14px 12px !important;
  border-radius: 18px !important;
}

.elite-compare3__graphTitle{
  font-size: .82rem !important;
  margin-bottom: 10px !important;
}

.elite-compare3__rows{
  gap: 10px !important;
}

.elite-compare3__row{
  grid-template-columns: 180px 1fr 120px !important;
  gap: 10px !important;
}

.elite-compare3__label{
  font-size: .88rem !important;
}

.elite-compare3__bar{
  height: 16px !important;
}

.elite-compare3__val .num{
  font-size: .95rem !important;
}

.elite-compare3__val .tag{
  font-size: .68rem !important;
}

/* price compare smaller */
.elite-compare3__priceCompare{
  gap: 10px !important;
  margin-top: 12px !important;
}

.elite-compare3__priceCol{
  padding: 10px 12px !important;
  border-radius: 16px !important;
}

.elite-compare3__priceCol .p{
  font-size: .95rem !important;
}

/* ===== Make buttons bigger + more attractive ===== */
.elite-compare3__tabs{
  min-width: 460px !important; /* slightly wider so they feel bigger */
  gap: 14px !important;
}

.elite-compare3__tab{
  padding: 14px 16px !important;         /* bigger */
  border-radius: 20px !important;
  border-color: rgba(220,190,255,.55) !important;
  box-shadow: 0 0 20px rgba(160,90,255,.35) !important;
  position: relative;
}

/* brighter glow layer */
.elite-compare3__tab .elite-compare3__shine{
  opacity: .28 !important;
}

/* nicer text */
.elite-compare3__tabTitle{
  font-size: .88rem !important;
  letter-spacing: .16em !important;
}

.elite-compare3__tabSub{
  font-size: .8rem !important;
  opacity: .9 !important;
}

/* hover: lift + stronger glow */
.elite-compare3__tab:hover{
  transform: translateY(-8px) scale(1.01) !important;
  box-shadow: 0 0 26px rgba(200,150,255,.80), 0 0 70px rgba(168,85,255,.28) !important;
}

/* active: strong premium glow */
.elite-compare3__tab.is-active{
  transform: translateY(-10px) scale(1.02) !important;
  border-color: rgba(255,255,255,.80) !important;
  box-shadow: 0 0 34px rgba(210,170,255,.95), 0 0 90px rgba(168,85,255,.30) !important;
}

/* mobile tighten */
@media (max-width: 980px){
  .elite-compare3__tabs{ min-width: 0 !important; }
}

























































































/* ===========================
   PHONE HEADER — LOGO + HAMBURGER + LEFT DRAWER ONLY
   (DO NOT AFFECT DESKTOP)
=========================== */

@media (max-width: 780px){

  /* hide desktop nav + icons */
  .elite-bubble-header__nav,
  .elite-bubble-header__right{
    display: none !important;
  }

  /* header layout */
  .elite-bubble-header__inner{
    position: relative !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 14px 18px !important;
  }

  /* center logo */
  .elite-bubble-header__logo-text{
    font-size: 30px !important;
    margin: 0 auto !important;
    text-align: center !important;
    display: block !important;
  }

  /* hamburger button */
  .elite-menu-btn{
    display: flex !important;
    position: absolute !important;
    left: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 44px;
    height: 44px;
    border-radius: 999px;
    border: 1px solid rgba(190,140,255,.75);
    background: #0b041b;
    color: #fff;
    font-size: 22px;
    align-items: center;
    justify-content: center;
    z-index: 10;
  }

  /* drawer shell */
  .elite-drawer{
    display: block !important;
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 9999;
  }

  .elite-drawer.elite-drawer-open{
    pointer-events: auto;
  }

  /* dark backdrop */
  .elite-drawer-backdrop{
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.6);
    opacity: 0;
    transition: opacity .25s ease;
  }

  .elite-drawer.elite-drawer-open .elite-drawer-backdrop{
    opacity: 1;
  }

  /* left panel */
  .elite-drawer-inner{
    position: absolute;
    left: 0;
    top: 0;
    height: 100%;
    width: 86vw;
    max-width: 400px;
    transform: translateX(-105%);
    transition: transform .3s ease;
    background: #080016;
    border-right: 1px solid rgba(190,140,255,.5);
    padding: 18px 16px 26px;
    overflow-y: auto;
  }

  .elite-drawer.elite-drawer-open .elite-drawer-inner{
    transform: translateX(0);
  }

  /* drawer links */
  .elite-drawer-nav a{
    display: block;
    margin: 12px 0;
    padding: 16px;
    border-radius: 18px;
    color: #fff;
    text-decoration: none;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(190,140,255,.35);
  }

  /* bottom icons */
  .elite-drawer-icons{
    display: flex;
    gap: 14px;
    margin-top: 28px;
  }

  .elite-drawer-icon{
    flex: 1;
    text-align: center;
    padding: 14px 0;
    border-radius: 999px;
    color: #fff;
    text-decoration: none;
    background: rgba(20,0,40,.85);
    border: 1px solid rgba(190,140,255,.55);
  }
}

/* lock scroll when drawer open */
html.elite-lock,
html.elite-lock body{
  overflow: hidden !important;
}

































/* ===========================
   FIX 1: DESKTOP/LAPTOP — NO HAMBURGER, NO DRAWER
   (ONLY PHONE SHOULD HAVE IT)
=========================== */

/* default: hide hamburger + drawer everywhere */
.elite-menu-btn{ display:none !important; }
.elite-drawer{ display:none !important; }

/* show normal desktop stuff again */
@media (min-width: 781px){
  .elite-bubble-header__nav,
  .elite-bubble-header__right{
    display:flex !important;
  }
}


/* ===========================
   FIX 2: PHONE — SHOW HAMBURGER + DRAWER
=========================== */
@media (max-width: 780px){

  /* hide desktop nav + icons on phone */
  .elite-bubble-header__nav,
  .elite-bubble-header__right{
    display:none !important;
  }

  /* show hamburger on phone */
  .elite-menu-btn{
    display:flex !important;
  }

  /* show drawer system on phone */
  .elite-drawer{
    display:block !important;
  }

  /* make header logo bigger + shinier on phone */
  .elite-bubble-header__logo-text{
    font-size: 34px !important;
    font-weight: 900 !important;
    text-shadow:
      0 0 10px rgba(255,255,255,1),
      0 0 26px rgba(195,150,255,1),
      0 0 44px rgba(121,40,255,.75) !important;
  }

  /* drawer menu words shiny */
  .elite-drawer-nav a{
    font-size: 20px !important;
    font-weight: 700 !important;
    letter-spacing: .2px !important;
    text-shadow:
      0 0 10px rgba(203,170,255,.75),
      0 0 22px rgba(121,40,255,.65) !important;
  }

  /* bottom icons bigger + shiny */
  .elite-drawer-icon{
    font-size: 28px !important;
    padding: 18px 0 !important;
    box-shadow:
      0 0 18px rgba(203,170,255,.75),
      0 0 36px rgba(121,40,255,.65) !important;
  }
  .elite-drawer-icon:active{
    transform: scale(.97) !important;
  }

  /* FIX 3: remove the X close button (hide it) */
  .elite-drawer-close,
  .elite-drawer-header button{
    display:none !important;
  }
}


















































/* ===========================
   PHONE DRAWER — SIZE + LOOK FIX (STEP 2)
   Paste at bottom of base.css
=========================== */

@media (max-width: 780px){

  /* Top "EliteReps" in drawer: big, white, shiny */
  .elite-drawer-logo,
  .elite-drawer-header .elite-drawer-logo,
  .elite-drawer-header a{
    font-size: 34px !important;
    font-weight: 900 !important;
    color: #ffffff !important;
    text-decoration: none !important;
    text-shadow:
      0 0 10px rgba(255,255,255,1),
      0 0 26px rgba(195,150,255,1),
      0 0 44px rgba(121,40,255,.65) !important;
  }

  /* Make drawer padding slightly tighter */
  .elite-drawer-inner{
    padding: 14px 14px 18px !important;
  }

  /* ROW BUTTONS: smaller + even */
  .elite-drawer-nav a{
    padding: 14px 14px !important;
    margin: 10px 0 !important;
    border-radius: 18px !important;
    font-size: 18px !important;
    font-weight: 750 !important;
    line-height: 1.2 !important;
  }

  /* Reduce the big “tall” feel */
  .elite-drawer-nav{
    padding-top: 4px !important;
  }

  /* Bottom icons: smaller + still shiny */
  .elite-drawer-icons{
    gap: 12px !important;
    margin-top: 18px !important;
  }

  .elite-drawer-icon{
    font-size: 22px !important;
    padding: 14px 0 !important;
    border-radius: 999px !important;
    box-shadow:
      0 0 14px rgba(203,170,255,.65),
      0 0 26px rgba(121,40,255,.55) !important;
  }

  /* If your bottom icons became circles from other CSS, keep them pill-shaped */
  .elite-drawer-icon{
    min-width: 0 !important;
  }
}


