/** Shopify CDN: Minification failed

Line 5507:93 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;
}

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

p:empty {
  display: none;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

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

.skip-to-content-link:focus {
  z-index: var(--layer-temporary);
  overflow: auto;
  width: auto;
  height: auto;
  padding: var(--padding-lg) var(--padding-4xl);
  left: var(--margin-lg);
  top: var(--margin-lg);
  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);
}

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

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

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

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

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

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

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

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

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

/* Typography presets */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

body:has(.header[transparent]) #header-group > .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: slideInLeft;
  --dialog-drawer-closing-animation: slideOutLeft;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: slideInRight;
  --dialog-drawer-closing-animation: slideOutRight;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Show more */

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

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

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

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

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

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

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

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

/* Collapsible row */

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  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) / calc(var(--media-preview-ratio)) + var(--padding-lg) * 2);
  right: var(--padding-lg);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.tax-note.tax-note.tax-note {
  font-size: min(0.85em, var(--font-paragraph--size));
  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;
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Fly to cart animation */
fly-to-cart {
  position: fixed;
  width: 40px;
  height: 40px;
  left: 0;
  top: 0;
  border-radius: 50%;
  z-index: calc(infinity);
  pointer-events: none;
  opacity: 0;
  overflow: hidden;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  transition: opacity 0.3s ease;
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
  background-color: var(--color-foreground);
  transform: translate(var(--x, 0), var(--y, 0)) scale(var(--scale, 1));
}

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

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

  to {
    transform: translateX(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

  to {
    transform: translateY(0);
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  * {
    pointer-events: none;
  }
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  button {
    --size: 0.5rem;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

.slideshow-controls__thumbnail {
  position: relative;
}

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

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

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

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

  svg {
    display: none;
  }
}

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

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

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

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

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

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

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

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

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

slideshow-arrows .slideshow-control {
  pointer-events: auto;
  opacity: 0;
  min-height: var(--minimum-touch-target);
  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);
}

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

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

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

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

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

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  &[shimmer] {
    color: transparent;

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

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

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

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

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

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

/* Global scrollbar styles */

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

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

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

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

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

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

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

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

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

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


/* Vern Horizon first-pass speed/shop UX 2026-05-01 */
/* Keep Horizon fast and shoppable: wider grids, visible header, tighter product cards. */
@media screen and (min-width: 990px) {
  .page-width { max-width: 1360px; }
  .product-card__title, .card__heading, product-card a[href*="/products/"] {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }
}
.header, .header * { text-rendering: optimizeLegibility; }
.product-card img { background: #fff; }
/* End Vern Horizon first-pass speed/shop UX */


/* Vern Horizon Pittsburgh visual pass 2026-05-01 */
:root {
  --yg-black: #050505;
  --yg-gold: #ffb612;
  --yg-gold-soft: #fff3bf;
  --yg-cream: #fffaf0;
}
html { scroll-padding-top: 118px; }
body { background: var(--yg-cream); }
#header-group {
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  background: var(--yg-black) !important;
  box-shadow: 0 2px 14px rgba(0,0,0,.18);
}
#header-group .shopify-section,
#header-group header,
#header-group .header,
#header-group [class*="announcement"] {
  background: var(--yg-black) !important;
  color: #fff !important;
  visibility: visible !important;
  opacity: 1 !important;
}
#header-group a,
#header-group button,
#header-group summary { color: #fff !important; }
#header-group a:hover,
#header-group button:hover,
#header-group summary:hover { color: var(--yg-gold) !important; }
#header-group [class*="announcement"] a,
#header-group aside a {
  color: var(--yg-gold) !important;
  font-weight: 700;
  letter-spacing: .01em;
}
main [class*="hero"] h1,
main h1 { text-wrap: balance; }
main [class*="hero"] .button,
main [class*="hero"] a[class*="button"] {
  background: var(--yg-gold) !important;
  color: #000 !important;
  border-color: var(--yg-gold) !important;
  font-weight: 800;
}
main [class*="hero"] .button:hover,
main [class*="hero"] a[class*="button"]:hover {
  background: #ffd65a !important;
  border-color: #ffd65a !important;
}
main h2 { text-wrap: balance; }
footer, footer .shopify-section { background: var(--yg-black) !important; color: #fff !important; }
footer a { color: var(--yg-gold) !important; }
/* End Vern Horizon Pittsburgh visual pass */


/* Vern Horizon sticky announcement correction 2026-05-01 */
/* Horizon renders #header-group as display: contents, so sticky must target the actual header and announcement sections. */
.shopify-section-group-header-group.header-section {
  position: sticky !important;
  top: 0 !important;
  z-index: 1003 !important;
  background: var(--yg-black, #050505) !important;
}
[id*="header_announcements"].shopify-section-group-header-group {
  position: sticky !important;
  top: 51px !important;
  z-index: 1002 !important;
  background: var(--yg-black, #050505) !important;
  transform: translateZ(0);
}
[id*="header_announcements"] .announcement-bar,
[id*="header_announcements"] .announcement-bar__slider,
[id*="header_announcements"] .announcement-bar__slides,
[id*="header_announcements"] .announcement-bar__slide,
[id*="header_announcements"] .announcement-bar__link {
  visibility: visible !important;
  opacity: 1 !important;
}
/* End Vern Horizon sticky announcement correction */

/* Vern Horizon header/footer visibility fix 2026-05-01 */
#header-group,
#header-group .shopify-section,
#header-group .header-section,
#header-group #header-component,
#header-group .header,
#header-group .header__row,
#header-group .header__columns,
#header-group .header-menu,
#header-group .header-menu__inner,
#header-group .header__column,
#header-group .header-actions,
#header-group .header__drawer,
#header-group header-drawer {
  background: #050505 !important;
  color: #ffffff !important;
}
#header-group .header__row {
  border: 0 !important;
  box-shadow: none !important;
}
#header-group a,
#header-group a:visited,
#header-group button,
#header-group summary,
#header-group .menu-list__link,
#header-group .header-menu__link,
#header-group .header-actions__action,
#header-group .account-button,
#header-group .cart-icon,
#header-group svg,
#header-group svg * {
  color: #ffffff !important;
  fill: currentColor !important;
  stroke: currentColor !important;
}
#header-group .menu-list__link,
#header-group .header-menu__link {
  opacity: 1 !important;
  font-weight: 700 !important;
  text-shadow: 0 1px 2px rgba(0,0,0,.4);
}
#header-group a:hover,
#header-group button:hover,
#header-group summary:hover,
#header-group .menu-list__link:hover,
#header-group .header-menu__link:hover {
  color: #ffb612 !important;
}
#header-group [class*="announcement"],
#header-group aside,
#header-group aside a {
  background: #050505 !important;
  color: #ffb612 !important;
}
footer .yg-footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .65rem 1.1rem;
  margin: 0;
}
footer .yg-footer-links a,
footer .yg-footer-contact a {
  color: #ffb612 !important;
  font-weight: 700;
  text-decoration: none;
}
footer .yg-footer-links a:hover,
footer .yg-footer-contact a:hover {
  text-decoration: underline;
}
footer .yg-footer-contact {
  margin: 0;
  color: rgba(255,255,255,.86);
}
footer .yg-payment-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .45rem;
  margin: 0;
}
footer .yg-payment-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 1.85rem;
  padding: .25rem .55rem;
  border-radius: .35rem;
  background: #ffffff;
  color: #111111;
  border: 1px solid rgba(255,182,18,.45);
  font-weight: 800;
  letter-spacing: .015em;
  box-shadow: 0 1px 0 rgba(255,255,255,.2);
}
@media (max-width: 749px) {
  #header-group .header__row { padding-block: .35rem !important; }
  #header-group .menu-list__link,
  #header-group .header-menu__link { font-size: .95rem !important; }
  footer .yg-footer-links { gap: .55rem .85rem; }
}
/* End Vern Horizon header/footer visibility fix */

/* Vern Horizon announcement/header/payment badge fix 2026-05-01 */
/* Announcement belongs above the nav and needs to look intentional. */
#shopify-section-sections--25911347544352__header_announcements_DBqWmm,
#header-group [id*="header_announcements"] {
  position: sticky !important;
  top: 0 !important;
  z-index: 1005 !important;
  background: #050505 !important;
  color: #ffb612 !important;
  display: block !important;
  visibility: visible !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slider,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slides,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slide,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm a {
  background: #050505 !important;
  color: #ffb612 !important;
  opacity: 1 !important;
  font-weight: 800 !important;
}
#shopify-section-sections--25911347544352__header_section {
  background: #050505 !important;
  color: #ffb612 !important;
  z-index: 1004 !important;
}
#shopify-section-sections--25911347544352__header_section .header,
#shopify-section-sections--25911347544352__header_section .header__row,
#shopify-section-sections--25911347544352__header_section .header__columns,
#shopify-section-sections--25911347544352__header_section .header__column,
#shopify-section-sections--25911347544352__header_section .header-menu,
#shopify-section-sections--25911347544352__header_section .header-actions,
#header-component {
  background: #050505 !important;
  color: #ffb612 !important;
  border: 0 !important;
  box-shadow: none !important;
}
#shopify-section-sections--25911347544352__header_section a,
#shopify-section-sections--25911347544352__header_section a:visited,
#shopify-section-sections--25911347544352__header_section button,
#shopify-section-sections--25911347544352__header_section summary,
#shopify-section-sections--25911347544352__header_section .menu-list__link,
#shopify-section-sections--25911347544352__header_section .header-menu__link,
#shopify-section-sections--25911347544352__header_section .header-actions__action,
#shopify-section-sections--25911347544352__header_section .account-button,
#shopify-section-sections--25911347544352__header_section .cart-icon,
#shopify-section-sections--25911347544352__header_section svg,
#shopify-section-sections--25911347544352__header_section svg * {
  color: #ffb612 !important;
  fill: currentColor !important;
  stroke: currentColor !important;
  opacity: 1 !important;
}
#shopify-section-sections--25911347544352__header_section .menu-list__link,
#shopify-section-sections--25911347544352__header_section .header-menu__link {
  font-weight: 800 !important;
  text-shadow: none !important;
}
#shopify-section-sections--25911347544352__header_section a:hover,
#shopify-section-sections--25911347544352__header_section button:hover,
#shopify-section-sections--25911347544352__header_section summary:hover {
  color: #ffffff !important;
}
.yg-payment-badges-section {
  background: #050505 !important;
  color: #ffffff !important;
  padding: 1.1rem 1rem .8rem !important;
  text-align: center !important;
}
.yg-payment-badges-inner {
  max-width: 1100px;
  margin: 0 auto;
}
.yg-payment-badges-title {
  margin: 0 0 .65rem;
  color: rgba(255,255,255,.82);
  font-size: .9rem;
  font-weight: 700;
}
.yg-payment-badges-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: .45rem .55rem;
  padding: 0;
  margin: 0;
  list-style: none;
}
.yg-payment-badge-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.6rem;
  height: 1.75rem;
  padding: .1rem .18rem;
  background: #fff;
  border-radius: .22rem;
  border: 1px solid rgba(255,182,18,.42);
  box-shadow: 0 1px 0 rgba(255,255,255,.18);
}
.yg-payment-icon {
  width: 38px;
  height: 24px;
  display: block;
}
@media (max-width: 749px) {
  #shopify-section-sections--25911347544352__header_section .menu-list__link,
  #shopify-section-sections--25911347544352__header_section .header-menu__link { font-size: .95rem !important; }
  .yg-payment-badges-section { padding-top: .9rem !important; }
  .yg-payment-badges-list { gap: .35rem; }
}
/* End Vern Horizon announcement/header/payment badge fix */

