/** Shopify CDN: Minification failed

Line 5078:0 Unexpected "<"
Line 5080:5 Unexpected "{"
Line 5080:14 Expected ":"
Line 5871:11 Unexpected "{"
Line 5871:20 Expected ":"
Line 5871:26 Unexpected "{"
Line 6684:0 Expected "}" to go with "{"

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

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

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

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

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

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

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

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

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

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

.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);
  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 > *:not(.header-section) {
  z-index: 1;
}

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

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

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

    > .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);
  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%);
  }
}
.footer-wave {
  width: 100%;
  height: 180px; /* adjust to taste */
  background: url('/cdn/shop/files/footer-wave-white.svg?v=1761107611') no-repeat bottom center;
  background-size: cover;            /* stretch to full width */
  position: relative;
  z-index: 10;                       /* above section background */
  margin-bottom: -1px;               /* tuck into footer so no gap */
}

/* keep this if you added it earlier */
.section-background { position: relative; z-index: 1; }

footer, .footer {
  background-color: #ffa51f; /* green footer */
  color: #3a2b1b;
  padding-top: 80px;
}
/* Keep Savor's injected footer background hidden */
#shopify-section-footer > .section-background { display:none !important; }

/* Make the actual footer green */
#shopify-section-footer,
#shopify-section-footer .section,
#shopify-section-footer footer,
#shopify-section-footer .footer { background-color:#d3e2c2 !important; }

/* Ensure the area *above* the wave is white */
#shopify-section-footer { position: relative; overflow: hidden; }
.footer-wave { position: relative; z-index: 10; }

/* White cap that sits directly above the wave to cover any leftover green */
.footer-wave::before{
  content:"";
  position:absolute;
  left:0; right:0;
  bottom:100%;       /* attaches to the top edge of the wave strip */
  height:120px;      /* increase if a sliver still shows */
  background:#ffffff;
}

/* Optional: pull the wave up a touch to remove tiny gaps */
.footer-wave{ margin-top:-1px; margin-bottom:-1px; }
/* ===== Recipes Split Section ===== */
.recipes-split { padding: 40px 0 10px; }
.recipes-split__inner {
  display: grid;
  grid-template-columns: 1fr minmax(260px, 420px) 1fr; /* left | center | right */
  gap: 36px;
  align-items: start;
}

/* ===== RECIPES SPLIT (safe block) ===== */
.recipes-split { padding: 40px 0 10px; }
.recipes-split__inner {
  display: grid;
  grid-template-columns: 1fr minmax(260px, 420px) 1fr;
  gap: 36px;
  align-items: start;
}

.recipes-split__center { text-align: left; }

.recipes-split__heading {
  font-size: clamp(32px, 4vw, 56px);
  line-height: 1.05;
  margin: 0 0 18px;
  color: #3a2b1b;
}
.recipes-split__subtext { margin: 0 0 18px; }
.recipes-split__btn {
  display: inline-block; padding: 12px 22px; border-radius: 999px;
  border: 2px solid currentColor; text-decoration: none;
}

.recipes-split__card { text-align: left; margin: 0; }
.recipes-split__image-link { display:block; }
.recipes-split__image {
  width: 100%; height: auto; aspect-ratio: 4/3; object-fit: cover;
  border-radius: 16px; transition: transform .25s ease;
}
.recipes-split__image-link:hover .recipes-split__image { transform: translateY(-2px); }

.recipes-split__title {
  font-size: clamp(20px, 2.2vw, 28px);
  margin: 14px 0 6px;
  color: #3a2b1b;
}
.recipes-split__title a { color: inherit; text-decoration: none; }
.recipes-split__cta {
  display: inline-flex; gap: 8px; align-items: center;
  text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 2px;
}
.recipes-split__arrow { transform: translateY(-1px); }

/* Mobile */
@media (max-width: 899px) {
  .recipes-split__inner { grid-template-columns: 1fr; gap: 28px; }
  .recipes-split__center { order: 1; }
  .recipes-split__card--left { order: 2; }
  .recipes-split__card--right { order: 3; }
}
/* ===== END RECIPES SPLIT ===== */
/* ====== Recipes Split (Inspo layout) ====== */
.recipes-split { padding: 48px 0; }
.recipes-split__inner{
  display:grid;
  grid-template-columns: minmax(320px, 1fr) minmax(320px, 420px) minmax(320px, 1fr);
  gap:48px;
  align-items:center;     /* centers the middle copy vertically */
}

/* Side cards = big images */
.recipes-split__card{ text-align:center; }
.recipes-split__image{
  display:block;
  width:100%;
  aspect-ratio: 3 / 4;    /* change to 3/4 for taller images */
  object-fit:cover;
  border-radius:18px;
}
.recipes-split__title{
  margin:16px 0 8px;
  font-size: clamp(20px,2.2vw,28px);
  font-weight: 700;
  color:#3a2b1b;
  text-transform:none;    /* avoid all caps look */
}
.recipes-split__title a{ color:inherit; text-decoration:none; }
.recipes-split__cta{
  display:inline-flex; align-items:center; gap:8px;
  text-decoration:none; border-bottom:1px solid currentColor; padding-bottom:2px;
}