/* Vern Horizon announcement visibility hotfix 2026-05-01 */
/* Keep the shipping message readable in preview and customer view. Do not let sticky math clip it. */
#shopify-section-sections--25911347544352__header_announcements_DBqWmm {
  position: relative !important;
  top: auto !important;
  z-index: 1006 !important;
  min-height: 42px !important;
  background: #050505 !important;
  color: #ffb612 !important;
  display: block !important;
  overflow: visible !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar {
  min-height: 42px !important;
  padding-top: 10px !important;
  padding-bottom: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slider,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slides,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slide {
  min-height: 22px !important;
  height: auto !important;
  overflow: visible !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text {
  display: block !important;
  margin: 0 !important;
  line-height: 1.25 !important;
  color: #ffb612 !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
}
#shopify-section-sections--25911347544352__header_section h1,
#shopify-section-sections--25911347544352__header_section .header__heading,
#shopify-section-sections--25911347544352__header_section .header__heading-link {
  color: #ffb612 !important;
}
/* End Vern Horizon announcement visibility hotfix */

/* Vern Horizon announcement overlay hotfix 2026-05-01 */
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slide {
  position: relative !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text {
  position: relative !important;
  z-index: 2 !important;
  background: transparent !important;
  color: #ffb612 !important;
  text-shadow: 0 1px 1px rgba(0,0,0,.4) !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__link {
  background: transparent !important;
  color: transparent !important;
  z-index: 3 !important;
}
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__link .visually-hidden {
  background: transparent !important;
  color: transparent !important;
}
/* End Vern Horizon announcement overlay hotfix */

/* Vern Horizon readability/sticky/footer pass 2026-05-01 */
/* Header: keep logo/nav/icons visible after scroll. Announcement is top-of-page only so it does not cover products. */
#shopify-section-sections--25911347544352__header_announcements_DBqWmm {
  position: relative !important;
  top: auto !important;
  z-index: 1001 !important;
}
#shopify-section-sections--25911347544352__header_section {
  position: sticky !important;
  top: 0 !important;
  z-index: 1010 !important;
  min-height: 56px !important;
  background: #050505 !important;
  color: #ffb612 !important;
  overflow: visible !important;
}
#shopify-section-sections--25911347544352__header_section #header-component,
#shopify-section-sections--25911347544352__header_section .header,
#shopify-section-sections--25911347544352__header_section .header__row,
#shopify-section-sections--25911347544352__header_section .header__columns,
#shopify-section-sections--25911347544352__header_section .header__column,
#shopify-section-sections--25911347544352__header_section .header-logo,
#shopify-section-sections--25911347544352__header_section .header-menu,
#shopify-section-sections--25911347544352__header_section .header-actions {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  clip-path: none !important;
  overflow: visible !important;
  background: #050505 !important;
  color: #ffb612 !important;
}
#shopify-section-sections--25911347544352__header_section .header-logo,
#shopify-section-sections--25911347544352__header_section .header-logo img,
#shopify-section-sections--25911347544352__header_section .header__heading-logo,
#shopify-section-sections--25911347544352__header_section .header-logo__image {
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  max-width: 44px !important;
  transform: none !important;
}
#shopify-section-sections--25911347544352__header_section a,
#shopify-section-sections--25911347544352__header_section a:visited,
#shopify-section-sections--25911347544352__header_section button,
#shopify-section-sections--25911347544352__header_section summary,
#shopify-section-sections--25911347544352__header_section .menu-list__link,
#shopify-section-sections--25911347544352__header_section .header-menu__link,
#shopify-section-sections--25911347544352__header_section .header-actions__action,
#shopify-section-sections--25911347544352__header_section svg,
#shopify-section-sections--25911347544352__header_section svg * {
  color: #ffb612 !important;
  fill: currentColor !important;
  stroke: currentColor !important;
  opacity: 1 !important;
  visibility: visible !important;
}
#shopify-section-sections--25911347544352__header_section .menu-list__link,
#shopify-section-sections--25911347544352__header_section .header-menu__link {
  font-weight: 800 !important;
  line-height: 1.25 !important;
}
#shopify-section-sections--25911347544352__header_section a:hover,
#shopify-section-sections--25911347544352__header_section button:hover,
#shopify-section-sections--25911347544352__header_section summary:hover {
  color: #ffffff !important;
}
/* Main content readability: gold is an accent, not body text on white. */
main .card__heading a,
main .card__information a,
main .product-card a,
main a.full-unstyled-link,
main .product-grid a:not(.button):not(.button-secondary),
main [class*="product"] a:not(.button):not(.button-secondary) {
  color: #151515 !important;
}
main .card__heading a:hover,
main .card__information a:hover,
main .product-card a:hover,
main a.full-unstyled-link:hover {
  color: #8a5a00 !important;
  text-decoration: underline !important;
}
main .price,
main .price * {
  color: #111111 !important;
}
/* Footer: black/gold hierarchy without gray mush. */
footer,
footer .section,
footer .color-scheme-5 {
  background: #050505 !important;
  color: #ffb612 !important;
}
footer h2,
footer h3,
footer .newsletter-form__field-wrapper,
footer .yg-payment-badges-title,
footer p,
footer li,
footer span,
footer .footer__content-bottom,
footer small {
  color: #ffb612 !important;
}
footer a,
footer a:visited,
footer button,
footer svg,
footer svg * {
  color: #ffb612 !important;
  fill: currentColor !important;
  stroke: currentColor !important;
}
footer a:hover,
footer button:hover {
  color: #ffffff !important;
}
footer input,
footer input::placeholder {
  color: #ffffff !important;
}
footer input {
  background: #111111 !important;
  border: 1px solid rgba(255,182,18,.65) !important;
}
footer .yg-footer-links,
footer .yg-footer-contact {
  color: #ffb612 !important;
  line-height: 1.55 !important;
}
footer .yg-footer-links a,
footer .yg-footer-contact a {
  color: #ffb612 !important;
  font-weight: 800 !important;
}
footer .yg-payment-badges-section {
  border-top: 1px solid rgba(255,182,18,.25) !important;
  border-bottom: 1px solid rgba(255,182,18,.25) !important;
}
footer .yg-payment-badge-item,
footer .yg-payment-badge-item svg,
footer .yg-payment-badge-item svg * {
  color: initial !important;
  fill: initial !important;
  stroke: initial !important;
}
/* End Vern Horizon readability/sticky/footer pass */

/* Vern Horizon hidden mega-menu repair 2026-05-01 */
/* Undo over-broad visibility rules inside closed Horizon mega menus. */
#shopify-section-sections--25911347544352__header_section .menu-list__submenu,
#shopify-section-sections--25911347544352__header_section .menu-list__submenu-inner,
#shopify-section-sections--25911347544352__header_section .mega-menu,
#shopify-section-sections--25911347544352__header_section .mega-menu__grid,
#shopify-section-sections--25911347544352__header_section .mega-menu__list,
#shopify-section-sections--25911347544352__header_section .mega-menu__column,
#shopify-section-sections--25911347544352__header_section .mega-menu__link {
  visibility: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .menu-list__submenu,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .menu-list__submenu-inner,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .mega-menu,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .mega-menu__grid,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .mega-menu__list,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .mega-menu__column,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .mega-menu__link,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .menu-list__submenu,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .menu-list__submenu-inner,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .mega-menu,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .mega-menu__grid,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .mega-menu__list,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .mega-menu__column,
#shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .mega-menu__link {
  visibility: visible !important;
  opacity: 1 !important;
  pointer-events: auto !important;
}
/* End Vern Horizon hidden mega-menu repair */

/* Vern Horizon footer gold specific hotfix 2026-05-01 */
/* Horizon footer sections are not wrapped in a footer tag, so target the section group IDs/classes directly. */
.shopify-section-group-footer-group,
.shopify-section-group-footer-group .section,
.shopify-section-group-footer-group .section-background,
[id*="__migrated_footer_content"],
[id*="__footer_utilities"],
[id*="__vern_payment_badges"] {
  background: #050505 !important;
  color: #ffb612 !important;
}
.shopify-section-group-footer-group h1,
.shopify-section-group-footer-group h2,
.shopify-section-group-footer-group h3,
.shopify-section-group-footer-group p,
.shopify-section-group-footer-group span,
.shopify-section-group-footer-group div,
.shopify-section-group-footer-group small,
.shopify-section-group-footer-group rte-formatter,
.shopify-section-group-footer-group .rte,
.shopify-section-group-footer-group .text-block,
.shopify-section-group-footer-group .footer-utilities__text,
.shopify-section-group-footer-group .footer-utilities__policy-list,
.shopify-section-group-footer-group .footer-utilities__group-copyright,
.shopify-section-group-footer-group .social-icons__wrapper {
  color: #ffb612 !important;
}
.shopify-section-group-footer-group a,
.shopify-section-group-footer-group a:visited,
.shopify-section-group-footer-group button,
.shopify-section-group-footer-group svg,
.shopify-section-group-footer-group svg * {
  color: #ffb612 !important;
  fill: currentColor !important;
  stroke: currentColor !important;
}
.shopify-section-group-footer-group a:hover,
.shopify-section-group-footer-group button:hover {
  color: #ffffff !important;
}
.shopify-section-group-footer-group input,
.shopify-section-group-footer-group input::placeholder {
  color: #ffffff !important;
}
.shopify-section-group-footer-group input {
  background: #111111 !important;
  border: 1px solid rgba(255,182,18,.72) !important;
}
.shopify-section-group-footer-group .yg-payment-badge-item,
.shopify-section-group-footer-group .yg-payment-badge-item svg,
.shopify-section-group-footer-group .yg-payment-badge-item svg * {
  color: initial !important;
  fill: initial !important;
  stroke: initial !important;
}
/* End Vern Horizon footer gold specific hotfix */

/* Vern Horizon payment icon color restore 2026-05-01 */
/* Keep footer text gold, but let Shopify payment SVGs use their own brand fills. */
.shopify-section-group-footer-group .yg-payment-badge-item,
.shopify-section-group-footer-group .yg-payment-badge-item * {
  color: revert !important;
  fill: revert !important;
  stroke: revert !important;
}
.shopify-section-group-footer-group .yg-payment-icon,
.shopify-section-group-footer-group .yg-payment-icon * {
  color: revert !important;
  fill: revert !important;
  stroke: revert !important;
}
.shopify-section-group-footer-group .yg-payment-icon .icon__fallback-text {
  color: #111111 !important;
}
/* End Vern Horizon payment icon color restore */