/* Center copy */
.recipes-split__center{ text-align:center; }
.recipes-split__heading{
  margin:0 0 14px;
  font-size: clamp(36px, 5vw, 64px);
  line-height:1.05;
  color:##ffa51f;
}
.recipes-split__subtext{ margin:0 0 18px; color:##ffa51f; }
.recipes-split__btn{
  display:inline-block; padding:12px 22px; border-radius:999px;
  border:2px solid currentColor; text-decoration:none;
}

/* Mobile */
@media (max-width: 899px){
  .recipes-split__inner{ grid-template-columns:1fr; gap:28px; }
  .recipes-split__center{ order:1; }
  .recipes-split__card--left{ order:2; }
  .recipes-split__card--right{ order:3; }
}
@media (min-width: 900px){
  .recipes-split__image{
    height: 560px;         /* adjust: 520, 600, 680… */
    width: 100%;
    aspect-ratio: auto;    /* disable previous ratio */
    object-fit: cover;
  }
}
@media (max-width: 899px){
  .recipes-split__image{
    aspect-ratio: 4 / 3;   /* or 3/4 if you like */
    height: auto;
  }
}

/* White text with orange outline for the Recipes heading */
.recipes-split__heading{
  /* fill */
  color: #fff;
  -webkit-text-fill-color: #fff;

  /* outline (Chrome/Safari/Edge) */
  -webkit-text-stroke: 2px #ffa51f;

  /* Firefox fallback: multi-direction shadows create a faux stroke */
  text-shadow:
    2px 0   #ffa51f,
   -2px 0   #ffa51f,
    0   2px #ffa51f,
    0  -2px #ffa51f,
    1px 1px #ffa51f,
   -1px 1px #ffa51f,
    1px -1px #ffa51f,
   -1px -1px #ffa51f;

  font-weight: 800;               /* looks better with an outline */
  letter-spacing: .02em;
}

/* Make the stroke slightly thinner on small screens */
@media (max-width: 640px){
  .recipes-split__heading{
    -webkit-text-stroke: 1.2px #ffa51f;
    text-shadow:
      1.5px 0   #ffa51f,
     -1.5px 0   #ffa51f,
      0   1.5px #ffa51f,
      0  -1.5px #ffa51f,
      1px 1px   #ffa51f,
     -1px 1px   #ffa51f,
      1px -1px  #ffa51f,
     -1px -1px  #ffa51f;
  }
}
/* Sun behind the LEFT recipe image only */
.recipes-split__card--left { position: relative; }

.recipes-split__card--left .recipes-split__image,
.recipes-split__card--left .recipes-split__image-link {
  position: relative;
  z-index: 2;                 /* keep the photo above the sun */
}

.recipes-split__card--left::before{
  content:"";
  position:absolute;
  z-index: 1;                 /* behind the image, above page bg */
  pointer-events:none;

  /* size & art */
  width: 520px;               /* sun size — tweak to taste */
  height: 520px;
  background: url('/cdn/shop/files/Untitled_design.svg?v=1761145590') no-repeat center / contain;
  opacity: 0.14;              /* how subtle it looks */

  /* position — nudge as you like */
  top: -90px;                 /* move up/down */
  left: -90px;                /* move left/right */
  transform: rotate(-10deg);  /* optional angle */
}

/* Mobile: scale it down so it doesn't overwhelm */
@media (max-width: 899px){
  .recipes-split__card--left::before{
    width: 300px;
    height: 300px;
    top: -50px;
    left: -40px;
    opacity: 0.12;
    transform: rotate(-8deg);
  }
}
/* SUN behind the LEFT image (already) */
.recipes-split__card--left { position: relative; }
.recipes-split__card--left .recipes-split__image,
.recipes-split__card--left .recipes-split__image-link { position: relative; z-index: 2; }
.recipes-split__card--left::before{
  content:"";
  position:absolute; z-index:1; pointer-events:none;
  width:520px; height:520px;
  background:url('/cdn/shop/files/Untitled_design.svg?v=1761145590') no-repeat center / contain;
  opacity:.14;
  top:-90px; left:-90px; transform:rotate(-10deg);
}

/* === OVERRIDES: Suns behind images, top corners, richer color === */

/* Ensure each card is a positioning context */
.recipes-split__card--left,
.recipes-split__card--right {
  position: relative;
}

/* Keep the photos above the sun graphics */
.recipes-split__card--left  .recipes-split__image,
.recipes-split__card--right .recipes-split__image,
.recipes-split__card--left  .recipes-split__image-link,
.recipes-split__card--right .recipes-split__image-link {
  position: relative;
  z-index: 2;
}

/* LEFT: sun behind, top-left */
.recipes-split__card--left::before{
  content:"";
  position:absolute;
  z-index: 1;                 /* behind the image */
  pointer-events:none;

  width: 520px; height: 520px;
  background: url('/cdn/s/files/.../sun.png') no-repeat center / contain;

  /* richer color */
  opacity: .28;               /* increase visibility */
  filter: saturate(1.7) contrast(1.1);

  /* lock to top-left, never bottom */
  top: -90px !important;
  left: -90px !important;
  right: auto !important;
  bottom: auto !important;
  transform: rotate(-10deg);
}
/* ===== Suns for Recipes Split ===== */

/* Make sure cards can position children and allow overflow */
.recipes-split__card--left,
.recipes-split__card--right { position: relative; overflow: visible !important; }

/* Keep the photos at a higher layer than "behind" graphics */
.recipes-split__card--left  .recipes-split__image,
.recipes-split__card--right .recipes-split__image,
.recipes-split__card--left  .recipes-split__image-link,
.recipes-split__card--right .recipes-split__image-link {
  position: relative; z-index: 2;
}

/* LEFT: sun BEHIND the image (top-left corner) */
.recipes-split__card--left::before{
  content:"";
  position:absolute; z-index:1; pointer-events:none;

  /* size */
  width:520px; height:520px;

  /* art */
  background: url('/cdn/shop/files/Untitled_design.svg?v=1761145590') no-repeat center / contain;
  opacity:.40; filter:saturate(1.7) contrast(1.1);

  /* position (anchored to top-left, nudged outward) */
  top:10; left:0;
  transform: translate(-22%, -22%) rotate(-10deg);
}

/* RIGHT: sun ON TOP of the image (top-right corner) */
.recipes-split__card--right::before{
  content:"";
  position:absolute; z-index:3; pointer-events:none;   /* higher than image */

  /* size */
  width:480px; height:480px;

  /* art */
  background: url('/cdn/shop/files/Untitled_design.svg?v=1761145590') no-repeat center / contain;
  opacity:.30; filter:saturate(1.8) contrast(1.1);
  /* optional: if you want it to "ink" into the photo look, uncomment: */
  /* mix-blend-mode: multiply; */

  /* position (anchored to top-right, nudged outward) */
  top:0; right:0;
  transform: translate(22%, -20%) rotate(8deg);
}

/* Mobile scale-down so they don't overwhelm */
@media (max-width: 899px){
  .recipes-split__card--left::before{
    width:300px; height:300px; opacity:.22; transform: translate(-18%, -18%) rotate(-8deg);
  }
  .recipes-split__card--right::before{
    width:280px; height:280px; opacity:.24; transform: translate(18%, -18%) rotate(6deg);
  }
}
/* ===== Suns at the BOTTOM of the images ===== */

/* make cards positioning contexts + allow overflow */
.recipes-split__card--left,
.recipes-split__card--right { position: relative; overflow: visible !important; }

/* keep images above “behind” graphics */
.recipes-split__card--left  .recipes-split__image,
.recipes-split__card--right .recipes-split__image,
.recipes-split__card--left  .recipes-split__image-link,
.recipes-split__card--right .recipes-split__image-link {
  position: relative; z-index: 2;
}
/* RESET any earlier right overlay */
.recipes-split__card--right::after { content: none !important; }

/* Make cards the positioning context + allow artwork to overflow */
.recipes-split__card--left,
.recipes-split__card--right { position: relative; overflow: visible !important; }

/* Keep photos above the suns */
.recipes-split__card--left  .recipes-split__image,
.recipes-split__card--right .recipes-split__image,
.recipes-split__card--left  .recipes-split__image-link,
.recipes-split__card--right .recipes-split__image-link {
  position: relative; z-index: 2;
}

/* LEFT: sun BEHIND image, bottom-left — pull UP with negative Y */
.recipes-split__card--left::before{
  content:"";
  position:absolute; z-index:1; pointer-events:none;
  width:520px; height:520px;
  background:url('/cdn/shop/files/Untitled_design_1.svg?v=1761152101') no-repeat center / contain;
  opacity:.28; filterYOUR-SUN-URL:saturate(1.7) contrast(1.1);

  bottom:0 !important; left:0 !important; top:auto !important; right:auto !important;
  transform: translate(-18%, -10%) rotate(-10deg);  /* ⬅ pull UP inside image */
}

/* RIGHT: sun BEHIND image, bottom-right — also pull UP */
.recipes-split__card--right::before{
  content:"";
  position:absolute; z-index:1; pointer-events:none;
  width:480px; height:480px;
  background:url('/cdn/shop/files/Untitled_design.svg?v=1761145590') no-repeat center / contain;
  opacity:.28; filter:saturate(1.7) contrast(1.1);

  bottom:0 !important; right:0 !important; top:auto !important; left:auto !important;
  transform: translate(18%, -8%) rotate(8deg);      /* ⬅ pull UP inside image */
}

/* If a tiny part still sits under the footer, give the section a bit more bottom room */
.recipes-split { padding-bottom: 32px; }

@media (max-width: 899px){
  .recipes-split__card--left::before{
    width:300px; height:300px; transform: translate(-14%, -8%) rotate(-8deg); opacity:.22;
  }
  .recipes-split__card--right::before{
    width:280px; height:280px; transform: translate(14%, -6%) rotate(6deg);  opacity:.22;
  }
}
/* === More saturation on BOTH recipe images === */
.recipes-split__image{
  filter: saturate(2.0) contrast(1.1);
  /* keeps edges crisp while boosting color */
}

/* Optional: stronger on hover (remove if you don’t want this) */
.recipes-split__image-link:hover .recipes-split__image{
  filter: saturate(1.6) contrast(1.1);
}

/* === Tiny upward nudge on the LEFT image only === */
.recipes-split__card--left .recipes-split__image{
  transform: translateY(-16px);   /* try -8px to -16px */
}

/* If transform was overridden elsewhere, force it */
.recipes-split .recipes-split__card--left img.recipes-split__image{
  transform: translateY(-10px) !important;
}

/* Keep layout tidy: crop the shift inside the image frame */
.recipes-split__card--left .recipes-split__image-link{
  display:block;
  overflow:hidden;
}

/* Mobile: dial it back so it doesn’t crowd */
@media (max-width: 899px){
  .recipes-split__image{
    filter: saturate(1.25) contrast(1.04);
  }
  .recipes-split__card--left .recipes-split__image{
    transform: translateY(-6px);
  }
/* === Make the section breathe on the sides (no touching edges) === */
.recipes-split{
  padding-left: clamp(16px, 4vw, 40px);
  padding-right: clamp(16px, 4vw, 40px);
}

/* === Taller images on desktop (long look) === */
@media (min-width: 900px){
  .recipes-split__image{
    aspect-ratio: 2 / 3;      /* try 1 / 2 for even taller */
    object-fit: cover;
  }
}

/* === Orange outline BEHIND each image (not on top) === */
.recipes-split__image-link{
  position: relative;
  display: block;
}
.recipes-split__image{
  position: relative;
  z-index: 2;                 /* image stays above outline */
  border-radius: 20px;        /* rounded image corners */
}

/* the frame that sits behind the image and peeks out */
.recipes-split__image-link::after{
  content: "";
  position: absolute;
  inset: -10px;               /* how far the outline sticks out */
  border: 4px solid #ffcc00;  /* your orange */
  border-radius: 24px;        /* a touch larger than image radius */
  z-index: 1;                 /* behind image, above background art */
  pointer-events: none;
}

/* make sun/rainbow decorations sit under the frame & image */
.recipes-split__card--left::before,
.recipes-split__card--right::before{
  z-index: 0 !important;      /* decorations furthest back */
}
/* Recipe cards: consistent mobile sizing */
.recipe-card__media {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;           /* change to 1/1 if you want perfect squares */
  border: 3px solid #f5b301;     /* your yellow outline */
  border-radius: 16px;
  overflow: hidden;
}

/* Force image to fill the frame evenly */
.recipe-card__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;             /* crops evenly without stretching */
}

/* Optional: keep titles/excerpts from making cards uneven */
.recipe-card__title { min-height: 2.4rem; }
.recipe-card__excerpt {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Mobile-first grid spacing */
.recipe-grid { display: grid; gap: 24px; }
@media (min-width: 750px) {
  .recipe-grid { grid-template-columns: repeat(2, 1fr); }
}
/* === Normalize recipe/article card image heights on mobile === */
@media (max-width: 749px) {
  /* Common wrappers used by Dawn and similar themes */
  .article-card .card__media,
  .article-card .media,
  .card--article .card__inner .media,
  .blog-articles .card__media,
  .recipe-card__media,
  .recipe-list .card__media {
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;   /* use 4/3 if you prefer rectangles */
    overflow: hidden !important;
    border-radius: 16px;               /* keep your rounded look */
  }

  /* Make the image fill the frame consistently */
  .article-card .card__media img,
  .article-card .media img,
  .card--article .card__inner .media img,
  .blog-articles .card__media img,
  .recipe-card__media img,
  .recipe-list .card__media img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;      /* crops evenly, no stretching */
    object-position: center !important;
    display: block !important;
  }
}

/* Optional: if your theme injects fixed heights, nuke them everywhere */
.article-card img,
.blog-articles img,
.recipe-list img { height: auto; }
.wave-divider{width:100%;line-height:0;display:block}
.wave-divider svg{width:100%;display:block}
.wave-flip{transform:scaleY(-1)}
.wave-overlap{margin-top:-1px} /* hides hairline seams */
/* Remove black background under product/collection images */
.card__media,
.product-card__media,
.media,
.media--square,
.shop-card__placeholder {
  background: transparent !important;
}

/* Make images fill their containers and crop cleanly */
.card__media img,
.product-card__media img,
.media img,
.product-media img,
.landing-row__item .media img {
  width: 100%;
  height: 100%;
  object-fit: cover;      /* fill without letterboxing */
  display: block;
}

/* Optional: enforce a consistent square card image if needed */
.card__media,
.product-card__media,
.landing-row__item .media {
  aspect-ratio: 1 / 1;   /* or 4/5, 3/4, etc. to taste */
  overflow: hidden;
}
/* Remove the black bands under product/collection images and make images fill */
.media,
.card-media,
.product-media,
.product-card__image,
.collection-product-card__image {
  background: transparent !important;
}

/* Make images fill their wrappers without letterboxing */
.media img,
.card-media img,
.product-media img,
.product-card__image img,
.collection-product-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Some Savor builds add an extra inner wrapper with a background */
.media > :where(img, picture) {
  background: transparent !important;
}

/* Safety: if any wrapper forces a fixed height, let the image cover it */
.product-card .media,
.collection-product-card .media {
  overflow: hidden;
}
/* ---------- Kill the black "band" under product images (Savor) ---------- */
/* Make every card/content area transparent so no black background shows */
.card,
.card__inner,
.card__media,
.card__content,
.card__information,
.product-card,
.product-card__inner,
.product-card__media,
.product-card__content,
.collection-product-card,
.collection-product-card__inner,
.collection-product-card__media,
.collection-product-card__content,
.product-grid .card,
.product-grid .card__content,
.product-grid .card__information,
.collection .card__content,
.collection .product-card__content {
  background: transparent !important;
}

/* Also clear any color-scheme surface on those blocks (some Savor builds use CSS vars) */
.card,
.card__content,
.card__information,
.product-card__content,
.collection-product-card__content {
  --color-surface: transparent !important;
  --bg: transparent !important;
}

/* Make sure the media area never contributes a background */
.media,
.media:before,
.media:after,
.card__media,
.product-card__media,
.collection-product-card__media {
  background: transparent !important;
}

/* Keep the image fully covering its wrapper */
.media img,
.card__media img,
.product-card__media img,
.collection-product-card__media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Hide any overflow if a fixed aspect ratio is used */
.card__media,
.product-card__media,
.collection-product-card__media {
  overflow: hidden;
}
/* Fix aspect ratio "black band" issue for product and collection images */
.media,
.card__media,
.product-card__media,
.collection-product-card__media {
  aspect-ratio: auto !important; /* let the image define its height */
  height: auto !important;
  background: transparent !important;
  overflow: visible !important;
}

/* Force images to fill their containers perfectly */
.media img,
.card__media img,
.product-card__media img,
.collection-product-card__media img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  display: block !important;
}

/* If a wrapper adds black due to color scheme */
.product-card,
.collection-product-card,
.card__inner {
  background: transparent !important;
  box-shadow: none !important;
}

/* Ensure consistent grid alignment */
.product-grid,
.collection-grid {
  align-items: flex-start !important;
}
/* Recommended/related product cards – remove black band under images */
.product-recommendations .product-card .media,
.product-recommendations .card__media,
.product-grid .product-card .media,
.product-grid .card__media,
.product-card__media,
.card__media,
.media {
  background: transparent !important;
}

/* Make the image fill the media box */
.product-recommendations .product-card .media img,
.product-recommendations .card__media img,
.product-grid .product-card .media img,
.product-grid .card__media img,
.product-card__media img,
.card__media img,
.media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* If the theme draws an overlay on the media wrapper, disable it */
.product-recommendations .card__media::after,
.product-grid .card__media::after,
.product-card__media::after,
.media::after {
  content: none !important;
}
/* Product recommendations cards – remove dark bar */
.product-recommendations .card,
.product-recommendations .card-wrapper,
.product-recommendations .card__content,
.product-recommendations .card__information {
  background: transparent !important;
}

/* If the content area is creating extra height, reduce it */
.product-recommendations .card__content,
.product-recommendations .card__information {
  padding: 0 !important;
  min-height: 0 !important;
}

/* Make sure the image fills the box nicely */
.product-recommendations .card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Some themes draw an overlay on the media wrapper */
.product-recommendations .card__media::after {
  content: none !important;
}
<script>
/* ===== Product page two-column layout ===== */
#pi-{{ section.id }}.product-information__grid,
.product-information__grid {
  display: grid;
  grid-template-columns: minmax(0, 58vw) minmax(420px, 1fr);
  gap: 2.5rem;
  align-items: start;
}

/* If your theme uses a class like .product-information__media / .product-details,
   make sure they don't span full-width on desktop */
.product-information__media { grid-column: 1; }
.product-details { grid-column: 2; }