/* Vern Horizon payment SVG fill map 2026-05-01 */
/* Restore brand colors for Shopify payment SVG paths after footer color overrides. */
.shopify-section-group-footer-group .yg-payment-icon [fill="#000"] { fill: #000 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#003087"] { fill: #003087 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#006FCF"] { fill: #006FCF !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#012169"] { fill: #012169 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#142688"] { fill: #142688 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#231F20"] { fill: #231F20 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#3086C8"] { fill: #3086C8 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#34A853"] { fill: #34A853 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#4285F4"] { fill: #4285F4 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#5A31F4"] { fill: #5A31F4 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#5F6368"] { fill: #5F6368 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#EA4335"] { fill: #EA4335 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#EB001B"] { fill: #EB001B !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#F48120"] { fill: #F48120 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#F79E1B"] { fill: #F79E1B !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#FBBC04"] { fill: #FBBC04 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#FF5F00"] { fill: #FF5F00 !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#FFF"] { fill: #FFF !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill="#fff"] { fill: #fff !important; }
.shopify-section-group-footer-group .yg-payment-icon [fill^="url("] { fill: inherit !important; }
.shopify-section-group-footer-group .yg-payment-badge-item { background: #ffffff !important; }
/* End Vern Horizon payment SVG fill map */

/* Vern Horizon mobile overflow overlay fix 2026-05-01 */
@media screen and (max-width: 989px) {
  html,
  body {
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  #shopify-section-header-group,
  .shopify-section-group-header-group,
  header-component,
  .header,
  main,
  .content-for-layout {
    max-width: 100vw !important;
    overflow-x: clip !important;
  }

  /* Horizon adds a second mobile horizontal nav row under the main header.
     At half-width it creates page-level horizontal scrolling, which makes
     offscreen links like Best Sellers / Blog appear over product cards. */
  .header__row--mobile .menu-list--mobile,
  .header__row--mobile .menu-list__scroll-container,
  .header__row--mobile .menu-list__list {
    display: none !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .header__row--mobile {
    display: none !important;
  }

  .menu-drawer-container:not([open]) .menu-drawer,
  details.menu-drawer-container:not([open]) .menu-drawer {
    visibility: hidden !important;
    pointer-events: none !important;
  }
}
/* End Vern Horizon mobile overflow overlay fix */

/* Vern Horizon sticky announcement/header repair 2026-05-01 */
:root {
  --yg-horizon-announcement-height: 34px;
}

/* Keep the Horizon announcement compact, centered, and one line. */
body .announcement-bar,
body .announcement-bar.spacing-style {
  min-height: var(--yg-horizon-announcement-height) !important;
  height: var(--yg-horizon-announcement-height) !important;
  max-height: var(--yg-horizon-announcement-height) !important;
  padding-block-start: 0 !important;
  padding-block-end: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

body .announcement-bar__slider,
body .announcement-bar__slides,
body .announcement-bar__slide,
body .announcement-bar__text,
body .announcement-bar__link {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  height: var(--yg-horizon-announcement-height) !important;
  min-height: var(--yg-horizon-announcement-height) !important;
  max-height: var(--yg-horizon-announcement-height) !important;
  line-height: var(--yg-horizon-announcement-height) !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: clip !important;
  text-align: center !important;
}

body .announcement-bar__text {
  font-size: clamp(12px, 3.15vw, 15px) !important;
  font-weight: 800 !important;
  margin: 0 !important;
}

/* The previous state had position: sticky without a usable top value, so both rows scrolled away. */
body .shopify-section-group-header-group:not(.header-section) {
  position: sticky !important;
  top: 0 !important;
  z-index: 10060 !important;
}

body .shopify-section-group-header-group.header-section {
  position: sticky !important;
  top: var(--yg-horizon-announcement-height) !important;
  z-index: 10055 !important;
}

body .header__row--top {
  min-height: 54px !important;
}

@media screen and (max-width: 749px) {
  :root { --yg-horizon-announcement-height: 30px; }
  body .announcement-bar__text { font-size: 12px !important; letter-spacing: 0 !important; }
  body .header__row--top { min-height: 52px !important; }
}

/* Keep the overflow fix active without hiding the real utility/mobile header row. */
html, body {
  max-width: 100% !important;
  overflow-x: clip !important;
}

/* Vern Horizon exact sticky header top override 2026-05-01 */
:root { --yg-horizon-announcement-height: 34px; }

#shopify-section-sections--25911347544352__header_announcements_DBqWmm,
#header-group [id*="header_announcements"] {
  position: sticky !important;
  top: 0 !important;
  z-index: 10120 !important;
  height: var(--yg-horizon-announcement-height) !important;
  min-height: var(--yg-horizon-announcement-height) !important;
  max-height: var(--yg-horizon-announcement-height) !important;
  overflow: hidden !important;
}

#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar,
#header-group [id*="header_announcements"] .announcement-bar {
  height: var(--yg-horizon-announcement-height) !important;
  min-height: var(--yg-horizon-announcement-height) !important;
  max-height: var(--yg-horizon-announcement-height) !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  align-items: center !important;
}

#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slider,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slides,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__slide,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text,
#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__link,
#header-group [id*="header_announcements"] .announcement-bar__slider,
#header-group [id*="header_announcements"] .announcement-bar__slides,
#header-group [id*="header_announcements"] .announcement-bar__slide,
#header-group [id*="header_announcements"] .announcement-bar__text,
#header-group [id*="header_announcements"] .announcement-bar__link {
  width: 100% !important;
  max-width: 100% !important;
  height: var(--yg-horizon-announcement-height) !important;
  min-height: var(--yg-horizon-announcement-height) !important;
  max-height: var(--yg-horizon-announcement-height) !important;
  line-height: var(--yg-horizon-announcement-height) !important;
  padding: 0 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-align: center !important;
}

#shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text,
#header-group [id*="header_announcements"] .announcement-bar__text {
  font-size: clamp(12px, 3.1vw, 15px) !important;
  font-weight: 800 !important;
}

#shopify-section-sections--25911347544352__header_section,
#header-group .header-section {
  position: sticky !important;
  top: var(--yg-horizon-announcement-height) !important;
  z-index: 10110 !important;
  min-height: 54px !important;
}

@media screen and (max-width: 749px) {
  :root { --yg-horizon-announcement-height: 30px; }
  #shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__text,
  #shopify-section-sections--25911347544352__header_announcements_DBqWmm .announcement-bar__link,
  #header-group [id*="header_announcements"] .announcement-bar__text,
  #header-group [id*="header_announcements"] .announcement-bar__link { font-size: 12px !important; letter-spacing: 0 !important; }
  #shopify-section-sections--25911347544352__header_section,
  #header-group .header-section { min-height: 52px !important; }
}

/* Vern Horizon closed drawer/sidebar leak fix 2026-05-01 */
@media screen and (max-width: 989px) {
  /* Keep the hamburger summary visible, but completely suppress the closed drawer.
     Horizon's closed mobile drawer was still laying out off-canvas menu items, which
     made the side/sidebar menu appear to leak over collection content at narrow widths. */
  #Details-menu-drawer-container:not([open]) .menu-drawer,
  #Details-menu-drawer-container:not([open]) .menu-drawer__navigation-container,
  #Details-menu-drawer-container:not([open]) .menu-drawer__inner-container,
  #Details-menu-drawer-container:not([open]) .menu-drawer__menu,
  #Details-menu-drawer-container:not([open]) .menu-drawer__utility-links,
  #Details-menu-drawer-container:not([open]) .menu-drawer__backdrop {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #Details-menu-drawer-container:not([open]) .menu-drawer {
    left: 0 !important;
    right: auto !important;
    width: min(92vw, 400px) !important;
    max-width: 400px !important;
    transform: translateX(-110%) !important;
    overflow: hidden !important;
  }

  #Details-menu-drawer-container:not([open]) .menu-drawer * {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #Details-menu-drawer-container:not([open]) .menu-drawer__backdrop {
    display: none !important;
  }

  #Details-menu-drawer-container[open] .menu-drawer {
    visibility: visible !important;
    opacity: 1 !important;
    left: 0 !important;
    right: auto !important;
    width: min(92vw, 400px) !important;
    max-width: 400px !important;
    transform: translateX(0) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    pointer-events: auto !important;
  }

  #Details-menu-drawer-container[open] .menu-drawer__navigation-container,
  #Details-menu-drawer-container[open] .menu-drawer__inner-container,
  #Details-menu-drawer-container[open] .menu-drawer__menu,
  #Details-menu-drawer-container[open] .menu-drawer__utility-links {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #Details-menu-drawer-container[open] .menu-drawer * {
    visibility: visible !important;
    opacity: 1 !important;
  }

  /* Closed collection/facet drawers should not leave invisible side panels either. */
  details:not([open]) .facets__display,
  details:not([open]) .facets-drawer,
  details:not([open]) .facets__drawer,
  details:not([open]) .facets__panel,
  details:not([open]) .facets__overlay {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateX(-110%) !important;
  }
}

/* Vern Horizon closed drawer hard display fix 2026-05-01 */
@media screen and (max-width: 989px) {
  /* Hard stop for the blank/off-canvas sidebar body after the menu closes. */
  details#Details-menu-drawer-container.menu-drawer-container:not([open]) > .menu-drawer,
  details#Details-menu-drawer-container.menu-drawer-container:not([open]) > .menu-drawer__backdrop,
  details#Details-menu-drawer-container.menu-drawer-container:not([open]) .menu-drawer {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transform: translateX(-120%) !important;
  }

  details#Details-menu-drawer-container.menu-drawer-container[open] > .menu-drawer,
  details#Details-menu-drawer-container.menu-drawer-container[open] .menu-drawer {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    transform: translateX(0) !important;
    left: 0 !important;
    right: auto !important;
    width: min(92vw, 400px) !important;
    max-width: 400px !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  details#Details-menu-drawer-container.menu-drawer-container:not([open]) .menu-drawer__backdrop {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
}

/* Vern Horizon mobile hero/product-card polish 2026-05-01 */
@media screen and (max-width: 749px) {
  /* Keep the homepage hero punchy without letting the H1 become a wall on phones. */
  .hero-wrapper h1,
  .hero h1 {
    font-size: clamp(2rem, 11vw, 3.15rem) !important;
    line-height: .98 !important;
    letter-spacing: -0.035em !important;
  }

  .hero-wrapper .section,
  .hero-wrapper.section-wrapper {
    --section-min-height: auto;
  }

  /* Horizon product cards expose long Shopify/Etsy titles. Clamp visible card titles
     while leaving links, product pages, SEO titles, and accessibility text intact. */
  product-card .text-block[class*="product_title"] p,
  product-card .text-block[class*="product-title"] p,
  product-card .text-block.h5 p,
  product-card .product-card__content .text-block p {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    line-height: 1.18 !important;
    font-size: .92rem !important;
    margin-block: 0 !important;
  }

  product-card .product-card__content {
    gap: 6px !important;
  }
}

@media screen and (min-width: 750px) {
  product-card .text-block[class*="product_title"] p,
  product-card .text-block[class*="product-title"] p,
  product-card .text-block.h5 p,
  product-card .product-card__content .text-block p {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    line-height: 1.2 !important;
  }
}

/* Vern Horizon product swatch selected state 2026-05-01 */
.variant-picker fieldset.variant-option--swatches .variant-option__button-label {
  position: relative;
}

.variant-picker fieldset.variant-option--swatches .variant-option__button-label .swatch {
  box-shadow: 0 0 0 1px rgba(0, 0, 0, .22);
}

.variant-picker fieldset.variant-option--swatches .variant-option__button-label:has(input:checked) .swatch {
  box-shadow:
    0 0 0 2px #f3c21b,
    0 0 0 4px #111111 !important;
}