/* ===== Tabs under the title ===== */
.p-tabs { margin-top: .5rem; }
.p-tabs__nav {
  display: flex;
  gap: 2rem;
  border-bottom: 1px solid currentColor;
  margin: .75rem 0 1rem;
}
.p-tabs__btn {
  appearance: none;
  background: none;
  border: 0;
  font: inherit;
  padding: .65rem 0;
  cursor: pointer;
  opacity: .65;
  position: relative;
}
.p-tabs__btn.is-active { opacity: 1; }
.p-tabs__btn.is-active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 2px;
  background: currentColor;
}
.p-tabs__pane { display: none; }
.p-tabs__pane.is-active { display: block; }

/* Variant short description block */
.p-variant-desc__inner {
  margin-bottom: .75rem;
  font-weight: 500;
}

/* Ensure media fits and kill any “band” decorations under the media */
.product-information__media img,
.product-information__media video {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
.product-information__media .media::after,
.product-card__media .media::after { display: none !important; }

/* ===== Mobile: stack layout & readable type ===== */
@media (max-width: 749px) {
  .product-information__grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .product-details h1 { 
    font-size: clamp(28px, 6.2vw, 36px);
    line-height: 1.15;
  }
  .product-details p,
  .p-tabs { font-size: clamp(16px, 4.5vw, 18px); line-height: 1.35; }
}
/* ===== Footer tidy-up (layout + spacing only) ===== */

/* Inner container width */
footer .footer__inner,
.footer .footer__inner,
.site-footer .footer__inner{
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: 24px;
}

/* Turn footer blocks into a clean grid */
footer .footer__blocks,
.footer .footer__blocks,
.site-footer .footer__blocks{
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr)); /* 4 neat columns */
  gap: 28px;
}

/* If your theme uses another wrapper, keep it neat as a fallback */
footer .footer,
footer .grid,
.footer .grid{
  gap: 28px;
}

/* Headings & lists — spacing only, inherit colors */
footer h2, footer h3,
.footer h2, .footer h3,
.site-footer h2, .site-footer h3{
  margin: 0 0 12px;
  font-weight: 700;
  letter-spacing: .2px;
}

footer ul, .footer ul, .site-footer ul{
  list-style: none;
  margin: 0;
  padding: 0;
}
footer li + li{ margin-top: 8px; }

/* Newsletter: input + button sizing only (no color changes) */
footer .newsletter-form input[type="email"],
footer input[type="email"][name="contact[email]"]{
  width: 100%;
  height: 44px;
  padding: 10px 14px;
  border-radius: 10px;
}

footer .newsletter-form button,
footer .newsletter button,
footer .newsletter .button{
  height: 44px;
  padding: 0 16px;
  border-radius: 10px;
  margin-top: 10px; /* stacks on mobile */
}

/* Put email + button in a row on wider screens */
@media (min-width: 640px){
  footer .newsletter-row{ display: flex; gap: 10px; }
  footer .newsletter-row input[type="email"]{ flex: 1; }
  footer .newsletter-form button{ margin-top: 0; }
}

/* Social icons row */
footer .footer__social, .footer .footer__social, .site-footer .footer__social{
  display: flex;
  gap: 14px;
  margin-top: 10px;
}
footer .footer__social a{
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: 999px;
}

/* Bottom bar: tidy line + spacing (keeps your colors) */
footer .footer__bottom, .footer .footer__bottom, .site-footer .footer__bottom{
  border-top: 1px solid rgba(0,0,0,.14);
  margin-top: 28px;
  padding-top: 16px;
  display: flex;
  gap: 16px;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  font-size: .95rem;
}

/* Responsive columns */
@media (max-width: 980px){
  footer .footer__blocks{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px){
  footer .footer__blocks{ grid-template-columns: 1fr; }
}
/* ---------- SOCIAL ICONS: larger, clearer, evenly spaced ---------- */
/* Matches most themes: .list-social / .footer__social / any class containing "social" */
footer :is(.list-social, .footer__social, [class*="social"]) {
  display: flex !important;
  gap: 16px !important;
  align-items: center !important;
}

/* Style each social link as a larger round button */
footer :is(.list-social__link, .footer__social a, [class*="social"] a) {
  width: 40px !important;
  height: 40px !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 2px solid currentColor !important;   /* uses your existing text color */
  opacity: 1 !important;                        /* fully visible */
}

/* Make the SVG/icon itself bigger */
footer :is(.list-social__link svg, .footer__social svg, [class*="social"] svg) {
  width: 22px !important;
  height: 22px !important;
}

/* Optional: give a tiny glow so icons pop on colored backgrounds (no color change) */
footer :is(.list-social__link, .footer__social a, [class*="social"] a) {
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.20));
}

/* ---------- COPYRIGHT / BOTTOM BAR: more prominent ---------- */
/* Hit most common bottom-bar containers */
footer :is(.footer__bottom, .site-footer__bottom, .footer-bottom, [class*="copyright"]) {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 20px !important;
  padding-top: 14px !important;

  /* thin top separator without changing your colors */
  border-top: 1px solid rgba(0,0,0,.14) !important;
}

/* Make the copyright text itself bigger/bolder */
footer :is(.footer__copyright, .site-footer__copyright, [class*="copyright"]) {
  font-size: 15.5px !important;
  font-weight: 700 !important;
  letter-spacing: .02em !important;
  line-height: 1.3 !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.18); /* subtle legibility boost, same color */
}

/* If your copyright is a simple <p> inside the bottom bar */
footer :is(.footer__bottom, .site-footer__bottom, .footer-bottom) p {
  margin: 0 !important;
}

/* ---------- MOBILE TWEAKS ---------- */
@media (max-width: 640px){
  footer :is(.list-social__link, .footer__social a, [class*="social"] a){
    width: 36px !important;
    height: 36px !important;
  }
  footer :is(.footer__bottom, .site-footer__bottom, .footer-bottom, [class*="copyright"]){
    gap: 10px !important;
  }
}
/* === Sun Daughters footer enhancements (layout only) === */
#sd-footer { /* keep your colors/wave untouched */ }

/* Make socials bigger and obvious */
#sd-footer a[href*="instagram"],
#sd-footer a[href*="tiktok"],
#sd-footer a[href*="facebook"],
#sd-footer a[href*="pinterest"],
#sd-footer a[href*="twitter"],
#sd-footer a[href*="x.com"],
#sd-footer a[href*="youtube"]{
  width: 42px !important;
  height: 42px !important;
  display: inline-grid !important;
  place-items: center !important;
  border-radius: 999px !important;
  border: 2px solid currentColor !important; /* uses your existing text color */
  margin-right: 12px !important;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.2));
}

/* Make SVG or IMG inside link larger */
#sd-footer a[href*="instagram"] svg,
#sd-footer a[href*="tiktok"] svg,
#sd-footer a[href*="facebook"] svg,
#sd-footer a[href*="pinterest"] svg,
#sd-footer a[href*="twitter"] svg,
#sd-footer a[href*="x.com"] svg,
#sd-footer a[href*="youtube"] svg,
#sd-footer a[href*="instagram"] img,
#sd-footer a[href*="tiktok"] img,
#sd-footer a[href*="facebook"] img,
#sd-footer a[href*="pinterest"] img,
#sd-footer a[href*="twitter"] img,
#sd-footer a[href*="x.com"] img,
#sd-footer a[href*="youtube"] img{
  width: 22px !important;
  height: 22px !important;
  object-fit: contain !important;
}

/* Make the copyright / bottom row more prominent */
#sd-footer .footer__bottom,
#sd-footer .site-footer__bottom,
#sd-footer .footer-bottom,
#sd-footer .footer__legal,
#sd-footer .footer-legal{
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 14px !important;
  margin-top: 22px !important;
  padding-top: 14px !important;
  border-top: 1px solid rgba(0,0,0,.14) !important;  /* subtle divider */
  flex-wrap: wrap !important;
}

/* Catch the copyright text even if the class name differs */
#sd-footer .footer__copyright,
#sd-footer .site-footer__copyright,
#sd-footer [class*="copyright"],
#sd-footer [class*="rights"],
#sd-footer [class*="legal"]{
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: 0.02em !important;
  line-height: 1.35 !important;
  text-shadow: 0 1px 0 rgba(0,0,0,.18); /* subtle legibility boost */
  margin: 0 !important;
}

/* Mobile tweaks */
@media (max-width: 640px){
  #sd-footer a[href*="instagram"],
  #sd-footer a[href*="tiktok"],
  #sd-footer a[href*="facebook"],
  #sd-footer a[href*="pinterest"],
  #sd-footer a[href*="twitter"],
  #sd-footer a[href*="x.com"],
  #sd-footer a[href*="youtube"]{
    width: 38px !important;
    height: 38px !important;
    margin-right: 10px !important;
  }
}
/* --- Footer bottom rule above Utilities (full width) --- */
#sd-footer .footer-content > *:last-child {
  grid-column: 1 / -1 !important; /* let the last row span the full grid */
}

#sd-footer .footer-content > *:last-child::before {
  content: "";
  display: block;
  height: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.65); /* the line */
  margin: 12px 0 18px;  /* spacing above/below the rule */
}

/* Optional: brighten socials + copyright a bit more */
#sd-footer .footer-content .social-links a,
#sd-footer .footer-content .social-links a svg {
  color: #fff !important;
  opacity: .95;
}

#sd-footer .footer-content .copyright,
#sd-footer .footer-content .copyright a {
  color: rgba(255,255,255,.9) !important;
}
footer.section .footer-content > *:last-child { grid-column: 1 / -1 !important; }
footer.section .footer-content > *:last-child::before {
  content:""; display:block; border-top:1px solid rgba(255,255,255,.65); margin:12px 0 18px;
}
.pi-card__meta { display: block; margin-top: .5rem; }
.pi-card__title { font-weight: 600; line-height: 1.2; color: #6f7f47; }
.pi-card__price { margin-top: .25rem; color: #2f2f2f; }
.pi-card__price-was { margin-left: .4rem; text-decoration: line-through; opacity: .6; }
.pi-card__image { display: block; }
.pi-card__img { display: block; width: 100%; height: auto; border-radius: 10px; }
/* ABOUT: forced styles for this specific Image-with-text */
#shopify-section-template--19525943984301__section_Uzp9yA .media{
  position:relative!important;
  overflow:hidden!important;
  border-radius:14px!important;
}

/* warm gold overlay */
#shopify-section-template--19525943984301__section_Uzp9yA .media::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(255,204,0,0.25) 0%, rgba(255,255,255,0.4) 100%);
  mix-blend-mode:multiply;
  pointer-events:none;
  border-radius:inherit;
}

/* gentle hover pop */
#shopify-section-template--19525943984301__section_Uzp9yA .media img,
#shopify-section-template--19525943984301__section_Uzp9yA .media .media__image{
  display:block;
  border-radius:14px!important;
  transition:transform .6s ease, box-shadow .4s ease!important;
  will-change:transform;
}
#shopify-section-template--19525943984301__section_Uzp9yA .media:hover img,
#shopify-section-template--19525943984301__section_Uzp9yA .media:hover .media__image{
  transform:scale(1.03)!important;
  box-shadow:0 8px 25px rgba(255,204,0,.4)!important;
}

/* fade-up the text column */
#shopify-section-template--19525943984301__section_Uzp9yA .image-with-text__content,
#shopify-section-template--19525943984301__section_Uzp9yA .image-with-text__text,
#shopify-section-template--19525943984301__section_Uzp9yA .rte{
  opacity:0;
  transform:translateY(16px);
  animation:aboutFadeUp .8s ease forwards .1s;
}
@keyframes aboutFadeUp{to{opacity:1; transform:translateY(0)}}
/* ===== Account / Sign-in modal (broad selectors to match Savor) ===== */
.modal--account .modal__header,
.drawer--account .drawer__header,
[id*="account"].modal .modal__header {
  background: #ffefdd;         /* header bg */
  color: #4a2b10;               /* header text */
}

/* Primary button in the account modal (Sign in) */
.modal--account .button,
.modal--account button[type="submit"],
.drawer--account .button,
[id*="account"].modal .button {
  background:rgb(255, 255, 255);          /* brand maroon */
  color:rgb(2, 2, 2);
  border: 1px solid #7f1515;
}
.modal--account .button:hover,
.drawer--account .button:hover,
[id*="account"].modal .button:hover {
  filter: brightness(0.92);
}

/* Optional: tabs inside the account area (Orders / Profile) */
.modal--account .tabs__list a,
.drawer--account .tabs__list a,
[id*="account"].modal .tabs__list a {
  background: #fff; 
  color: #4a2b10;
  border: 1px solid #ffd9a6;
}
.modal--account .tabs__list a.is-active,
.drawer--account .tabs__list a.is-active,
[id*="account"].modal .tabs__list a.is-active {
  background: #ffefdd;
  color: #7f1515;
  border-color: #ffa51f;
}
/* Add to cart button with price inside */
.pi-atc-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
}

.pi-atc-btn .pi-atc-price {
  font-size: 0.95em;
  opacity: 0.9;
}
/* Hide standalone price on Product Info Tabs layout */
.pi-section .price,
.pi-section .product__price,
.pi-section .pi-price {
  display: none;
}
/* Layout: quantity + add to cart side by side */
.pi-actions {
  display: flex;
  gap: 0.75rem;
  align-items: stretch;
  margin-top: 1.25rem;
}
/* Quantity pill */
.pi-qty {
  display: flex;
  align-items: center;
  border: 1px solid #5c3b17;          /* tweak color to match your theme */
  border-radius: 999px;
  overflow: hidden;
  background: #ffffff;
  min-width: 110px;
}

/* +/- buttons */
.pi-qty-btn {
  width: 2.5rem;
  height: 2.75rem;
  border: none;
  background: transparent;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

/* Quantity input */
.pi-qty-input {
  width: 2.75rem;
  height: 2.75rem;
  border: none;
  text-align: center;
  font-size: 1rem;
  outline: none;
}

/* Hide number arrows in some browsers */
.pi-qty-input::-webkit-outer-spin-button,
.pi-qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.pi-qty-input[type=number] {
  -moz-appearance: textfield;
}
/* Add to cart pill */
.pi-btn-primary.pi-atc-btn {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
  border-radius: 999px;
  border: none;
  height: 2.75rem;
  background: #d4a52a;       /* your brand yellow/gold – change if needed */
  color: #ffffff;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
}

/* Price text inside button */
.pi-atc-btn .pi-atc-price {
  font-size: 0.95em;
  opacity: 0.9;
}

/* Optional hover */
.pi-btn-primary.pi-atc-btn:hover {
  filter: brightness(0.95);
}
/* OUR PICKS – make SEE DETAILS button full width */
.imggrid4__cta {
  margin-top: 12px;
}

.imggrid4__btn {
  display: block;        /* makes it fill the row */
  width: 100%;           /* full width of the card/picture */
  text-align: center;    /* center the text */
  padding: 0.9rem 0;     /* equal padding left/right */
  border-radius: 999px;  /* keeps the pill shape */
  text-decoration: none; /* no underline */
}
/* 🌼 Flower button on products page (VIEW button) */
.products-page-view-btn a,
.products-page-view-btn button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  width: 100%;
  padding: 1.1rem 3rem;      /* controls click area */
  border: none;
  background: transparent;   /* we draw the flower behind it */
  cursor: pointer;

  color: #ffffff;
  font-weight: 700;
  text-transform: uppercase;
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  text-decoration: none;

  z-index: 0;
}
.template-collection .products-page-view-btn a,
.template-collection .products-page-view-btn button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 1.1rem 3rem;
  background: transparent;
  border: none;
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  z-index: 0;
}

.template-collection .products-page-view-btn a::before,
.template-collection .products-page-view-btn button::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 3rem;
  height: 3rem;
  transform: translate(-50%, -50%);
  background: #7a8a54;
  border-radius: 50%;
  z-index: -1;
  box-shadow:
    0 -2rem 0 #7a8a54,
    0  2rem 0 #7a8a54,
    -2rem 0 0 #7a8a54,
    2rem 0 0 #7a8a54;
}
/* Sun Daughters - About Story section */
.sd-story {
  background: #ffeeda; /* soft cream */
  padding: 60px 0;
}