.variant-picker fieldset.variant-option--swatches .variant-option__button-label:focus-within .swatch {
  outline: 2px solid #f3c21b;
  outline-offset: 4px;
}

/* Vern Horizon half-screen desktop menu leak fix 2026-05-01 */
@media screen and (max-width: 1199px) {
  /* At half-width desktop windows, Horizon can keep desktop nav text alive even when the layout is too narrow.
     Force this range to use the drawer/header controls and fully suppress desktop/mega menu text. */
  #shopify-section-sections--25911347544352__header_section header-menu,
  #shopify-section-sections--25911347544352__header_section .header-menu,
  #shopify-section-sections--25911347544352__header_section .header__column--center,
  #shopify-section-sections--25911347544352__header_section .menu-list,
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item,
  #shopify-section-sections--25911347544352__header_section .menu-list__link,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .mega-menu,
  #shopify-section-sections--25911347544352__header_section .mega-menu__grid,
  #shopify-section-sections--25911347544352__header_section .mega-menu__list,
  #shopify-section-sections--25911347544352__header_section .mega-menu__link,
  #shopify-section-sections--25911347544352__header_section .mega-menu__link-title {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
    transform: none !important;
  }

  #shopify-section-sections--25911347544352__header_section .header__drawer,
  #shopify-section-sections--25911347544352__header_section header-drawer,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container > summary {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #shopify-section-sections--25911347544352__header_section .header__columns {
    grid-template-columns: auto 1fr auto !important;
    align-items: center !important;
    overflow: hidden !important;
  }

  #shopify-section-sections--25911347544352__header_section .header__row,
  #shopify-section-sections--25911347544352__header_section .header__columns,
  #shopify-section-sections--25911347544352__header_section .header__column {
    max-width: 100vw !important;
  }

  html, body {
    overflow-x: clip !important;
  }
}

/* Vern Horizon half-screen closed drawer child leak fix 2026-05-01 */
@media screen and (max-width: 1199px) {
  /* The 990-1199px half-desktop range can keep the mobile drawer subtree measurable/off-canvas.
     When the drawer is closed, hide the drawer and every child so links like Best Sellers/Blog cannot bleed into collection cards. */
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer *,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer__navigation,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer__menu,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer__menu-item,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container:not([open]) .menu-drawer__menu-item-text {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
    width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    max-height: 0 !important;
    overflow: hidden !important;
    left: auto !important;
    right: auto !important;
    transform: none !important;
    clip-path: inset(50%) !important;
  }

  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer {
    display: grid !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    width: min(92vw, 390px) !important;
    max-width: min(92vw, 390px) !important;
    height: auto !important;
    max-height: calc(100vh - 86px) !important;
    overflow-y: auto !important;
    clip-path: none !important;
  }
}

/* Vern Horizon mobile header logo center fix 2026-05-01 */
@media screen and (max-width: 989px) {
  /* Make mobile header feel intentional: menu/search left, centered logo, account/cart right. */
  #shopify-section-sections--25911347544352__header_section .header__row--top .header__columns {
    position: relative !important;
    min-height: 52px !important;
    display: grid !important;
    grid-template-columns: 44px 44px 1fr 44px 44px !important;
    align-items: center !important;
    width: 100% !important;
  }

  #shopify-section-sections--25911347544352__header_section .header__drawer,
  #shopify-section-sections--25911347544352__header_section .header__icon--menu {
    grid-column: 1 !important;
    justify-self: start !important;
  }

  #shopify-section-sections--25911347544352__header_section .search-action.desktop\:hidden,
  #shopify-section-sections--25911347544352__header_section search-button.search-action.desktop\:hidden {
    grid-column: 2 !important;
    justify-self: start !important;
  }

  #shopify-section-sections--25911347544352__header_section .header-logo {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
    z-index: 3 !important;
    width: 42px !important;
    height: 42px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  #shopify-section-sections--25911347544352__header_section .header-logo img,
  #shopify-section-sections--25911347544352__header_section .header-logo svg {
    max-width: 42px !important;
    max-height: 42px !important;
    object-fit: contain !important;
  }

  #shopify-section-sections--25911347544352__header_section .account-drawer {
    grid-column: 4 !important;
    justify-self: end !important;
  }

  #shopify-section-sections--25911347544352__header_section .cart-drawer {
    grid-column: 5 !important;
    justify-self: end !important;
  }

  #shopify-section-sections--25911347544352__header_section .header-actions__action,
  #shopify-section-sections--25911347544352__header_section .header__icon--menu {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
  }
}


/* removed stale logo override: /* Vern Horizon desktop wide transparent logo 2026-05-01 */ */


/* removed stale logo override: /* Vern Horizon exact desktop wide transparent logo override 2026-05-01 */ */


/* removed stale logo override: /* Vern Horizon desktop logo header height containment 2026-05-01 */ */


/* removed stale logo override: /* Vern Horizon compact full lockup logo override 2026-05-01 */ */


/* removed stale logo override: /* Vern Horizon compact full-lockup logo downsize 2026-05-01 */ */


/* Vern Horizon mobile product card readability 2026-05-01 */
@media screen and (max-width: 749px) {
  main .text-block.h1 p {
    max-width: 100% !important;
    font-size: clamp(2rem, 10vw, 2.5rem) !important;
    line-height: 1 !important;
    overflow-wrap: normal !important;
  }

  .product-grid {
    column-gap: 12px !important;
    row-gap: 22px !important;
  }

  .product-grid__item product-card,
  .product-grid__item .product-card {
    min-height: 100%;
  }

  .product-grid__item .product-card__content {
    border-radius: 10px;
  }

  .product-grid__item .text-block p,
  .product-grid__item .text-block,
  .product-grid__item .product-card h3,
  .product-grid__item .product-card .h4 {
    font-size: 0.95rem !important;
    line-height: 1.24 !important;
    letter-spacing: 0 !important;
  }

  .product-grid__item .text-block p,
  .product-grid__item .product-card h3 {
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }

  .product-grid__item .price,
  .product-grid__item .price * {
    font-size: 0.92rem !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
  }

  .product-grid__item quick-add-component button,
  .product-grid__item .quick-add__button,
  .product-grid__item button[aria-label*="Add"],
  .product-grid__item button:has(svg) {
    min-width: 40px !important;
    min-height: 40px !important;
  }
}

@media screen and (max-width: 340px) {
  .product-grid {
    grid-template-columns: 1fr !important;
  }
}
/* End Vern Horizon mobile product card readability 2026-05-01 */
/* Vern Horizon collection page padding fix 2026-05-01 */
/* Collection pages were letting the SEO cross-link band hug the viewport edge on
   wide screens. Keep the section compact, but align it with the collection hero
   and product grid gutters. */
.yg-collection-seo-support {
  overflow-x: clip;
}

.yg-collection-seo-support__inner.page-width {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: none !important;
  margin-inline: auto !important;
  padding: clamp(22px, 2.2vw, 34px) clamp(24px, 3.333vw, 80px) !important;
}

.yg-collection-seo-support__copy {
  max-width: 58rem;
}

.yg-collection-seo-support__links {
  padding-inline: 0 !important;
}

.product-grid-container .collection-wrapper {
  box-sizing: border-box;
  padding-inline: 0;
}

@media screen and (min-width: 750px) {
  .yg-collection-seo-support__inner.page-width {
    align-items: center;
    column-gap: clamp(28px, 4vw, 72px) !important;
  }
}

@media screen and (min-width: 750px) and (max-width: 989px) {
  .yg-collection-seo-support__inner.page-width {
    align-items: start;
    grid-template-columns: 1fr !important;
    row-gap: 16px !important;
  }

  .yg-collection-seo-support__links {
    flex-wrap: wrap !important;
    overflow-x: visible !important;
    justify-content: flex-start !important;
    gap: 9px !important;
  }

  .yg-collection-seo-support__links a {
    padding: 8px 12px !important;
  }
}

@media screen and (max-width: 749px) {
  .yg-collection-seo-support__inner.page-width {
    padding: 18px 18px 20px !important;
    gap: 14px !important;
  }

  .yg-collection-seo-support__links {
    justify-content: flex-start !important;
    gap: 8px !important;
  }

  .yg-collection-seo-support__links a {
    padding: 7px 11px !important;
  }
}


/* Vern Horizon desktop mega menu usability fix 2026-05-01 */
@media screen and (min-width: 990px) {
  header-menu .menu-list__submenu {
    max-height: min(44vh, 240px);
    overflow-y: auto;
    overscroll-behavior: contain;
    box-shadow: 0 18px 32px rgba(0, 0, 0, 0.18);
  }
  header-menu .mega-menu,
  header-menu .mega-menu__grid,
  header-menu .mega-menu__list {
    max-height: 240px;
  }
  header-menu .mega-menu__list {
    overflow-y: auto;
    padding-block-end: 16px;
  }
  header-menu .menu-list__submenu::-webkit-scrollbar,
  header-menu .mega-menu__list::-webkit-scrollbar {
    width: 8px;
  }
  header-menu .menu-list__submenu::-webkit-scrollbar-thumb,
  header-menu .mega-menu__list::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.28);
    border-radius: 999px;
  }
}

/* Vern Horizon buyer-intent mega menu readability 2026-05-02 */
@media screen and (min-width: 1200px) {
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu-inner,
  #shopify-section-sections--25911347544352__header_section .mega-menu {
    background: #070707 !important;
    border-top: 1px solid rgba(243, 194, 27, .32) !important;
    box-shadow: 0 18px 34px rgba(0, 0, 0, .38) !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu__list {
    gap: clamp(18px, 2.2vw, 34px) !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu__link,
  #shopify-section-sections--25911347544352__header_section .mega-menu__link-title,
  #shopify-section-sections--25911347544352__header_section .mega-menu a {
    color: #f7f1df !important;
    text-decoration-color: rgba(243, 194, 27, .55) !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu__link[aria-current='page'],
  #shopify-section-sections--25911347544352__header_section .mega-menu__link:hover,
  #shopify-section-sections--25911347544352__header_section .mega-menu a:hover {
    color: #ffd84d !important;
    text-decoration-color: #ffd84d !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu__link--parent,
  #shopify-section-sections--25911347544352__header_section .mega-menu__link--parent .mega-menu__link-title,
  #shopify-section-sections--25911347544352__header_section .mega-menu__column > .mega-menu__link:first-child,
  #shopify-section-sections--25911347544352__header_section .mega-menu__column > a:first-child {
    color: #f3c21b !important;
    font-weight: 800 !important;
    letter-spacing: .02em !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu .resource-card,
  #shopify-section-sections--25911347544352__header_section .mega-menu .collection-card,
  #shopify-section-sections--25911347544352__header_section .mega-menu .product-card {
    background: #111111 !important;
    border: 1px solid rgba(243, 194, 27, .34) !important;
    border-radius: 14px !important;
    overflow: hidden !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu .resource-card a,
  #shopify-section-sections--25911347544352__header_section .mega-menu .collection-card a,
  #shopify-section-sections--25911347544352__header_section .mega-menu .product-card a {
    color: #ffffff !important;
  }

  #shopify-section-sections--25911347544352__header_section .mega-menu img {
    opacity: 1 !important;
    filter: none !important;
  }
}
/* End Vern Horizon buyer-intent mega menu readability 2026-05-02 */

/* Vern Horizon mobile drawer launch polish 2026-05-02 */
@media screen and (max-width: 749px) {
  /* Use the whole phone viewport for the hamburger drawer so account/cart/page content do not peek through beside it. */
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer {
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: calc(100vh - 34px) !important;
    max-height: calc(100vh - 34px) !important;
    left: 0 !important;
    right: 0 !important;
    border-right: 0 !important;
    box-shadow: none !important;
    background: #070707 !important;
  }

  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer__navigation-container,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer__navigation {
    width: 100% !important;
    max-width: 100% !important;
  }

  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer a,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer button,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer summary {
    min-height: 46px !important;
  }
}

/* Vern Horizon mobile nested drawer visibility fix 2026-05-02 */
@media screen and (max-width: 749px) {
  /* Earlier leak fixes made all drawer descendants visible. Restore Horizon's intended nested behavior:
     closed submenu panels stay hidden, while the active/open submenu remains readable. */
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer details:not([open]) > .menu-drawer__submenu,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer details:not([open]) > .menu-drawer__submenu * {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer details[open] > .menu-drawer__submenu,
  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer details[open] > .menu-drawer__submenu > .menu-drawer__inner-submenu {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #shopify-section-sections--25911347544352__header_section #Details-menu-drawer-container[open] .menu-drawer .menu-drawer__submenu {
    background: #070707 !important;
  }
}

/* Vern Horizon closed mega-menu descendant hide fix 2026-05-02 */
@media screen and (min-width: 1200px) {
  /* Hide every descendant inside closed dropdowns. Featured collection cards were still measurable/visible
     below the header before hover after switching Horizon to featured_collections mega menus. */
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:not(:hover):not(:focus-within) .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:not(:hover):not(:focus-within) .menu-list__submenu * {
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:hover .menu-list__submenu *,
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:focus-within .menu-list__submenu * {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }
}


/* VERN-YG-HORIZON-COMPACT-HEADER 2026-05-04 */
@media screen and (min-width: 750px) {
  #header-component.header--compact .header__columns {
    padding-block-start: 0 !important;
    padding-block-end: 0 !important;
    min-height: 78px !important;
    align-items: center !important;
  }

  #header-component.header--compact .header__row,
  #header-component.header--compact .header__row--top {
    min-height: 78px !important;
  }

  #header-component.header--compact .header-logo,
  #header-component.header--compact .header-logo__image-container,
  #header-component.header--compact .header-logo__image {
    max-height: 72px !important;
    height: auto !important;
  }

  #header-component.header--compact .header-logo__image {
    width: auto !important;
    max-width: 150px !important;
    object-fit: contain !important;
  }

  #header-component.header--compact .menu-list__link,
  #header-component.header--compact nav a {
    font-size: clamp(15px, 1vw, 18px) !important;
    line-height: 1.15 !important;
  }
}

@media screen and (max-width: 749px) {
  #header-component.header--compact .header-logo,
  #header-component.header--compact .header-logo__image-container,
  #header-component.header--compact .header-logo__image {
    max-height: 44px !important;
    height: auto !important;
  }

  #header-component.header--compact .header-logo__image {
    width: auto !important;
    max-width: 104px !important;
    object-fit: contain !important;
  }
}
/* END VERN-YG-HORIZON-COMPACT-HEADER */

/* Vern live Horizon mobile width polish 2026-05-11 */
@media screen and (max-width: 749px) {
  html, body { width: 100% !important; max-width: 100% !important; overflow-x: hidden !important; }
  body { align-items: stretch !important; }
  body > .content-for-layout,
  body > .shopify-section-group-footer-group,
  .content-for-layout > .shopify-section,
  .shopify-section-group-header-group,
  .shopify-section-group-header-group header,
  .shopify-section-group-header-group header-component {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  .announcement-bar,
  .announcement-bar__message,
  .announcement-bar a {
    font-size: 1.15rem !important;
    line-height: 1.2 !important;
    letter-spacing: .01em !important;
    white-space: nowrap !important;
  }
  .yg-motion-hero,
  .yg-motion-hero__art,
  .yg-motion-hero__shade { width: 100vw !important; max-width: 100vw !important; }
  .yg-motion-hero__inner.page-width {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box !important;
  }
  .section-resource-list__header {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
  .section-resource-list__header rte-formatter,
  .section-resource-list__header .text-block { width: 100% !important; max-width: 100% !important; }
  .resource-list.resource-list--grid { width: 100% !important; max-width: 100% !important; }
  product-card.product-card { min-width: 0 !important; }
  .product-card .text-block,
  .product-card [class*='product_title'] {
    font-size: 1.25rem !important;
    line-height: 1.25 !important;
    overflow-wrap: anywhere !important;
  }
}

/* removed stale mobile transparent-logo override 2026-05-22 */

/* VERN-YG-CHOOSE-OPTIONS-PILL 2026-05-11 */
/* Make desktop collection quick actions read like competitor-style buttons, not mystery icons. */
@media screen and (min-width: 750px) {
  .product-card .card-gallery:hover .quick-add__button,
  .product-card .quick-add__button:is(:focus, :hover) {
    border-radius: 999px !important;
    padding: var(--padding-xs) var(--padding-sm) !important;
    min-width: max-content !important;
  }

  .product-card .card-gallery:hover .quick-add__button .add-to-cart-text,
  .product-card .quick-add__button:is(:focus, :hover) .add-to-cart-text {
    gap: var(--gap-2xs) !important;
    margin-inline: 0 !important;
    padding-inline: 0 !important;
  }

  .product-card .card-gallery:hover .quick-add__button .add-to-cart-text__content,
  .product-card .quick-add__button:is(:focus, :hover) .add-to-cart-text__content {
    width: fit-content !important;
    max-width: 12rem !important;
    opacity: 1 !important;
    transform: translateX(0) !important;
    white-space: nowrap !important;
  }
}
/* END VERN-YG-CHOOSE-OPTIONS-PILL */



/* Vern polish 2026-05-11: contain animated hero SVG so it cannot create desktop horizontal scroll. */
html,
body {
  overflow-x: clip;
}

.yg-motion-hero,
.yg-motion-hero__art,
.yg-motion-hero__svg {
  overflow: hidden;
  contain: paint;
  max-width: 100vw;
}


/* Vern defensive homepage polish 20260511-190442: handles Shopify stale public HTML variants. */
html, body {
  max-width: 100%;
  overflow-x: hidden !important;
}
#MainContent,
.shopify-section,
.section,
.yg-motion-hero,
.yg-motion-hero__art,
.yg-motion-hero__svg,
svg {
  max-width: 100vw;
}
.yg-motion-hero,
.yg-motion-hero__art {
  overflow: hidden !important;
  contain: paint;
}
.yg-path-card[href*="holiday-pittsburgh-gifts"] {
  display: none !important;
}
.yg-path-grid {
  grid-auto-flow: row;
}
@media (min-width: 750px) {
  .yg-path-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 749px) {
  .yg-path-grid { grid-template-columns: 1fr !important; }
}

/* Vern desktop header overflow slot/menu leak fix 2026-05-12 */
@media screen and (min-width: 990px) {
  /* Horizon's overflow-list can leave slotted overflow links measurable at x=40
     even when the More menu is closed. Hide hidden overflow slots and the empty
     More trigger on desktop so Best Sellers / Blog cannot bleed over the hero. */
  header-menu overflow-list > li[slot="overflow"],
  header-menu overflow-list > li[slot="more"] {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  /* Closed mega-menu panels should not be visible until their parent top-level
     item is hovered or keyboard-focused. */
  header-menu .menu-list__list-item:not(:hover):not(:focus-within) > .menu-list__submenu {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }
}

/* Vern mobile/tablet homepage polish */
@media screen and (max-width: 989px) {
  .yg-motion-hero__inner.page-width {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    padding-left: clamp(20px, 6vw, 40px) !important;
    padding-right: clamp(20px, 6vw, 40px) !important;
  }
  .yg-motion-hero__inner.page-width > * {
    max-width: 100%;
  }
}
@media screen and (min-width: 750px) and (max-width: 989px) {
  .yg-motion-hero__inner.page-width {
    padding-left: 40px !important;
    padding-right: 40px !important;
  }
}
@media screen and (max-width: 749px) {
  .yg-motion-hero__inner.page-width {
    padding-left: 22px !important;
    padding-right: 22px !important;
  }
  .section-header a[href*="summer-pittsburgh-picks"],
  .section-header a[href*="yinzergear-best-sellers"],
  .collection__view-all a[href*="summer-pittsburgh-picks"] {
    font-size: 1.2rem;
    line-height: 1.2;
  }
}

/* VERN-YG-MENU-USABILITY-FIX 2026-05-19 */
@media screen and (min-width: 1200px) {
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item {
    position: relative;
  }

  /* Invisible hover bridge between nav item and absolute dropdown. */
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item:has(.menu-list__submenu)::after {
    content: '';
    position: absolute;
    left: -18px;
    right: -18px;
    top: 100%;
    height: 28px;
    z-index: 6;
    pointer-events: auto;
  }

  /* Use Horizon's active/expanded state, not only fragile :hover. */
  #shopify-section-sections--25911347544352__header_section .menu-list__link[aria-expanded='true'] + .menu-list__submenu,
  #shopify-section-sections--25911347544352__header_section .menu-list__link[aria-expanded='true'] + .menu-list__submenu *,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu:hover,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu:hover *,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu:focus-within,
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu:focus-within * {
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #shopify-section-sections--25911347544352__header_section header-menu[aria-expanded='true'] {
    --submenu-opacity: 1 !important;
  }
}
/* END VERN-YG-MENU-USABILITY-FIX 2026-05-19 */


/* VERN-YG-PRODUCT-GALLERY-CLEANUP 2026-05-19 */
@media screen and (min-width: 990px) {
  .product-information__media .media-gallery--carousel {
    max-width: min(680px, 48vw);
    margin-inline: auto;
  }
  .product-information__media .product-media-container {
    border-radius: 12px !important;
    overflow: hidden;
    background: #f7f4ea;
  }
  .product-information__media .product-media__image {
    object-fit: contain !important;
  }
  .product-information__media .slideshow-controls,
  .product-information__media .thumbnail-list,
  .product-information__media [class*='thumbnail'] {
    max-width: 100%;
  }
}
@media screen and (max-width: 989px) {
  .product-information__media .product-media-container {
    border-radius: 10px !important;
    overflow: hidden;
  }
}
/* END VERN-YG-PRODUCT-GALLERY-CLEANUP 2026-05-19 */


/* VERN-YG-PDP-VARIANT-GRID 2026-05-19 */
/* Keep apparel product pages shoppable above the fold: sizes should scan as a grid, not a 9-row form wall. */
.product-details .variant-option--equal-width-buttons:not(.variant-option--swatches) {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px !important;
}
.product-details .variant-option--equal-width-buttons:not(.variant-option--swatches) > legend {
  grid-column: 1 / -1;
  margin-bottom: 2px;
}
.product-details .variant-option--equal-width-buttons:not(.variant-option--swatches) .variant-option__button-label {
  width: auto !important;
  min-width: 0 !important;
  min-height: 42px !important;
  padding: 10px 12px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 420px) {
  .product-details .variant-option--equal-width-buttons:not(.variant-option--swatches) {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px !important;
  }
  .product-details .variant-option--equal-width-buttons:not(.variant-option--swatches) .variant-option__button-label {
    min-height: 40px !important;
    padding-inline: 8px !important;
  }
}
/* END VERN-YG-PDP-VARIANT-GRID 2026-05-19 */


/* VERN-YG-DESKTOP-NAV-DROPDOWN-WIDTH-FIX 2026-05-19 */
@media screen and (min-width: 1200px) {
  /* Previous hover-bridge patch made the submenu relative to the top-level item,
     but Horizon then inherited that narrow item width. Keep the dropdown open
     without compressing submenu links into one-letter columns. */
  #shopify-section-sections--25911347544352__header_section .menu-list__list-item > .menu-list__submenu {
    width: max-content !important;
    min-width: 280px !important;
    max-width: min(360px, calc(100vw - 48px)) !important;
    overflow: visible !important;
  }
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu-inner,
  #shopify-section-sections--25911347544352__header_section .mega-menu,
  #shopify-section-sections--25911347544352__header_section .mega-menu__grid,
  #shopify-section-sections--25911347544352__header_section .mega-menu__list,
  #shopify-section-sections--25911347544352__header_section .mega-menu__column {
    width: max-content !important;
    min-width: 280px !important;
    max-width: min(360px, calc(100vw - 48px)) !important;
    overflow: visible !important;
  }
  #shopify-section-sections--25911347544352__header_section .menu-list__submenu a,
  #shopify-section-sections--25911347544352__header_section .mega-menu__link {
    display: flex !important;
    width: auto !important;
    min-width: 220px !important;
    max-width: 320px !important;
    white-space: normal !important;
    line-height: 1.25 !important;
  }
}
/* END VERN-YG-DESKTOP-NAV-DROPDOWN-WIDTH-FIX 2026-05-19 */