.sd-story__inner {
  max-width: 1100px;
  margin: 0 auto;
}

.sd-story__heading {
  margin-bottom: 16px;
}

.sd-story__body p {
  margin-bottom: 12px;
}

.sd-story__signature {
  margin-top: 24px;
  font-weight: 600;
}

/* layout for desktop */
@media (min-width: 900px) {
  .sd-story__inner {
    display: flex;
    align-items: center;
    gap: 48px;
  }
  .sd-story__text {
    flex: 0 0 50%;
  }
  .sd-story__media {
    flex: 0 0 50%;
    position: relative;
    padding: 40px 0;
  }
}

/* image + green shape */
.sd-story__media::before {
  content: "";
  position: absolute;
  top: 8%;
  left: -12%;
  width: 70%;
  height: 84%;
  background: #c7ec9a; /* soft green blob */
  border-radius: 999px;
  z-index: 0;
}
/* Recipe page layout */
.recipe-page {
  padding: 60px 0 80px;
}

.recipe-page__inner {
  display: grid;
  gap: 40px;
}

@media (min-width: 900px) {
  .recipe-page__inner {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    align-items: flex-start;
  }
}

.recipe-page__title {
  font-size: clamp(28px, 4vw, 40px);
  margin-bottom: 24px;
}

.recipe-page__subheading {
  margin-top: 24px;
  margin-bottom: 8px;
  font-weight: 700;
}

.recipe-page__ingredients,
.recipe-page__method {
  line-height: 1.6;
}

.recipe-page__back {
  display: inline-block;
  margin-top: 28px;
  padding: 10px 22px;
  border-radius: 999px;
  background: #ffcc00;
  color: #000;
  text-decoration: none;
  font-weight: 600;
}

.recipe-page__image-wrap {
  max-width: 500px;
  margin: 0 auto;
}

.recipe-page__image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  object-fit: cover;
}
/* Recipe page basic layout */
.recipe-page {
  padding: 60px 0 80px;
}

.recipe-page__header {
  text-align: center;
  margin-bottom: 40px;
}

.recipe-page__title {
  margin-bottom: 16px;
}

.recipe-page__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 32px;
  border-radius: 999px;
  background: #ffcc00;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
}

.recipe-page__body {
  display: grid;
  gap: 40px;
}

@media (min-width: 900px) {
  .recipe-page__body {
    grid-template-columns: minmax(260px, 1fr) minmax(260px, 1.2fr);
    align-items: flex-start;
  }
}

.recipe-page__image {
  max-width: 450px;
  margin: 0 auto;
}

.recipe-page__img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  object-fit: cover;
}

.recipe-page__subheading {
  margin: 0 0 8px;
  font-weight: 700;
}

.recipe-page__paragraph {
  margin: 0 0 24px;
  line-height: 1.6;
}
/* Bring recipe recommended products closer to the content */
.template-page--recipe .pi-recos,
.page-template--recipe .pi-recos,
#MainContent .pi-recos {
  margin-top: 32px !important;    /* was probably very large */
}

/* Optional: reduce bottom padding on the recipe content itself */
.template-page--recipe .recipe-layout,
.page-template--recipe .recipe-layout {
  padding-bottom: 32px !important;
}
/* Hide default product recommendations list under PI recommendations */
.product-recommendations,
.product-recommendations__inner {
  display: none !important;
}
/* Recs section – use smaller gutters and full width */
#pi-recos-{{ section.id }}{
  --side-pad: clamp(8px, 2vw, 20px);   /* smaller padding on the sides */
  padding-left: var(--side-pad);
  padding-right: var(--side-pad);

  max-width: 100%;                    /* no narrow box */
  margin: 0;                          /* no centering box */
}
/* Mobile: add outline to white buttons so they are visible */
@media (max-width: 749px) {

  /* Adjust selectors if your buttons use different classes */
  .button,
  .btn,
  a.button--primary,
  a.button--secondary {
    border: 2px solid #ffd230;   /* outline color – use your brand yellow */
    color: #ffd230;              /* text matches outline */
  }

  /* If you want the inside still white, keep this */
  .button,
  .btn,
  a.button--primary,
  a.button--secondary {
    background-color: #ffffff;
  }

  /* Optional: make text bold for better readability */
  .button,
  .btn {
    font-weight: 600;
  }
}
@media (max-width: 749px) {
  .hero .button,
  .about-section .button {
    border: 2px solid #ffd230;
    color: #ffd230;
  }
}
/* --- MOBILE BUTTON FIX --- */
@media (max-width: 749px) {

  /* Fix ALL main buttons on small screens */
  .button,
  .button--primary,
  .button--secondary,
  .hero__button a,
  .hero__cta a {
    border: 2px solid #d39e4a !important; /* your golden color */
    background-color: #d39e4a !important;
    color: #ffffff !important;
    padding: 12px 22px !important;
    border-radius: 6px !important;
    display: inline-block !important;
  }

  /* If the theme uses link-style buttons */
  .button--link {
    border: 2px solid #d39e4a !important;
    background-color: transparent !important;
    color: #d39e4a !important;
  }
}
/* === HERO CTA button (desktop + mobile) === */
#shop-all-hero .button,
#shop-all-hero .btn,
#shop-all-hero a.button {
  background: #c8913c;
  color: #fff;
  border-radius: 999px;
  padding-inline: 32px;
}

/* Keep the outline / border on mobile as well */
@media (max-width: 768px) {
  #shop-all-hero .button,
  #shop-all-hero .btn,
  #shop-all-hero a.button {
    border: 2px solid #c8913c;
    background: transparent;   /* if you want outlined style */
    color: #c8913c;
  }
}

/* === ABOUT page Learn More button === */
.about-section .button,
.about-section .btn,
.about-section a.button {
  background: #c8913c;
  color: #fff;
  border-radius: 999px;
  padding-inline: 32px;
}

@media (max-width: 768px) {
  .about-section .button,
  .about-section .btn,
  .about-section a.button {
    border: 2px solid #c8913c;
    background: transparent;
    color: #c8913c;
  }
}
/* Force header icons to stay clean on mobile */
.header__icon,
.header__icon .button,
.header__icon .btn,
.header__icon a {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}
/* Make sure header icons (search, cart) keep the default look on mobile */
@media (max-width: 749px) {
  .header__icons .button,
  .header__icon button,
  .header__icon-button {
    background: transparent !important;
    border: none !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    border-radius: 0 !important;
  }
}
/* FIX: don't style header icons like buttons on mobile */
@media (max-width: 749px) {
  .header__icons button,
  .header__icons .button,
  .site-header__icons button,
  .site-header__icons .button,
  header button,
  header .button {
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
    min-width: auto !important;
  }
}
/* === HEADER SEARCH ICON FIX === */

/* Remove the gold button styling from the search action */
.header__actions .header__action-item--search button,
.header__actions .header__action-item--search .button {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

/* Make sure the header search has no extra box around it */
.header__actions .header__action-item--search {
  background: transparent !important;
}
/* Make the search icon itself green */
.header__actions .header__action-item--search svg,
.header__actions .header__action-item--search svg * {
  stroke: #7a8a54 !important;  /* outline color */
  fill:   #7a8a54 !important;  /* for themes that use fill */
}
/* RESET HEADER ICON BUTTONS (mobile + desktop) */
.header__icons .header__icon,
.header__icons .header__icon-button,
.header__icons button.header__icon {
  background: transparent !important;   /* no gold block */
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  color: #7a8a54;                       /* green icon */
}

/* Make sure the SVG itself is visible and uses that color */
.header__icons .header__icon svg,
.header__icons .header__icon-button svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
}
/* Sun Daughters – fix search icon color */
.header [data-icon="search"] svg,
.header .icon-search,
.header .icon-search svg,
.header__search-toggle svg,
.header__search-toggle .icon {
  color: #7a8a54 !important;   /* your green */
  stroke: #7a8a54 !important;
  fill: none !important;
}