/* VERN-YG-WIDTH-LOGO-REPAIR 2026-05-22: generic Shopify header/width lock, no generated section-id dependency. */
html,
body,
#MainContent,
.content-for-layout,
#header-group,
#header-group .shopify-section,
#header-component,
.header,
.header__row,
.header__columns,
main,
footer,
.shopify-section {
  width: 100% !important;
  max-width: none !important;
  box-sizing: border-box !important;
}
body {
  margin: 0 !important;
  overflow-x: clip !important;
}
#MainContent,
.content-for-layout,
main {
  display: block !important;
}
.yg-motion-hero,
.yg-sales-proofbar,
.ui-test-product-list,
.yg-paths,
footer {
  inline-size: 100% !important;
  width: 100% !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
#header-group #header-component,
#header-group .header__row,
#header-group .header__columns {
  min-height: 76px !important;
}
@media screen and (max-width: 749px) {
  #header-group #header-component,
  #header-group .header__row,
  #header-group .header__columns {
    min-height: 58px !important;
  }
}
/* End VERN-YG-WIDTH-LOGO-REPAIR 2026-05-22 */

/* VERN-YG-BACKUP-SALES-REDESIGN-QA 2026-05-22
   Generic selectors only: keep the backup and live header logo/menu stable even when Shopify regenerates section IDs. */
html,
body {
  max-width: 100% !important;
  overflow-x: clip !important;
}

#header-group .header-logo__image {
  content: url("/cdn/shop/files/Yinzergear_Transparent_Logo.png") !important;
  object-fit: contain !important;
}

#header-group .header-logo__image,
#header-group .header-logo__image-container img {
  max-height: 58px !important;
  object-fit: contain !important;
}

#header-group .menu-list__list-item > .menu-list__submenu,
#header-group .menu-list__submenu-inner,
#header-group .mega-menu,
#header-group .mega-menu__grid,
#header-group .mega-menu__list,
#header-group .mega-menu__column {
  max-width: min(380px, calc(100vw - 32px)) !important;
}

@media screen and (min-width: 1200px) {
  #header-group .menu-list__list-item {
    position: relative;
  }

  #header-group .menu-list__list-item > .menu-list__submenu,
  #header-group .menu-list__submenu-inner,
  #header-group .mega-menu,
  #header-group .mega-menu__grid,
  #header-group .mega-menu__list,
  #header-group .mega-menu__column {
    width: max-content !important;
    min-width: 280px !important;
    overflow: visible !important;
  }

  #header-group .menu-list__submenu a,
  #header-group .mega-menu__link {
    display: flex !important;
    width: auto !important;
    min-width: 220px !important;
    max-width: 340px !important;
    white-space: normal !important;
    line-height: 1.25 !important;
  }
}

@media screen and (max-width: 768px) {
  #MainContent,
  .content-for-layout,
  .shopify-section,
  .section,
  .section > *,
  .yg-motion-hero,
  .yg-motion-hero__art,
  .yg-sales-proofbar,
  .yg-paths,
  .yg-path-grid {
    min-width: 0 !important;
    max-width: 100vw !important;
    box-sizing: border-box !important;
  }
}
/* END VERN-YG-BACKUP-SALES-REDESIGN-QA 2026-05-22 */

/* VERN-YG-BACKUP-PREMIUM-NAV 2026-05-22
   Make the backup header feel like the storefront, not default Horizon chrome. */
#header-group,
#header-group .header,
#header-group .header__row,
#header-group .header__columns {
  background: #020202 !important;
}

#header-group .header__row {
  border-bottom: 1px solid rgba(255, 182, 18, 0.18) !important;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.36) !important;
}

#header-group .menu-list__link,
#header-group .menu-list__link span,
#header-group .mega-menu__link,
#header-group .mega-menu__link-title,
#header-group nav a {
  color: #f7d878 !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
}

#header-group .menu-list__link {
  min-height: 40px !important;
  border-radius: 999px !important;
  padding-inline: 12px !important;
  font-weight: 850 !important;
  text-shadow: 0 1px 10px rgba(0, 0, 0, 0.46) !important;
  transition: background-color 0.16s ease, color 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease !important;
}

#header-group .menu-list__link:hover,
#header-group .menu-list__link:focus-visible,
#header-group .menu-list__link[aria-expanded='true'] {
  background: #ffb612 !important;
  color: #080808 !important;
  box-shadow: 0 8px 22px rgba(255, 182, 18, 0.18) !important;
  transform: translateY(-1px) !important;
}

#header-group .menu-list__link:hover span,
#header-group .menu-list__link:focus-visible span,
#header-group .menu-list__link[aria-expanded='true'] span {
  color: #080808 !important;
}

#header-group .header-actions__action,
#header-group .header__icon--menu,
#header-group .search-action,
#header-group summary,
#header-group button {
  color: #f7d878 !important;
}

#header-group .header-actions__action svg,
#header-group .header__icon--menu svg,
#header-group .search-action svg {
  color: #f7d878 !important;
  stroke: currentColor !important;
}

#header-group .header-actions__action svg *,
#header-group .header__icon--menu svg *,
#header-group .search-action svg * {
  color: #f7d878 !important;
  stroke: currentColor !important;
}

#header-group .header-actions__action:hover,
#header-group .header__icon--menu:hover,
#header-group .search-action:hover {
  color: #ffb612 !important;
  background: rgba(255, 182, 18, 0.12) !important;
  border-radius: 999px !important;
}

#header-group .menu-list__list-item > .menu-list__submenu,
#header-group .menu-list__submenu-inner,
#header-group .mega-menu,
#header-group .mega-menu__grid,
#header-group .mega-menu__list,
#header-group .mega-menu__column {
  background: #050505 !important;
  border-color: rgba(255, 182, 18, 0.28) !important;
  border-radius: 0 0 10px 10px !important;
  box-shadow: 0 24px 54px rgba(0, 0, 0, 0.55) !important;
}

#header-group .menu-list__submenu a,
#header-group .mega-menu__link {
  color: #fff2bd !important;
  font-weight: 760 !important;
}

#header-group .menu-list__submenu a:hover,
#header-group .mega-menu__link:hover,
#header-group .mega-menu a:hover {
  color: #080808 !important;
  background: #ffb612 !important;
  border-radius: 8px !important;
}

@media screen and (max-width: 749px) {
  #header-group .header__row {
    box-shadow: 0 10px 24px rgba(0, 0, 0, 0.34) !important;
  }

  #header-group .menu-drawer {
    background: #050505 !important;
    color: #fff2bd !important;
    left: 0 !important;
    right: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    border-right: 0 !important;
    box-shadow: 0 22px 58px rgba(0, 0, 0, 0.62) !important;
  }

  #header-group details[open] .menu-drawer,
  #header-group #Details-menu-drawer-container[open] .menu-drawer,
  #header-group details[open] .menu-drawer__navigation-container,
  #header-group details[open] .menu-drawer__navigation,
  #header-group details[open] .menu-drawer__menu,
  #header-group #Details-menu-drawer-container[open] .menu-drawer__navigation-container,
  #header-group #Details-menu-drawer-container[open] .menu-drawer__navigation,
  #header-group #Details-menu-drawer-container[open] .menu-drawer__menu {
    background: #050505 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    left: 0 !important;
    right: 0 !important;
    box-sizing: border-box !important;
  }

  #header-group .menu-drawer a,
  #header-group .menu-drawer button,
  #header-group .menu-drawer summary,
  #header-group .menu-drawer__menu-item,
  #header-group .menu-drawer__menu-item-text {
    color: #f7d878 !important;
    font-size: clamp(18px, 5.2vw, 23px) !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    line-height: 1.08 !important;
    text-decoration: none !important;
  }

  #header-group .menu-drawer a,
  #header-group .menu-drawer button,
  #header-group .menu-drawer summary {
    min-height: 48px !important;
    padding: 10px 18px !important;
    border-bottom: 1px solid rgba(255, 182, 18, 0.25) !important;
  }

  #header-group .menu-drawer a:hover,
  #header-group .menu-drawer button:hover,
  #header-group .menu-drawer summary:hover {
    color: #080808 !important;
    background: #ffb612 !important;
  }

  #header-group .menu-drawer details[open] > summary,
  #header-group .menu-drawer details[open] > summary *,
  #header-group .menu-drawer summary[aria-expanded='true'],
  #header-group .menu-drawer summary[aria-expanded='true'] * {
    color: #080808 !important;
    background: #ffb612 !important;
  }

  #header-group .menu-drawer details[open] > .menu-drawer__submenu,
  #header-group .menu-drawer .menu-drawer__submenu,
  #header-group .menu-drawer__inner-submenu {
    background: #050505 !important;
  }

  #header-group .menu-drawer .menu-drawer__submenu a,
  #header-group .menu-drawer .menu-drawer__submenu button,
  #header-group .menu-drawer .menu-drawer__submenu summary {
    font-size: clamp(15px, 4.4vw, 18px) !important;
    min-height: 42px !important;
    padding-left: 28px !important;
    color: #ffe7a3 !important;
    background: transparent !important;
  }
}
/* END VERN-YG-BACKUP-PREMIUM-NAV 2026-05-22 */

/* VERN-YG-BACKUP-RESPONSIVE-NAV-RAIL 2026-05-22
   The backup header needs its own breakpoints: Horizon keeps desktop nav alive
   too long, which makes tablet and narrow desktop sizes feel broken. */
#header-group #header-component .header__columns {
  max-width: min(1680px, calc(100vw - 48px)) !important;
  margin-inline: auto !important;
}

@media screen and (min-width: 1200px) {
  #header-group #header-component .header__columns {
    grid-template-columns: minmax(112px, 0.7fr) minmax(0, auto) minmax(112px, 0.7fr) !important;
    gap: clamp(14px, 1.4vw, 28px) !important;
  }

  #header-group #header-component .header__column--center {
    min-width: 0 !important;
    justify-content: center !important;
  }

  #header-group #header-component .header-menu__inner,
  #header-group #header-component .menu-list,
  #header-group #header-component .menu-list__list {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #header-group #header-component .menu-list__list {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(2px, 0.34vw, 9px) !important;
  }

  #header-group #header-component .menu-list__link {
    min-height: 36px !important;
    padding: 8px clamp(8px, 0.55vw, 13px) !important;
    border-radius: 999px !important;
    font-size: clamp(14px, 0.82vw, 17px) !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  #header-group #header-component .header-actions {
    gap: 8px !important;
  }

  #header-group #header-component .header-actions__action,
  #header-group #header-component .search-action button {
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
  }

  #header-group #header-component .menu-list__list-item {
    position: relative !important;
  }

  #header-group #header-component .menu-list__list-item:has(> .menu-list__submenu)::after {
    content: '' !important;
    position: absolute !important;
    left: -10px !important;
    right: -10px !important;
    top: 100% !important;
    height: 14px !important;
    pointer-events: auto !important;
  }

  #header-group #header-component .menu-list__list-item > .menu-list__submenu {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: min(340px, calc(100vw - 48px)) !important;
    min-width: 292px !important;
    max-width: min(340px, calc(100vw - 48px)) !important;
    height: auto !important;
    max-height: none !important;
    padding: 10px !important;
    background: rgba(3, 3, 3, 0.98) !important;
    border: 1px solid rgba(255, 182, 18, 0.34) !important;
    border-radius: 10px !important;
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.68) !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__submenu-inner,
  #header-group #header-component .mega-menu,
  #header-group #header-component .mega-menu__grid,
  #header-group #header-component .mega-menu__list,
  #header-group #header-component .mega-menu__column {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__submenu a,
  #header-group #header-component .mega-menu__link {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 40px !important;
    padding: 10px 12px !important;
    border-radius: 7px !important;
    color: #f7d878 !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    white-space: normal !important;
  }

  #header-group #header-component .menu-list__submenu a + a,
  #header-group #header-component .mega-menu__link + .mega-menu__link {
    margin-top: 2px !important;
  }
}

@media screen and (min-width: 1200px) and (max-width: 1340px) {
  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 50px !important;
  }

  #header-group #header-component .menu-list__link {
    font-size: 14px !important;
    padding-inline: 8px !important;
  }
}

@media screen and (max-width: 1199px) {
  #header-group #header-component .header__columns {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 48px minmax(0, 1fr) auto !important;
    gap: 8px !important;
    align-items: center !important;
    min-height: 66px !important;
    max-width: 100vw !important;
    padding-inline: 14px !important;
  }

  #header-group #header-component .header-menu.mobile\:hidden,
  #header-group #header-component .header__column--center,
  #header-group #header-component .menu-list:not(.menu-list--mobile) {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #header-group #header-component .header__column--left,
  #header-group #header-component .header__column--right {
    display: flex !important;
    min-width: 0 !important;
    align-items: center !important;
    gap: 6px !important;
  }

  #header-group #header-component .header__column--left {
    grid-column: 1 / 3 !important;
    justify-content: flex-start !important;
  }

  #header-group #header-component .header__column--right {
    grid-column: 3 !important;
    justify-content: flex-end !important;
  }

  #header-group #header-component .header__drawer.desktop\:hidden,
  #header-group #header-component header-drawer,
  #header-group #header-component #Details-menu-drawer-container,
  #header-group #header-component #Details-menu-drawer-container > summary {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  #header-group #header-component .header__drawer.desktop\:hidden {
    order: 0 !important;
    width: 46px !important;
    min-width: 46px !important;
  }

  #header-group #header-component .header-logo {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    z-index: 3 !important;
    transform: translate(-50%, -50%) !important;
    margin: 0 !important;
  }

  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 50px !important;
    max-width: 116px !important;
    width: auto !important;
    object-fit: contain !important;
  }

  #header-group #header-component .search-action.mobile\:hidden {
    display: none !important;
  }

  #header-group #header-component .header-actions {
    gap: 4px !important;
  }

  #header-group #header-component .header-actions__action,
  #header-group #header-component .header__icon--menu {
    width: 44px !important;
    min-width: 44px !important;
    height: 44px !important;
  }

  #header-group #header-component #Details-menu-drawer-container:not([open]) .menu-drawer,
  #header-group #header-component #Details-menu-drawer-container:not([open]) .menu-drawer * {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  #header-group #header-component #Details-menu-drawer-container[open] .menu-drawer {
    display: block !important;
    position: fixed !important;
    inset: 66px 0 auto 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: calc(100dvh - 66px) !important;
    max-height: calc(100dvh - 66px) !important;
    overflow-y: auto !important;
    background: #050505 !important;
    border-top: 1px solid rgba(255, 182, 18, 0.28) !important;
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.72) !important;
  }

  #header-group #header-component .menu-drawer,
  #header-group #header-component .menu-drawer__navigation-container,
  #header-group #header-component .menu-drawer__navigation,
  #header-group #header-component .menu-drawer__menu,
  #header-group #header-component .menu-drawer__menu > li {
    background: #050505 !important;
  }

  #header-group #header-component .menu-drawer a,
  #header-group #header-component .menu-drawer button,
  #header-group #header-component .menu-drawer summary,
  #header-group #header-component .menu-drawer__menu-item,
  #header-group #header-component .menu-drawer__menu-item-text,
  #header-group #header-component .menu-drawer__menu > li > a {
    color: #f7d878 !important;
    font-size: clamp(18px, 2.2vw, 22px) !important;
    font-weight: 800 !important;
    line-height: 1.12 !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
  }

  #header-group #header-component .menu-drawer a,
  #header-group #header-component .menu-drawer button,
  #header-group #header-component .menu-drawer summary {
    min-height: 50px !important;
    padding: 12px 18px !important;
    border-bottom: 1px solid rgba(255, 182, 18, 0.24) !important;
  }

  #header-group #header-component .menu-drawer details[open] > summary,
  #header-group #header-component .menu-drawer details[open] > summary *,
  #header-group #header-component .menu-drawer summary[aria-expanded='true'],
  #header-group #header-component .menu-drawer summary[aria-expanded='true'] * {
    color: #050505 !important;
    background: #ffb612 !important;
  }

  #header-group #header-component .menu-drawer .menu-drawer__submenu a,
  #header-group #header-component .menu-drawer .menu-drawer__submenu button,
  #header-group #header-component .menu-drawer .menu-drawer__submenu summary {
    color: #ffe7a3 !important;
    font-size: clamp(15px, 1.8vw, 18px) !important;
    font-weight: 760 !important;
    min-height: 42px !important;
    padding-left: 30px !important;
    background: transparent !important;
  }
}

@media screen and (max-width: 520px) {
  #header-group #header-component .header__columns {
    min-height: 58px !important;
    padding-inline: 10px !important;
  }

  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 44px !important;
    max-width: 104px !important;
  }

  #header-group #header-component #Details-menu-drawer-container[open] .menu-drawer {
    top: 58px !important;
    height: calc(100dvh - 58px) !important;
    max-height: calc(100dvh - 58px) !important;
  }
}
/* END VERN-YG-BACKUP-RESPONSIVE-NAV-RAIL 2026-05-22 */

/* VERN-YG-BACKUP-TABLET-DESKTOP-BRIDGE 2026-05-22
   Avoid Horizon's broken drawer internals in the 990-1199px range. */
@media screen and (min-width: 990px) and (max-width: 1199px) {
  #header-group #header-component .header__columns {
    position: relative !important;
    display: grid !important;
    grid-template-columns: minmax(92px, 0.45fr) minmax(0, auto) minmax(92px, 0.45fr) !important;
    gap: 10px !important;
    min-height: 70px !important;
    max-width: min(1160px, calc(100vw - 32px)) !important;
    margin-inline: auto !important;
    padding-inline: 8px !important;
  }

  #header-group #header-component .header__drawer.desktop\:hidden,
  #header-group #header-component header-drawer,
  #header-group #header-component #Details-menu-drawer-container {
    display: none !important;
    visibility: hidden !important;
    opacity: 0 !important;
    pointer-events: none !important;
  }

  #header-group #header-component .header__column--left,
  #header-group #header-component .header__column--center,
  #header-group #header-component .header__column--right {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    min-width: 0 !important;
    align-items: center !important;
  }

  #header-group #header-component .header__column--left {
    grid-column: 1 !important;
    justify-content: flex-start !important;
  }

  #header-group #header-component .header__column--center {
    grid-column: 2 !important;
    justify-content: center !important;
  }

  #header-group #header-component .header__column--right {
    grid-column: 3 !important;
    justify-content: flex-end !important;
  }

  #header-group #header-component .header-logo {
    position: static !important;
    transform: none !important;
    margin: 0 !important;
  }

  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 48px !important;
    max-width: 108px !important;
    width: auto !important;
    object-fit: contain !important;
  }

  #header-group #header-component .header-menu.mobile\:hidden,
  #header-group #header-component .header-menu__inner,
  #header-group #header-component .menu-list:not(.menu-list--mobile),
  #header-group #header-component .menu-list__list {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__list {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2px !important;
  }

  #header-group #header-component .menu-list__list-item,
  #header-group #header-component .menu-list__link {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__link {
    min-height: 34px !important;
    padding: 7px 7px !important;
    border-radius: 999px !important;
    color: #f7d878 !important;
    font-size: 13px !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  #header-group #header-component .header-actions__action,
  #header-group #header-component .search-action button {
    width: 38px !important;
    min-width: 38px !important;
    height: 38px !important;
  }

  #header-group #header-component .menu-list__list-item {
    position: relative !important;
  }

  #header-group #header-component .menu-list__list-item > .menu-list__submenu {
    position: absolute !important;
    top: calc(100% + 10px) !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: min(320px, calc(100vw - 40px)) !important;
    min-width: 280px !important;
    max-width: min(320px, calc(100vw - 40px)) !important;
    height: auto !important;
    max-height: none !important;
    padding: 10px !important;
    background: rgba(3, 3, 3, 0.98) !important;
    border: 1px solid rgba(255, 182, 18, 0.34) !important;
    border-radius: 10px !important;
    box-shadow: 0 24px 50px rgba(0, 0, 0, 0.68) !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__submenu-inner,
  #header-group #header-component .mega-menu,
  #header-group #header-component .mega-menu__grid,
  #header-group #header-component .mega-menu__list,
  #header-group #header-component .mega-menu__column {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: none !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  #header-group #header-component .menu-list__submenu a,
  #header-group #header-component .mega-menu__link {
    display: flex !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 38px !important;
    padding: 9px 11px !important;
    color: #f7d878 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1.18 !important;
    white-space: normal !important;
  }
}
/* END VERN-YG-BACKUP-TABLET-DESKTOP-BRIDGE 2026-05-22 */