/* make sure the button itself doesn’t add a white background */
.header__search-toggle,
.header__icon-button[data-action="toggle-search"] {
  background: transparent !important;
  border: none !important;
}
/* ===== FIX SEARCH ICON COLOR (DESKTOP + MOBILE) ===== */

/* 1) Target the search icon button itself – no white background */
.header__icon--search,
button[aria-label="Search"],
a[aria-label="Search"] {
  background: transparent !important;
  border: none !important;
}

/* 2) Force the magnifying glass to be green */
.header__icon--search svg,
.header__icon--search svg *,
button[aria-label="Search"] svg,
button[aria-label="Search"] svg *,
a[aria-label="Search"] svg,
a[aria-label="Search"] svg * {
  fill: #7a8a54 !important;   /* your green */
  stroke: #7a8a54 !important;
}

/* In case your theme uses .icon-search class */
.icon-search,
.icon-search * {
  fill: #7a8a54 !important;
  stroke: #7a8a54 !important;
}
header svg.icon-search path {
  fill: #7a8a54 !important;
  stroke: #7a8a54 !important;
}
/* ================================
   FIX SEARCH RESULTS BLACK BLOCKS
   ================================ */

/* Remove any black background from product info on the search page */
.template-search .card__inner,
.template-search .card__content,
.template-search .card__information,
.template-search .product-card,
.template-search .product-card__info {
  background: transparent !important;
  box-shadow: none !important;
}

/* Make sure the product names & prices are visible */
.template-search .card__heading,
.template-search .card-information__text,
.template-search .product-card__title,
.template-search .price,
.template-search .price__regular,
.template-search .price__sale {
  color: #6f7f47 !important;  /* your green */
}

/* Just in case anything is getting clipped to a black block */
.template-search .card {
  overflow: visible !important;
}
/* ------- FIX SEARCH RESULTS GRID ------- */

/* Remove the black block behind each result */
.template-search .product-grid__item {
  background: transparent !important;
  box-shadow: none !important;
}

/* Make sure the card itself doesn’t introduce a dark background */
.template-search .product-grid__item .card,
.template-search .product-grid__item .card__inner {
  background: transparent !important;
}

/* Ensure title + price are visible in your usual green */
.template-search .product-grid__item .card__heading,
.template-search .product-grid__item .price,
.template-search .product-grid__item .price-item {
  color: #6f7f47 !important;   /* adjust if you use a different green */
}
/* --- Fix tiny black mark on search result product images --- */

/* Remove any overlay pseudo-elements the theme adds on cards */
.template-search .product-grid__item::before,
.template-search .product-grid__item::after {
  content: none !important;
  background: transparent !important;
}

/* Make sure there is no outline / box-shadow left on the cards */
.template-search .product-grid__item,
.template-search .product-grid__item * {
  outline: none !important;
  box-shadow: none !important;
}
/* ---- Fix tiny black mark on search results cards ---- */
.template-search .product-grid__item,
.template-search .product-card {
  background: transparent !important;
  border: none !important;
}

/* Remove any pseudo-elements that might be drawing a tiny bar/shape */
.template-search .product-grid__item::before,
.template-search .product-grid__item::after,
.template-search .product-card::before,
.template-search .product-card::after {
  content: none !important;
  display: none !important;
}
/* Remove the tiny dark bar under product images on the search page */
.template-search .product-grid__item,
.template-search .product-card,
.template-search .product-card__image {
  border: none !important;
  box-shadow: none !important;
}

/* In case the line is a pseudo-element */
.template-search .product-card__image::before,
.template-search .product-card__image::after,
.template-search .product-card::before,
.template-search .product-card::after {
  content: none !important;
  border: none !important;
  box-shadow: none !important;
}
/* Remove the tiny dark bar under product images on the search page */
.template-search .product-grid__item,
.template-search .product-card,
.template-search .product-card__image {
  border: none !important;
  box-shadow: none !important;
}

/* In case the line is a pseudo-element */
.template-search .product-card__image::before,
.template-search .product-card__image::after,
.template-search .product-card::before,
.template-search .product-card::after {
  content: none !important;
  border: none !important;
  box-shadow: none !important;
}
/* SEARCH RESULTS – kill the tiny black bar under product images */
results-list .product-grid__item img {
  display: block;              /* removes any tiny gaps from inline images */
}