/* VERN-YG-BACKUP-DROPDOWN-SLAB-FIX 2026-05-22 */
@media screen and (min-width: 990px) {
  #header-group #header-component .header-menu,
  #header-group #header-component .header-menu__inner,
  #header-group #header-component header-menu,
  #header-group #header-component header-menu nav,
  #header-group #header-component .menu-list {
    background: transparent !important;
  }
}
/* END VERN-YG-BACKUP-DROPDOWN-SLAB-FIX 2026-05-22 */

/* VERN-YG-BACKUP-LOGO-PRESENCE-FIX 2026-05-22 */
#header-group #header-component .header-logo,
#header-group #header-component .header-logo__image-container {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: visible !important;
}

#header-group #header-component .header-logo__image,
#header-group #header-component .header-logo__image-container img {
  content: url("/cdn/shop/files/Yinzergear_Transparent_Logo.png") !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
}

@media screen and (min-width: 1200px) {
  #header-group #header-component .header__columns {
    min-height: 84px !important;
  }

  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 72px !important;
    max-width: 154px !important;
  }
}

@media screen and (min-width: 990px) and (max-width: 1199px) {
  #header-group #header-component .header__columns {
    min-height: 76px !important;
  }

  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 62px !important;
    max-width: 132px !important;
  }
}

@media screen and (max-width: 989px) {
  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 56px !important;
    max-width: 122px !important;
  }
}

@media screen and (max-width: 520px) {
  #header-group #header-component .header-logo__image,
  #header-group #header-component .header-logo__image-container img {
    max-height: 50px !important;
    max-width: 112px !important;
  }
}
/* END VERN-YG-BACKUP-LOGO-PRESENCE-FIX 2026-05-22 */

/* VERN-YG-BACKUP-MOBILE-LOGO-CENTER-FIX 2026-05-22 */
@media screen and (max-width: 989px) {
  #header-group #header-component .header__columns {
    display: grid !important;
    grid-template-columns: 44px 44px minmax(0, 1fr) 44px 44px !important;
    grid-template-areas: 'menu search logo account cart' !important;
    column-gap: 0 !important;
    align-items: center !important;
  }

  #header-group #header-component .header__column--left,
  #header-group #header-component .header__column--right {
    display: contents !important;
  }

  #header-group #header-component .header__drawer.desktop\:hidden {
    grid-area: menu !important;
    display: flex !important;
    width: 44px !important;
    min-width: 44px !important;
    justify-self: center !important;
  }

  #header-group #header-component .search-action.desktop\:hidden,
  #header-group #header-component search-button.search-action.desktop\:hidden {
    grid-area: search !important;
    display: flex !important;
    width: 44px !important;
    min-width: 44px !important;
    justify-self: center !important;
  }

  #header-group #header-component .header-logo {
    grid-area: logo !important;
    position: static !important;
    transform: none !important;
    justify-self: center !important;
    align-self: center !important;
    margin: 0 !important;
  }

  #header-group #header-component .account-drawer,
  #header-group #header-component .account-actions {
    grid-area: account !important;
    justify-self: center !important;
  }

  #header-group #header-component .cart-drawer,
  #header-group #header-component cart-drawer-component {
    grid-area: cart !important;
    justify-self: center !important;
  }
}
/* END VERN-YG-BACKUP-MOBILE-LOGO-CENTER-FIX 2026-05-22 */

/* VERN-YG-BACKUP-MOBILE-LOGO-ABSOLUTE-CENTER 2026-05-22 */
@media screen and (max-width: 989px) {
  #header-group #header-component .header__columns {
    position: relative !important;
    grid-template-columns: 88px minmax(0, 1fr) 88px !important;
    grid-template-areas: 'left logo right' !important;
  }

  #header-group #header-component .header__column--left {
    display: flex !important;
    grid-area: left !important;
    justify-content: flex-start !important;
    gap: 0 !important;
  }

  #header-group #header-component .header__column--right {
    display: flex !important;
    grid-area: right !important;
    justify-content: flex-end !important;
    gap: 0 !important;
  }

  #header-group #header-component .header-logo {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
    grid-area: auto !important;
    z-index: 4 !important;
  }
}
/* END VERN-YG-BACKUP-MOBILE-LOGO-ABSOLUTE-CENTER 2026-05-22 */

/* VERN-YG-BACKUP-PRODUCT-CARD-TEXT-POLISH 2026-05-22
   Bring homepage product cards up to the black/gold storefront system. */
.ui-test-product-list product-card.product-card,
.ui-test-product-list .product-card {
  position: relative !important;
  display: block !important;
  height: 100% !important;
  overflow: hidden !important;
  border: 1px solid rgba(17, 17, 17, 0.18) !important;
  border-radius: 12px !important;
  background: #090909 !important;
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.10) !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease !important;
}

.ui-test-product-list product-card.product-card:hover,
.ui-test-product-list .product-card:hover,
.ui-test-product-list product-card.product-card:focus-within,
.ui-test-product-list .product-card:focus-within {
  transform: translateY(-3px) !important;
  border-color: rgba(255, 182, 18, 0.72) !important;
  box-shadow: 0 22px 46px rgba(0, 0, 0, 0.18) !important;
}

.ui-test-product-list .product-card__content {
  gap: 0 !important;
  height: 100% !important;
  background: #090909 !important;
}

.ui-test-product-list .card-gallery {
  overflow: hidden !important;
  border-radius: 12px 12px 0 0 !important;
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 182, 18, 0.12), transparent 42%),
    #f8f5ec !important;
}

.ui-test-product-list .card-gallery img,
.ui-test-product-list .product-media__image {
  transform: scale(0.98) !important;
  transition: transform 0.24s ease, filter 0.24s ease !important;
}

.ui-test-product-list product-card:hover .card-gallery img,
.ui-test-product-list product-card:hover .product-media__image,
.ui-test-product-list .product-card:hover .card-gallery img,
.ui-test-product-list .product-card:hover .product-media__image {
  transform: scale(1.015) !important;
  filter: saturate(1.04) contrast(1.03) !important;
}

.ui-test-product-list .product-card__content > .group-block,
.ui-test-product-list product-card .group-block[data-testid='group-block'] {
  position: relative !important;
  flex: 1 1 auto !important;
  width: 100% !important;
  padding: 14px 15px 15px !important;
  background:
    linear-gradient(135deg, rgba(255, 182, 18, 0.08), transparent 42%),
    #090909 !important;
  border-top: 1px solid rgba(255, 182, 18, 0.22) !important;
}

.ui-test-product-list .product-card__content > .group-block::before,
.ui-test-product-list product-card .group-block[data-testid='group-block']::before {
  content: '' !important;
  position: absolute !important;
  left: 15px !important;
  top: -1px !important;
  width: 42px !important;
  height: 3px !important;
  background: #ffb612 !important;
  border-radius: 0 0 999px 999px !important;
}

.ui-test-product-list .group-block-content {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 9px !important;
  justify-content: stretch !important;
  justify-items: stretch !important;
  align-content: start !important;
  min-height: 94px !important;
}

.ui-test-product-list .product-card a.contents,
.ui-test-product-list .product-card .user-select-text {
  color: inherit !important;
  text-decoration: none !important;
}

.ui-test-product-list .product-card .text-block[class*='product_title'],
.ui-test-product-list .product-card .text-block[class*='product-title'],
.ui-test-product-list .product-card .text-block.h5 {
  width: 100% !important;
  max-width: none !important;
  min-height: 2.32em !important;
  text-align: left !important;
  justify-self: stretch !important;
  color: #fff6d6 !important;
}

.ui-test-product-list .product-card .text-block[class*='product_title'] p,
.ui-test-product-list .product-card .text-block[class*='product-title'] p,
.ui-test-product-list .product-card .text-block.h5 p,
.ui-test-product-list .product-card__content .text-block p {
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  margin: 0 !important;
  min-height: 2.32em !important;
  color: #fff6d6 !important;
  font-family: var(--font-body--family, Arial, sans-serif) !important;
  font-size: clamp(15px, 1.12vw, 18px) !important;
  font-weight: 850 !important;
  line-height: 1.14 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  text-align: left !important;
  text-wrap: balance !important;
}

.ui-test-product-list product-price,
.ui-test-product-list .product-card product-price {
  display: flex !important;
  justify-content: flex-start !important;
  justify-self: stretch !important;
  align-self: start !important;
  width: 100% !important;
  min-width: 0 !important;
  margin-inline: 0 !important;
  text-align: left !important;
}

.ui-test-product-list .product-card .price,
.ui-test-product-list .product-card product-price,
.ui-test-product-list .product-card price-list {
  color: #111 !important;
  font-family: var(--font-body--family, Arial, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.ui-test-product-list .product-card .price {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  background: #ffb612 !important;
  color: #111 !important;
  box-shadow: inset 0 -1px 0 rgba(0, 0, 0, 0.18) !important;
  margin-inline: 0 auto !important;
  white-space: nowrap !important;
}

.ui-test-product-list .product-badges,
.ui-test-product-list .product-badges * {
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

@media screen and (max-width: 749px) {
  .ui-test-product-list product-card.product-card,
  .ui-test-product-list .product-card {
    border-radius: 10px !important;
  }

  .ui-test-product-list .product-card__content > .group-block,
  .ui-test-product-list product-card .group-block[data-testid='group-block'] {
    padding: 12px 12px 13px !important;
  }

  .ui-test-product-list .group-block-content {
    gap: 8px !important;
    min-height: 88px !important;
  }

  .ui-test-product-list .product-card .text-block[class*='product_title'] p,
  .ui-test-product-list .product-card .text-block[class*='product-title'] p,
  .ui-test-product-list .product-card .text-block.h5 p,
  .ui-test-product-list .product-card__content .text-block p {
    font-size: 14px !important;
    line-height: 1.16 !important;
    min-height: 2.32em !important;
  }

  .ui-test-product-list .product-card .price {
    min-height: 26px !important;
    padding-inline: 9px !important;
    font-size: 11px !important;
  }
}
/* END VERN-YG-BACKUP-PRODUCT-CARD-TEXT-POLISH 2026-05-22 */

/* VERN-YG-BACKUP-SHIPPING-ANNOUNCEMENT-GOLD 2026-05-27
   Keep the backup redesign's shipping promise visible as a compact utility strip. */
#header-group [id*="header_announcements"] {
  background: #ffb612 !important;
  color: #070707 !important;
  border-bottom: 1px solid rgba(0, 0, 0, 0.32) !important;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18) !important;
}

#header-group [id*="header_announcements"] .announcement-bar,
#header-group [id*="header_announcements"] .announcement-bar__slider,
#header-group [id*="header_announcements"] .announcement-bar__slides,
#header-group [id*="header_announcements"] .announcement-bar__slide,
#header-group [id*="header_announcements"] .announcement-bar__link,
#header-group [id*="header_announcements"] .announcement-bar__text {
  background: #ffb612 !important;
  color: #070707 !important;
}

#header-group [id*="header_announcements"] .announcement-bar__text,
#header-group [id*="header_announcements"] .announcement-bar__link {
  font-family: var(--font-body--family, Arial, sans-serif) !important;
  font-size: clamp(12px, 1.45vw, 15px) !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
}

@media screen and (max-width: 420px) {
  #header-group [id*="header_announcements"] .announcement-bar__text,
  #header-group [id*="header_announcements"] .announcement-bar__link {
    font-size: 11px !important;
  }
}
/* END VERN-YG-BACKUP-SHIPPING-ANNOUNCEMENT-GOLD 2026-05-27 */