/* Remove borders / background that create the thin black strip */
results-list .product-grid__item .product-card,
results-list .product-grid__item .product-card__inner,
results-list .product-grid__item .product-card__meta,
results-list .product-grid__item .card-information,
results-list .product-grid__item .card-information__wrapper {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Just in case there is specifically a top border on the meta area */
results-list .product-grid__item .product-card__meta,
results-list .product-grid__item .card-information {
  border-top: none !important;
}
results-list .product-grid__item * {
  border-color: transparent !important;
}
/* --- Fix black strip on search results cards --- */

/* search template only */
.template-search .section-background,
.template-search .product-grid-container,
.template-search .product-grid,
.template-search .product-grid__item,
.template-search .product-grid__item::before,
.template-search .product-grid__item::after {
  background: transparent !important;
  box-shadow: none !important;
}

/* make sure the page background shows instead */
.template-search body,
.template-search .section {
  background-color: #fff !important; /* or your page background color */
}
/* --- Kill the tiny black bar on the search results grid --- */

/* Remove any black bg / border from search result product items */
.template-search .product-grid__item,
.template-search .product-grid__item::before,
.template-search .product-grid__item::after {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Just in case the container itself is painting a line */
.template-search .product-grid-container,
.template-search .product-grid-container::before,
.template-search .product-grid-container::after {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

/* Make sure list items don’t leave a 1px row hanging around */
.template-search .product-grid__item {
  display: flex;
  flex-direction: column;
}
/* FIX: Remove leftover black bar above/below product images */
.product-card__inner,
.product-card__media,
.product-card__image-wrapper,
.product-grid__item::before,
.product-card::before {
    background: transparent !important;
    box-shadow: none !important;
}

/* Remove any black ::after pseudo-elements Savor adds */
.product-card__inner::after,
.product-card::after,
.product-grid__item::after {
    background: transparent !important;
    content: none !important;
}

/* Ensure no bar comes from misplaced border */
.product-card,
.product-card__inner,
.product-card__media {
    border: none !important;
}

/* Prevent the “highlight box” from showing a black strip */
.product-card__media img {
    display: block !important;
}
/* FIX: Remove leftover black bar above/below product images */
.product-card__inner,
.product-card__media,
.product-card__image-wrapper,
.product-grid__item::before,
.product-card::before {
    background: transparent !important;
    box-shadow: none !important;
}

/* Remove any black ::after pseudo-elements Savor adds */
.product-card__inner::after,
.product-card::after,
.product-grid__item::after {
    background: transparent !important;
    content: none !important;
}

/* Ensure no bar comes from misplaced border */
.product-card,
.product-card__inner,
.product-card__media {
    border: none !important;
}

/* Prevent the “highlight box” from showing a black strip */
.product-card__media img {
    display: block !important;
}
.product-grid-view-zoom-out--details {
  display: none !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
}
/* === Predictive search popup background === */

/* Main search panel */
.predictive-search,
.predictive-search__results,
.predictive-search__results-inner,
.search-modal__content {
  background-color: #ffffff !important;
}

/* “Recently viewed / Products” area */
.predictive-search__results-list,
.predictive-search__item {
  background-color: #ffffff !important;
}

/* Dimmed overlay behind the panel */
.search-modal__overlay,
.predictive-search__overlay {
  background-color: rgba(255, 255, 255, 0.95) !important; /* almost solid white */
}

/* Make sure text stays readable */
.predictive-search__heading,
.predictive-search__item-heading,
.predictive-search__item-price {
  color: #4f6340; /* your green-ish text color */
}
/* === SEARCH DRAWER STYLING (SUNDaughters) === */

/* Overall search overlay background */
.predictive-search,
.predictive-search__results,
.search-modal,
.search-modal__content {
  background: #ffffff !important;   /* white */
}

/* Headings like "Products", "Collections" */
.predictive-search__heading,
.predictive-search__title,
.search-modal__title {
  color: #6f7f47;                  /* your soft green */
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 600;
}

/* Product titles */
.predictive-search__item-heading,
.predictive-search__item-content h3,
.predictive-search__item-content a {
  color: #6f7f47;                  /* green */
  font-weight: 600;
}

/* Prices */
.predictive-search__item-price,
.predictive-search__item-price span {
  color: #b47c2e;                  /* warm golden-brown */
}

/* Remove / soften dark bar at the bottom */
.predictive-search__footer,
.search-modal__footer {
  background: #ffffff !important;
  box-shadow: 0 -1px 0 rgba(0, 0, 0, 0.06);
}

/* "View all" button */
.predictive-search__view-all,
.predictive-search__submit,
.search-modal__button {
  background: #ffd230;             /* your yellow */
  color: #ffffff;
  border-radius: 999px;
  padding-inline: 2.5rem;
  font-weight: 700;
  text-transform: uppercase;
  border: none;
}

.predictive-search__view-all:hover,
.predictive-search__submit:hover,
.search-modal__button:hover {
  filter: brightness(0.95);
}

/* Hover state for each result row */
.predictive-search__item:hover,
.predictive-search__item:focus-within {
  background: #fff9e0;             /* very soft yellow */
}
/* === SEARCH POPUP COLORS (SAVOR) ================================= */

/* Make the predictive search / search popup background white */
.predictive-search,
.predictive-search__results,
.search-modal,
.search-modal__content,
.search-modal__results,
.search-modal__results-wrapper {
  background-color: #ffffff !important;
  color: #7a8a54 !important; /* your soft green */
}

/* Headings & product titles in the popup */
.predictive-search__heading,
.predictive-search__item-heading,
.predictive-search__item-heading a {
  color: #7a8a54 !important;
}

/* Prices inside search results */
.predictive-search__item .price,
.predictive-search__item .price__regular,
.predictive-search__item .price__sale {
  color: #7a8a54 !important;
}

/* "VIEW ALL" button in the search popup */
.predictive-search__view-all,
.predictive-search__view-all .button,
.search-modal__view-all,
.search-modal__view-all .button {
  background-color: #ffd230 !important; /* yellow */
  color: #ffffff !important;
  border-radius: 999px;
  padding: 0.7rem 2.8rem;
  border: none;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

/* Remove any dark gradient overlay at the bottom, if the theme adds one */
.predictive-search::before,
.search-modal::before {
  display: none !important;
  background: none !important;
}
.media--root .media-scrubber,
.shopify-model-viewer-ui {
  display: none !important;
}
/* Fix product card double-image overlay on mobile */
.card__media,
.product-card__media,
.card-media__hover,
.card-media--hover {
  opacity: 1 !important;
  display: block !important;
}

.card-media__hover img,
.card__media--hover img {
  display: none !important;
}

@media (max-width: 749px) {
  .card-media__hover,
  .card__media--hover {
    display: none !important;
  }
}
/* Force product card images to crop the same on mobile */
@media (max-width: 749px) {
  .product-grid .media img,
  .collection .media img,
  .card--product .media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .product-grid .media,
  .collection .media,
  .card--product .media {
    aspect-ratio: 1 / 1; /* makes them square */
    overflow: hidden;
  }
}
/* Hide product name & price on search results page
   because the yellow pill button already shows them */
.template-search .product-grid__item h3,
.template-search .product-grid__item .price,
.template-search .product-grid__item .product-card__title,
.template-search .product-grid__item .product-card__price {
  display: none;
}
/* Make search magnifying glass visible on the search page */
.template-search .field__icon,
.template-search .field__icon svg,
.template-search .predictive-search__submit svg {
  color: #4b6d3c;   /* change to your green/yellow if you want */
  fill: #4b6d3c;
  stroke: #4b6d3c;
}
/* Make the search magnifying glass visible on the search results page */
.template-search button[type="submit"] svg,
.template-search .field__button svg,
.template-search .field__icon svg,
.template-search .icon-search,
.template-search .icon-search svg {
  color: #4b6d3c;   /* pick your color */
  fill: #4b6d3c;
  stroke: #4b6d3c;
}
/* Circular yellow SOLD OUT badge */
.badge--sold-out {
  background-color: #ffd230 !important; /* yellow */
  color: #ffffff !important;
  border-radius: 9999px !important;     /* circle */
  min-width: 72px;
  min-height: 72px;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 0.8rem;
  text-transform: uppercase;

  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
  transform: rotate(-18deg);           /* tilted like your example */
  box-shadow: 0 4px 10px rgba(0,0,0,0.18);
}
/* ================================
   SEARCH MODAL – DESKTOP VIEW ALL
   Make desktop match mobile style
   ================================ */
@media (min-width: 750px) {
  /* Remove the dark gradient at the bottom */
  .search-modal .predictive-search__results::after {
    display: none !important;
  }

  /* Make the footer area light, not black */
  .search-modal .predictive-search__results-footer,
  .search-modal .predictive-search__footer {
    background: #f4f4f4 !important; /* light grey like the rest of the modal */
    box-shadow: none !important;
  }

  /* Style the "VIEW ALL" button like mobile */
  .search-modal .predictive-search__button,
  .search-modal .predictive-search__footer .button,
  .search-modal .predictive-search__footer button {
    background-color: #dca341 !important;  /* your gold */
    color: #ffffff !important;
    border-radius: 999px;
    border: none;
    padding: 0.75rem 2.25rem;
    font-weight: 700;
  }

  .search-modal .predictive-search__footer .button:hover,
  .search-modal .predictive-search__button:hover {
    background-color: #ffa51f !important;  /* a bit brighter on hover */
  }
}
/* Desktop search modal button styles */
@media (min-width: 900px) {
  .search-modal .search-modal__footer .button,
  .search-modal .search-modal__footer .button:visited,
  .search-modal .predictive-search button.button {
    background-color: #ffa51f;   /* orange */
    border-color: #ffa51f;
    color: #ffffff;              /* white text */
  }
}/* Desktop search modal footer + button */
@media (min-width: 900px) {
  /* bottom gradient */
  .search-modal .search-modal__footer {
    background: linear-gradient(
      to top,
rgb(162, 190, 157) 0%,        /* solid green at bottom */
      rgba(79, 111, 74, 0) 100%
    ) !important;
  }

  /* "VIEW ALL" button */
  .search-modal .search-modal__footer .button,
  .search-modal .predictive-search button.button {
    background-color: #ffa51f !important; /* orange */
    border-color: #ffa51f !important;
    color: #ffffff !important;
  }
}
/* ==== DESKTOP PREDICTIVE SEARCH FOOTER ==== */
@media (min-width: 900px) {

  /* Green fade background at the bottom of the search modal */
  .search-modal .search-modal__footer,
  .search-modal .search-modal__footer::before {
    background: linear-gradient(
      0deg,
      #325b4d 0%,           /* solid green at bottom */
      rgba(50, 91, 77, 0) 70%
    ) !important;
  }

  /* Orange VIEW ALL button on desktop */
  .search-modal .search-modal__footer .button,
  .search-modal .search-modal__footer .button:visited,
  .search-modal .predictive-search button.button {
    background-color: #ffa51f !important; /* your orange */
    border-color: #ffa51f !important;
    color: #ffffff !important;
  }
}
/* Predictive search footer gradient + button (all screen sizes) */
.search-modal .search-modal__footer {
  /* green fade from bottom to transparent */
  background: linear-gradient(
    to top,
    #476a45 0%,        /* solid green at the very bottom */
    #476a45 40%,       /* still green a bit higher */
    rgba(71, 106, 69, 0) 100%  /* fades to transparent */
  );
}

/* "VIEW ALL" button – orange */
.search-modal .search-modal__footer .button,
.search-modal .search-modal__footer .button.button-primary,
.search-modal .predictive-search-form__footer .button.button-primary {
  background-color: #ffa51f;
  border-color: #ffa51f;
  color: #ffffff;
}





