/** Shopify CDN: Minification failed

Line 6328:0 All "@import" rules must come first

**/
* {
  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);
  --submenu-animation-speed: 360ms;
  --submenu-animation-easing: cubic-bezier(0.25, 0.1, 0.25, 1);
}

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,
textarea:hover {
  background-color: var(--color-input-hover-background);
}

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

.collection-card,
.featured-blog-posts-card {
  width: 100%;
  position: relative;
  height: 100%;
}

/* Editorial layout */
.resource-list:not(.hidden--desktop) .collection-card--flexible-aspect-ratio,
.resource-list:not(.hidden--desktop) .blog-post-card--flexible-aspect-ratio {
  .collection-card__image,
  .featured-blog-posts-card__image,
  .blog-placeholder-svg {
    aspect-ratio: 99;
    height: 100%;
  }

  .collection-card__inner,
  .featured-blog-posts-card__inner {
    display: flex;
    flex-direction: column;
    height: 100%;
  }

  .collection-card__content,
  .featured-blog-posts-card__content {
    flex-shrink: 0;
  }

  &:not(.collection-card--image-bg) .collection-card__content,
  .featured-blog-posts-card__content {
    height: auto;
  }
}

.collection-card__inner,
.featured-blog-posts-card__inner {
  width: 100%;
  overflow: hidden;
  position: relative;
  display: flex;
  flex-direction: column;
  z-index: var(--layer-flat);
  pointer-events: none;
}

.collection-card__content,
.featured-blog-posts-card__content {
  display: flex;
  position: relative;
  height: 100%;
  width: 100%;
  gap: var(--gap);
}

.collection-card__link,
.featured-blog-posts-card__link {
  position: absolute;
  inset: 0;

  /* allows focus outline to have radius in supported browsers */
  border-radius: var(--border-radius);
}

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

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

.product-card__content {
  position: relative;
}

.product-card__content {
  cursor: pointer;
}

@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 .predictive-search-results__card:hover {
    transform: translateY(calc(-1 * var(--hover-lift-amount)));
  }

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

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

  .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 .predictive-search-results__card:hover {
    transform: scale(var(--hover-subtle-zoom-amount));
  }

}

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;
  display: flex;
  flex-direction: column;
}

.content-for-layout > .shopify-section:last-child {
  flex-grow: 1;
}

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

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

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

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

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

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

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

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

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

  width: 100%;

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

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

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

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

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

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

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

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

@media screen and (max-width: 749px) {
  .section--mobile-full-width > * {
    grid-column: 1 / -1;
  }
}

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

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

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

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

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

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

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

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

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

/* Utility */

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

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

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

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

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

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

.contents {
  display: contents;
}

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

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

  display: flex;
  flex-direction: column;
}

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

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

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

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

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

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

.text-left {
  --text-align: left;

  text-align: left;
}

.text-center {
  --text-align: center;

  text-align: center;
}

.text-right {
  --text-align: right;

  text-align: right;
}

.text-inherit {
  color: inherit;
}

.user-select-text {
  user-select: text;
}

.justify-left {
  justify-content: left;
}

.justify-center {
  justify-content: center;
}

.justify-right {
  justify-content: right;
}

.title--aligned-center {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.background-image-container {
  overflow: hidden;
  position: absolute;
  inset: 0;
  opacity: var(--image-opacity);
}

.background-image-container img,
.background-image-container svg {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.background-image-fit img,
.background-image-fit svg {
  object-fit: contain;
}

.svg-wrapper {
  color: currentcolor;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
  pointer-events: none;
}

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

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

.svg-wrapper > svg {
  width: var(--icon-size-sm);
  height: var(--icon-size-sm);
}

.relative {
  position: relative;
}

/* Icons */
.icon-success,
.icon-error {
  width: var(--icon-size-md);
  height: var(--icon-size-md);
  flex-shrink: 0;
}

.icon-success {
  color: var(--color-success);
}

.icon-error {
  fill: var(--color-error);
}

.icon-default {
  fill: currentColor;
}

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

/* Base text and heading styles */
body,
.paragraph:not(.button),
.paragraph > *,
.text-block.paragraph :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h1 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h2 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h3 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h4 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h5 :is(h1, h2, h3, h4, h5, h6) {
  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 > *,
.text-block.h6 :is(h1, h2, h3, h4, h5, 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-secondary)),
.rte :is(p, ul, ol, table):not(.h1, .h2, .h3, .h4, .h5, .h6) a:where(:not(.button, .button-secondary)) {
  text-decoration-color: currentcolor;

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

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

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

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

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

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

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

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

/* All other header group content should be beneath the floating header,
but above the rest of the page content */
body:has(.header[transparent]) #header-group > *:not(.header-section) {
  z-index: calc(var(--layer-sticky) - 1);
}

/* Featured collection block */
.featured-collection-block {
  width: 100%;
}

/* Product grid */
.product-grid-container {
  display: block;
  width: 100%;
  padding-block: var(--padding-block-start) var(--padding-block-end);

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

.product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--product-grid-gap);
  margin: auto;
  padding: 0;
  list-style: none;
}

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

.product-grid :is(h3, p) {
  margin: 0;
}

.product-grid__item {
  border: var(--product-card-border-width) solid rgb(var(--color-border-rgb) / var(--product-card-border-opacity));
}

.product-grid--organic[product-grid-view='default'] .product-grid__item {
  height: fit-content;
}

.product-grid__card.product-grid__card {
  display: flex;
  flex-flow: column nowrap;
  gap: var(--product-card-gap);
  align-items: var(--product-card-alignment);
  text-decoration: none;
  color: var(--color, var(--color-foreground));
  padding-block: var(--padding-block-start) var(--padding-block-end);
  padding-inline: var(--padding-inline-start) var(--padding-inline-end);
  overflow: hidden;
}

[product-grid-view='zoom-out'] .product-grid__card {
  row-gap: var(--padding-xs);
}

[product-grid-view='default'] {
  --product-grid-gap: 16px;
  --padding-block-start: 24px;
  --padding-block-end: 24px;
  --padding-inline-start: 0px;
  --padding-inline-end: 0px;
}

[product-grid-view='default'] .product-grid__item {
  padding-block: 0;
}

[product-grid-view='mobile-single'],
.product-grid-mobile--large {
  @media screen and (max-width: 749px) {
    grid-template-columns: 1fr;
  }
}

.product-grid__card .group-block > * {
  @media screen and (max-width: 749px) {
    flex-direction: column;
  }
}

ul[product-grid-view='zoom-out'] .product-grid__card > * {
  display: none;
}

[product-grid-view='zoom-out'] {
  --product-grid-columns-desktop: repeat(
    10,
    minmax(clamp(50px, calc(100% - 9 * var(--product-grid-gap)) / 10, 80px), 1fr)
  );
}

.product-grid-view-zoom-out--details {
  display: none;
}

.product-grid-view-zoom-out--details .h4,
.product-grid-view-zoom-out--details span,
.product-grid-view-zoom-out--details s {
  font-size: var(--font-size--xs);
  font-family: var(--font-paragraph--family);
}

.product-grid-view-zoom-out--details span {
  font-weight: 500;
}

.product-grid-view-zoom-out--details .h4 {
  line-height: 1.3;
  font-weight: 400;
}

.product-grid-view-zoom-out--details > span.h6,
.product-grid-view-zoom-out--details > div.h6 > product-price {
  display: inline-block;
  line-height: 0;
  margin-top: var(--margin-2xs);
}

.product-grid-view-zoom-out--details > span.h6 > *,
.product-grid-view-zoom-out--details > div.h6 > * > * {
  line-height: 1.2;
}

@media (prefers-reduced-motion: no-preference) {
  :root:active-view-transition-type(product-grid) {
    details[open] floating-panel-component {
      view-transition-name: panel-content;

      .checkbox *,
      .facets__pill-label {
        transition: none;
      }

      .facets--vertical & {
        view-transition-name: none;
      }
    }

    .product-grid {
      view-transition-name: product-grid;
    }

    footer {
      view-transition-name: footer;
    }

    .product-grid__item,
    floating-panel-component {
      transition: none;
    }
  }
}

::view-transition-group(panel-content) {
  z-index: 1;
}

::view-transition-new(product-grid) {
  animation-delay: 150ms;
  animation-name: fadeInUp;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
}

results-list[initialized] {
  .product-grid__item {
    transition: opacity var(--animation-speed) var(--animation-easing),
      transform var(--animation-speed) var(--animation-easing);

    @starting-style {
      opacity: 0;
      transform: translateY(10px);
    }
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

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

/* Collection and product list cards have equal heights */
:is(.product-grid__item, .resource-list__item) .product-card {
  display: grid;
  height: 100%;
}

/* Video background */
.video-background,
.video-background * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.video-background--cover * {
  object-fit: cover;
}

.video-background--contain * {
  object-fit: contain;
}

.text-block {
  width: 100%;
}

.text-block > *:first-child,
.text-block > *:first-child:empty + * {
  margin-block-start: 0;
}

.text-block > *:last-child,
.text-block > *:has(+ *:last-child:empty) {
  margin-block-end: 0;
}

/* This is to deal with the margin applied to the p when custom styles are enabled. The p isn't the first child anymore due to the style tag */
.text-block > style + * {
  margin-block-start: 0;
}

/* Dialog */
.dialog-modal {
  border: none;
  box-shadow: var(--shadow-popover);

  @media screen and (min-width: 750px) {
    border-radius: var(--style-border-radius-popover);
    max-width: var(--normal-content-width);
  }

  @media screen and (max-width: 749px) {
    max-width: 100%;
    max-height: 100%;
    height: 100dvh;
    width: 100dvw;
    padding: var(--padding-md);
  }
}

.dialog-modal::backdrop {
  transition: backdrop-filter var(--animation-speed) var(--animation-easing);
  backdrop-filter: brightness(1);
  background: rgb(var(--backdrop-color-rgb) / var(--backdrop-opacity));
}

.dialog-modal[open] {
  animation: elementSlideInTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    animation: backdropFilter var(--animation-speed) var(--animation-easing) forwards;
    transition: opacity var(--animation-speed) var(--animation-easing);
  }
}

.dialog-modal.dialog-closing {
  animation: elementSlideOutTop var(--animation-speed) var(--animation-easing) forwards;

  &::backdrop {
    opacity: 0;
  }
}

/* stylelint-disable value-keyword-case */
.dialog-drawer {
  --dialog-drawer-opening-animation: move-and-fade;
  --dialog-drawer-closing-animation: move-and-fade;
}

.dialog-drawer--right {
  --dialog-drawer-opening-animation: move-and-fade;
  --dialog-drawer-closing-animation: move-and-fade;
}
/* stylelint-enable value-keyword-case */

.dialog-drawer[open] {
  --start-x: var(--custom-transform-from, 100%);
  --end-x: var(--custom-transform-to, 0px);
  --start-opacity: 1;

  animation: var(--dialog-drawer-opening-animation) var(--animation-speed) var(--animation-easing) forwards;
}

.dialog-drawer[open].dialog-closing {
  --start-x: 0px;
  --end-x: 100%;
  --start-opacity: 1;
  --end-opacity: 1;

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

.dialog-drawer--right[open] {
  --start-x: -100%;
  --start-opacity: 1;
}

.dialog-drawer--right[open].dialog-closing {
  --start-x: 0px;
  --end-x: -100%;
  --start-opacity: 1;
  --end-opacity: 1;

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

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

  display: grid;
  align-content: center;
  text-decoration: none;
  text-align: var(--text-align);
  color: var(--button-color);
  appearance: none;
  background-color: var(--button-background-color);
  border: none;
  font-family: var(--font-paragraph--family);
  font-style: var(--font-paragraph--style);
  font-weight: var(--font-paragraph--weight);
  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:not([type='checkbox'], [type='radio']) {
  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,
.show-more:where([data-expanded='true']) .show-more__button .icon-plus .horizontal {
  transform: rotate(90deg);
}

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

:not(.dialog-zoomed-gallery) > .product-media-container {
  --slide-width: 100%;

  display: flex;
  aspect-ratio: var(--gallery-aspect-ratio, var(--media-preview-ratio));
  max-height: var(--constrained-height);
  width: var(--slide-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;
  }

  @supports (--test: round(up, 100%, 1px)) {
    /* width and overflow forces children to shrink to parent width */
    --slide-width: round(up, 100%, 1px);
  }
}

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

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

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

  body:has(header-component[transparent]) .product-media-container.constrain-height {
    --viewport-offset: 0px;
  }

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

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

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

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

: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 {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  aspect-ratio: var(--size-style-aspect-ratio, auto);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

/* Variant option component */
.variant-option {
  --options-border-radius: var(--variant-picker-button-radius);
  --options-border-width: var(--variant-picker-button-border-width);
  --variant-option-padding-inline: var(--padding-md);
}

.variant-option + .variant-option {
  margin-top: var(--padding-lg);
}

.variant-option--swatches {
  --options-border-radius: var(--variant-picker-swatch-radius);

  width: 100%;

  overflow-list::part(list) {
    padding-block: var(--overflow-list-padding-block, 0);
    padding-inline: var(--overflow-list-padding-inline, 0);
  }
}

.variant-option--swatches > overflow-list {
  justify-content: var(--product-swatches-alignment);

  @media screen and (max-width: 749px) {
    justify-content: var(--product-swatches-alignment-mobile);
  }
}

.variant-option--buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gap-sm);
  margin: 0;
  padding: 0;
  border: none;
}

.variant-option--buttons legend {
  padding: 0;
  margin-block-end: var(--margin-xs);
}

.variant-option__swatch-value {
  padding-inline-start: var(--padding-xs);
  color: rgb(var(--color-foreground-rgb) / var(--opacity-70));
}

@media (prefers-reduced-motion: no-preference) {
  .variant-option__button-label,
  .variant-option__select-wrapper,
  .variant-option__button-label::before,
  .variant-option__button-label::after,
  .variant-option__button-label:has([data-previous-checked='true'], [data-current-checked='true'])
    .variant-option__button-label__pill,
  .variant-option__button-label:not(.variant-option__button-label--has-swatch) svg line:last-of-type {
    transition-duration: var(--animation-speed);
    transition-timing-function: var(--animation-easing);
  }

  .variant-option__button-label__pill {
    transition-property: transform;
  }

  .variant-option__button-label:not(.variant-option__button-label--has-swatch) svg line:last-of-type {
    transition-property: clip-path;
  }

  .variant-option__button-label:has([data-previous-checked='true'], [data-current-checked='true'])
    .variant-option__button-label__pill {
    transition-property: transform;
  }

  .variant-option__button-label::after {
    transition-property: clip-path;
  }

  .variant-option__button-label::before {
    transition-property: border-color;
  }

  .variant-option__select-wrapper,
  .variant-option__button-label {
    transition-property: background-color, border-color, color;
  }
}

.variant-option__button-label {
  --variant-picker-stroke-color: var(--color-variant-border);

  cursor: pointer;
  display: flex;
  flex: 0 0 3.25em;
  align-items: center;
  position: relative;
  padding-block: var(--padding-sm);
  padding-inline: var(--padding-lg);
  border: var(--options-border-width) solid var(--color-variant-border);
  border-radius: var(--options-border-radius);
  overflow: clip;
  justify-content: center;
  min-height: 3.25em;
  min-width: fit-content;
  white-space: nowrap;
  background-color: var(--color-variant-background);
  color: var(--color-variant-text);
  gap: 0;

  &:hover,
  &:hover:has([aria-disabled='true']):has([data-option-available='false']) {
    background-color: var(--color-variant-hover-background);
    border-color: var(--color-variant-hover-border);
    color: var(--color-variant-hover-text);
  }

  /* we need something like overflow-clip-margin to use the pseudoelement but it doesn't work in Safari */

  /* so instead use the layered background image trick */
  &:not(.variant-option__button-label--has-swatch):has([data-option-available='false']) {
    border-width: 0;
  }

  /* ::after/::before act as a fake border for the button style variant */

  /* ::after is the unavailable variant border that clips in */
  &:not(.variant-option__button-label--has-swatch)::before,
  &:has([data-option-available='false']):not(.variant-option__button-label--has-swatch)::after {
    content: '';
    position: absolute;
    inset: 0;
    border: var(--options-border-width) solid var(--color-selected-variant-border);
    border-radius: inherit;
    pointer-events: none;
    z-index: 2;
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(var(--clip, 0 0 0 0));
  }

  &:has([data-option-available='false']):not(.variant-option__button-label--has-swatch)::before {
    inset: 0;
  }

  &:not(.variant-option__button-label--has-swatch)::before {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(0 0 0 0);
    border-color: var(--color-variant-border);
    inset: calc(var(--options-border-width) * -1);
  }

  &:has(:checked):not(.variant-option__button-label--has-swatch, :has([data-option-available='false']))::before {
    border-color: var(--color-selected-variant-border);
  }

  /* setting left/right accounts for variant buttons of different widths */
  &:not(:has(:checked)):has(~ label > :checked),
  &:has(:checked):has(~ label > [data-previous-checked='true']) {
    .variant-option__button-label__pill {
      right: 0;
      left: unset;
    }
  }

  &:has([data-previous-checked='true']) ~ label:has([data-current-checked='true']),
  &:has(:checked) ~ label {
    .variant-option__button-label__pill {
      left: 0;
      right: unset;
    }
  }

  &:not(:has(:checked)):has(~ label > :checked) {
    --pill-offset: calc(100% + 1px);
  }

  &:has(:checked) ~ label {
    --pill-offset: calc(-100% - 1px);
  }

  &:has([data-current-checked='true']):first-of-type
    ~ label:last-of-type:not(.variant-option__button-label--has-swatch),
  &:not(:has(:checked)):has(~ label > :checked):not(.variant-option__button-label--has-swatch) {
    --clip: 0 0 0 100%;
  }

  &:not(:has([data-current-checked='true'])):first-of-type:has(~ label:last-of-type > :checked):not(
      .variant-option__button-label--has-swatch
    ),
  &:has(:checked) ~ label:not(.variant-option__button-label--has-swatch) {
    --clip: 0 100% 0 0;
  }

  &:has([data-previous-checked='true'], [data-current-checked='true']) .variant-option__button-label__pill {
    width: max(var(--pill-width-current, 100%), var(--pill-width-previous, 100%));
  }

  @media screen and (min-width: 750px) {
    padding: var(--padding-xs) var(--variant-option-padding-inline);
  }
}

/* wrap around only for 3 or more variants in a row */

/* the more complex selector rules here produce the wrap around effect for first/last variants */
.variant-option--buttons:has(:nth-of-type(3)) {
  .variant-option__button-label:has([data-current-checked='true']):first-of-type ~ label:last-of-type {
    --pill-offset: calc(100% + 1px);
  }

  .variant-option__button-label:not(:has([data-current-checked='true'])):first-of-type:has(
      ~ label:last-of-type > :checked
    ) {
    --pill-offset: calc(-100% - 1px);
  }
}

.variant-option__button-label__pill {
  background: var(--color-selected-variant-background);
  position: absolute;
  top: calc(var(--options-border-width) * -1);
  bottom: calc(var(--options-border-width) * -1);
  border-radius: inherit;
  pointer-events: none;
  width: 100%;
  transform: translateX(var(--pill-offset, 0));
}

.variant-option__button-label__text {
  pointer-events: none;
  text-align: start;
  text-wrap: auto;
  z-index: 2;
}

.variant-option--equal-width-buttons {
  --variant-min-width: clamp(44px, calc(var(--variant-option-padding-inline) * 2 + var(--variant-ch)), 100%);

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(var(--variant-min-width), 1fr));

  .variant-option__button-label {
    min-width: var(--variant-min-width);
  }

  .variant-option__button-label__text {
    text-align: center;
    text-wrap: balance;
  }
}

.variant-option__button-label:has(:focus-visible) {
  --variant-picker-stroke-color: var(--color-foreground);

  border-color: var(--color-foreground);
  outline: var(--focus-outline-width) solid var(--color-foreground);
  outline-offset: var(--focus-outline-offset);
}

.variant-option__button-label--has-swatch {
  --focus-outline-radius: var(--variant-picker-swatch-radius);

  padding: 0;
  border: none;
  flex-basis: auto;
  min-height: auto;
}

/* Override global label:has(input) display rule with higher specificity */
.variant-option__button-label--has-swatch:has(input) {
  display: block;
}

.variant-option__button-label:has(:checked) {
  color: var(--color-selected-variant-text);
  border-color: var(--color-selected-variant-border);
}

.variant-option__button-label:has(:checked):hover {
  border-color: var(--color-selected-variant-hover-border);
  color: var(--color-selected-variant-hover-text);

  .variant-option__button-label__pill {
    background-color: var(--color-selected-variant-hover-background);
  }
}

.variant-option__button-label:has([data-option-available='false']) {
  color: rgb(var(--color-variant-text-rgb) / var(--opacity-60));
}

.variant-option__button-label--has-swatch:hover {
  outline: var(--focus-outline-width) solid rgb(var(--color-foreground-rgb) / var(--opacity-35-55));
  outline-offset: var(--focus-outline-offset);
}

.variant-option__button-label--has-swatch:has(:checked) {
  --focus-outline: var(--focus-outline-width) solid var(--color-foreground);

  outline: var(--focus-outline);
  outline-offset: var(--focus-outline-offset);
}

/* 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. **/
  .variant-option__button-label--has-swatch:has(:checked),
  .variant-option__button-label:has(:focus-visible) .swatch {
    outline: none;
    position: relative;
    overflow: visible;
  }

  .variant-option__button-label--has-swatch:has(:checked)::after,
  .variant-option__button-label:has(:focus-visible) .swatch::after {
    content: '';
    position: absolute;
    inset: calc(-1 * var(--focus-outline-offset));
    border: var(--focus-outline);
    border-radius: var(--focus-outline-radius, 50%);
    background-color: transparent;
    display: inherit;
  }
}

.variant-option__button-label:has([data-option-available='false']):has(:checked) {
  background-color: inherit;
  color: rgb(var(--color-variant-text-rgb) / var(--opacity-60));
}

.variant-option__button-label input {
  /* remove the checkbox from the page flow */
  position: absolute;

  /* set the dimensions to match those of the label */
  inset: 0;

  /* hide it */
  opacity: 0;
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: unset;
  border: none;
  border-radius: 0;
  background: transparent;
  appearance: auto;
  display: block;
  cursor: pointer;
}

.variant-option__button-label svg {
  position: absolute;
  left: var(--options-border-width);
  top: var(--options-border-width);
  height: calc(100% - (var(--options-border-width) * 2));
  width: calc(100% - (var(--options-border-width) * 2));
  cursor: pointer;
  pointer-events: none;
  stroke-width: var(--style-border-width);
  stroke: var(--variant-picker-stroke-color);
}

.variant-option__button-label:not(.variant-option__button-label--has-swatch) svg {
  stroke: var(--color-variant-border);

  line {
    stroke-width: var(--options-border-width);
  }

  line:last-of-type {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: inset(var(--clip, 0 0 0 0));
    stroke: rgb(var(--color-variant-text-rgb) / 1);
  }
}

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

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

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

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

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

.tax-note:empty {
  display: none;
}

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

/* Volume pricing note should match unit-price styling (small, grey text) */
product-price .volume-pricing-note,
product-price.text-block:is(.h1, .h2, .h3, .h4, .h5, .h6) .volume-pricing-note {
  display: block;
  font-family: var(--font-body--family);
  font-weight: normal;
  font-size: var(--font-size--xs);
  line-height: normal;
  letter-spacing: normal;
  text-transform: none;
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

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

.price-item__group {
  display: inline-block;
}

.price-item--sale {
  white-space: nowrap;
}

.price__hidden {
  display: none;
}

form.payment-terms {
  padding-top: 0.5em;
  font-size: min(0.85em, var(--font-paragraph--size));
  font-weight: var(--font-paragraph--weight);
  color: rgb(var(--color-foreground-rgb) / var(--opacity-subdued-text));
}

.installments:not(:has(shopify-payment-terms)) {
  display: none;
}

.card-gallery {
  position: relative;
}

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

/* Hide "Add" button when "Choose" button is shown */
[data-quick-add-button='choose'] add-to-cart-component {
  display: none;
}

/* Hide "Choose" button when "Add" button is shown */
[data-quick-add-button='add'] .quick-add__button--choose {
  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(--font-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);
    height: auto;

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

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

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

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

    > .group-block--height-fill {
      height: calc(var(--section-min-height, auto) - var(--section-height-offset, 0px));
    }
  }
}

@media screen and (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) var(--font-heading--spacing);
  }

  :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-top: 50%;
  --checkbox-left: 1.5px;
  --checkbox-offset: 3px;
  --checkbox-path-opacity: 0;
  --checkbox-cursor: pointer;

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

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

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

.checkbox__input {
  position: absolute;
  opacity: 0;
  margin: 0;
  padding: 0;
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  aspect-ratio: unset;
  border: none;
  border-radius: 0;
  background: transparent;
  appearance: auto;
  display: block;
  cursor: pointer;

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

/* Radio buttons and checkboxes - shared base styles */
:where(input[type='radio']),
:where(input[type='checkbox']) {
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  aspect-ratio: 1;
  margin: 0;
  margin-inline-end: var(--padding-3xs);
  padding: 0;
  border: var(--checkbox-border);
  appearance: none;
  position: relative;
  display: inline-block;
  vertical-align: middle;
  cursor: pointer;
}

/* Radio buttons */
input[type='radio'] {
  border-radius: var(--style-border-radius-50);
  background: transparent;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

:where(input[type='radio']):checked {
  border-color: var(--color-foreground);
  background: var(--color-background);
}

:where(input[type='radio']):checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: calc(var(--checkbox-size) / 2);
  height: calc(var(--checkbox-size) / 2);
  background: var(--color-foreground);
  border-radius: var(--style-border-radius-50);
  transition: background 0.2s ease;
}

:where(input[type='radio']):disabled {
  border-color: var(--input-disabled-border-color);
  background-color: var(--input-disabled-background-color);
  cursor: not-allowed;
}

:where(input[type='radio']):disabled:checked::after {
  background: var(--input-disabled-background-color);
}

:where(input[type='radio']):not(:disabled):hover {
  border-color: rgb(var(--color-foreground-rgb) / var(--opacity-40-60));
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

:where(input[type='radio']):not(:disabled):hover:checked {
  border-color: var(--color-foreground);
  background-color: var(--color-background);
}

:where(input[type='radio']):not(:disabled):hover:checked::after {
  background: rgb(var(--color-foreground-rgb) / var(--opacity-85));
}

/* Checkboxes */
:where(input[type='checkbox']) {
  border-radius: var(--checkbox-border-radius);
  background-color: var(--color-background);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

:where(input[type='checkbox']):checked {
  background-color: var(--color-foreground);
  border-color: var(--color-foreground);
}

:where(input[type='checkbox']):checked::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: var(--checkbox-size);
  height: var(--checkbox-size);
  background-color: var(--color-background);
  mask-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.75439 10.7485L7.68601 14.5888C7.79288 14.7288 7.84632 14.7988 7.91174 14.8242C7.96907 14.8466 8.03262 14.8469 8.09022 14.8253C8.15596 14.8007 8.21026 14.7314 8.31886 14.5927L15.2475 5.74658' stroke='black' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}

:where(input[type='checkbox']):not(:disabled):hover {
  border-color: rgb(var(--color-foreground-rgb) / var(--opacity-40-60));
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-5));
}

:where(input[type='checkbox']):not(:disabled):hover:checked {
  border-color: var(--color-foreground);
  background-color: rgb(var(--color-foreground-rgb) / var(--opacity-85));
}

:where(input[type='checkbox']):disabled {
  background-color: var(--input-disabled-background-color);
  border-color: var(--input-disabled-border-color);
  cursor: not-allowed;
}

:where(input[type='checkbox']):disabled:checked::after {
  background-color: var(--input-disabled-text-color);
}

/* Shared styles for radio buttons and checkboxes */
:where(input[type='radio']) + label,
:where(input[type='checkbox']) + label {
  display: inline;
  vertical-align: middle;
  cursor: pointer;
}

:where(input[type='radio']):disabled + label,
:where(input[type='checkbox']):disabled + label {
  color: var(--input-disabled-text-color);
  cursor: not-allowed;
}

/* Flexbox for labels wrapping radio buttons or checkboxes */
label:has(input[type='radio']),
label:has(input[type='checkbox']) {
  display: inline-flex;
  align-items: center;
  gap: var(--padding-2xs);
  cursor: pointer;
}

label:has(input[type='radio']:disabled),
label:has(input[type='checkbox']:disabled) {
  cursor: not-allowed;
}

/* Override for swatch labels to maintain block display */
.variant-option__button-label--has-swatch:has(input[type='radio']) {
  display: block;
}

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

/* Cart items component */
.cart-items-component {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* Cart typography */
.cart-primary-typography {
  font-family: var(--cart-primary-font-family);
  font-style: var(--cart-primary-font-style);
  font-weight: var(--cart-primary-font-weight);
}

.cart-secondary-typography {
  font-family: var(--cart-secondary-font-family);
  font-style: var(--cart-secondary-font-style);
  font-weight: var(--cart-secondary-font-weight);
}

/* 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,
.quick-add-modal .quantity-selector {
  border-radius: var(--style-border-radius-buttons-primary);
}

.product-details .quantity-selector .quantity-minus,
.quick-add-modal .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,
.quick-add-modal .quantity-selector .quantity-plus {
  border-start-end-radius: var(--style-border-radius-buttons-primary);
  border-end-end-radius: var(--style-border-radius-buttons-primary);
}

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  animation-duration: 0.6s;
}

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

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

  animation-duration: 0.8s;
}

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

  5% {
    opacity: 1;
  }

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

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

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

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

/* Collection Wrapper - Shared layout CSS for collection and search pages */

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

.collection-wrapper {
  @media screen and (min-width: 750px) {
    --facets-vertical-col-width: 6;

    grid-template-columns:
      1fr repeat(
        var(--centered-column-number),
        minmax(0, calc((var(--page-width) - var(--page-margin) * 2) / var(--centered-column-number)))
      )
      1fr;
  }

  @media screen and (min-width: 990px) {
    --facets-vertical-col-width: 5;
  }
}

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

.collection-wrapper:has(.facets--vertical) .facets-block-wrapper--vertical:not(.hidden) ~ .main-collection-grid {
  @media screen and (min-width: 750px) {
    grid-column: var(--facets-vertical-col-width) / var(--full-width-column-number);
  }
}

.collection-wrapper:has(.facets-block-wrapper--vertical:not(#filters-drawer)):has(.collection-wrapper--full-width) {
  @media screen and (min-width: 750px) {
    grid-column: 1 / -1;
    grid-template-columns: 0fr repeat(var(--centered-column-number), minmax(0, 1fr)) 0fr;
  }
}

:is(.collection-wrapper--full-width, .collection-wrapper--full-width-on-mobile)
  [product-grid-view='default']
  .product-grid__card {
  @media screen and (max-width: 749px) {
    padding-inline-start: max(var(--padding-xs), var(--padding-inline-start));
    padding-inline-end: max(var(--padding-xs), var(--padding-inline-end));
  }
}

:is(.collection-wrapper--full-width, .collection-wrapper--full-width-on-mobile)
  [product-grid-view='mobile-single']
  .product-grid__card {
  @media screen and (max-width: 749px) {
    padding-inline-start: max(var(--padding-xs), var(--padding-inline-start));
    padding-inline-end: max(var(--padding-xs), var(--padding-inline-end));
  }
}

/* Make product media go edge-to-edge by using negative margins */
:is(.collection-wrapper--full-width) .card-gallery,
:is(.collection-wrapper--full-width-on-mobile) .card-gallery {
  @media screen and (max-width: 749px) {
    margin-inline-start: calc(-1 * max(var(--padding-xs), var(--padding-inline-start)));
    margin-inline-end: calc(-1 * max(var(--padding-xs), var(--padding-inline-end)));
  }
}

.collection-wrapper--full-width .main-collection-grid__title {
  margin-left: var(--page-margin);
}

.collection-wrapper--full-width-on-mobile .main-collection-grid__title {
  @media screen and (max-width: 749px) {
    margin-left: var(--page-margin);
  }
}

.collection-wrapper--grid-full-width .facets--vertical:not(.facets--drawer) {
  @media screen and (min-width: 750px) {
    padding-inline-start: max(var(--padding-sm), var(--padding-inline-start));
  }
}

.collection-wrapper:has(.product-grid-mobile--large) .facets-mobile-wrapper.facets-controls-wrapper {
  @media screen and (max-width: 749px) {
    display: none;
  }
}

.collection-wrapper:has(> .facets--horizontal) .facets__panel[open] {
  @media screen and (min-width: 750px) {
    z-index: var(--facets-open-z-index);
  }
}

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

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

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

  50% {
    transform: scale(1.2);
  }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

@keyframes fadeOut {
  from {
    opacity: 1;
  }

  to {
    opacity: 0;
  }
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

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

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

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

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

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

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

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

@media screen and (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 screen and (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 Arrow Hover Animation - must stay in base.css for proper CSS cascade */

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

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

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

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

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

:where(.section-resource-list.section--full-width) product-card[data-product-transition] > .group-block,
:where(.section-carousel.section--full-width) product-card[data-product-transition] > .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;
}

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

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

.predictive-search-results__inner {
  flex-grow: 1;
  overflow-y: auto;
  padding-block: var(--padding-lg);
  container-type: inline-size;
  color: var(--color-foreground);
}

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

.product-recommendations {
  display: block;
}

.product-recommendations__skeleton-item {
  aspect-ratio: 3 / 4;
  background-color: var(--color-foreground);
  opacity: var(--skeleton-opacity);
  border-radius: 4px;
}

@media screen and (max-width: 749px) {
  .product-recommendations__skeleton-item:nth-child(2n + 1) {
    display: none;
  }
}

product-recommendations:has([data-has-recommendations='false']) {
  display: none;
}

.add-to-cart-button {
  --text-speed: 0.26;
  --base-delay: calc(var(--text-speed) * 0.25);
  --tick-speed: 0.1;
  --ring-speed: 0.2;
  --check-speed: 0.2;
  --burst-speed: 0.32;
  --step-delay: 3;
  --speed: 1;

  user-select: none;
  transition-property: color, box-shadow, background-color, scale, translate;
  transition-duration: var(--animation-speed);
  transition-timing-function: var(--ease-out-cubic);

  &:active {
    scale: 0.99;
    translate: 0 1px;
  }
}

.add-to-cart-button .svg-wrapper .checkmark-burst {
  width: 30px;
  height: 30px;
}

.add-to-cart-text {
  --atc-opacity: 0;
  --atc-destination: -1em;

  display: flex;
  gap: var(--gap-2xs);
  align-items: center;
  justify-content: center;
  animation-duration: var(--animation-speed);
  animation-timing-function: var(--animation-easing);
  animation-fill-mode: forwards;
  transition: width var(--animation-speed) var(--animation-easing),
    opacity var(--animation-speed) var(--animation-easing);
}

.add-to-cart__added {
  --atc-opacity: 1;
  --atc-destination: 0px;

  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
}

.add-to-cart__added-icon {
  width: 32px;
  height: 32px;
}

[data-added='true'] .add-to-cart-text,
[data-added='true'] .add-to-cart__added {
  animation-name: atc-slide;
}

.checkmark-burst {
  opacity: 0;
  overflow: visible;

  .burst {
    rotate: 20deg;
  }

  .check {
    opacity: 0.2;
    scale: 0.8;
    filter: blur(2px);
    transform: translateZ(0);
  }

  :is(.ring, .line, .check, .burst, .tick) {
    transform-box: fill-box;
    transform-origin: center;
  }

  :is(.line) {
    stroke-dasharray: 1.5 1.5;
    stroke-dashoffset: -1.5;
    translate: 0 -180%;
  }

  g {
    transform-origin: center;
    rotate: calc(var(--index) * (360 / 8) * 1deg);
  }
}

.add-to-cart-button[data-added='true'] .checkmark-burst {
  opacity: 1;
}

.add-to-cart-button[data-added='true'] {
  .check {
    opacity: 1;
    scale: 1;
    filter: blur(0);
  }

  .tick {
    scale: 1.75;
  }

  .ring {
    opacity: 0;
    scale: 1;
  }

  .line {
    stroke-dashoffset: 1.5;
  }

  .add-to-cart-text {
    /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
    clip-path: circle(0% at 50% 50%);
    filter: blur(2px);
    opacity: 0;
    translate: 0 4px;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .add-to-cart-button[data-added='true'] {
    .check {
      transition-property: opacity, scale, filter;
      transition-duration: calc(calc(var(--check-speed) * 1s));
      transition-delay: calc((var(--base-delay) * 1s));
      transition-timing-function: var(--ease-out-quad);
    }

    .tick {
      transition-property: scale;
      transition-duration: calc((calc(var(--tick-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * (var(--step-delay) * 1.1))) * 1s));
      transition-timing-function: ease-out;
    }

    .ring {
      transition-property: opacity, scale;
      transition-duration: calc((calc(var(--ring-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * var(--step-delay))) * 1s));
      transition-timing-function: var(--ease-out-quad);
    }

    .line {
      transition-property: stroke-dashoffset;
      transition-duration: calc((calc(var(--burst-speed) * 1s)));
      transition-delay: calc(((var(--base-delay) + (var(--check-speed) * var(--step-delay))) * 1s));
      transition-timing-function: var(--ease-out-cubic);
    }
  }

  .add-to-cart-text {
    transition-property: clip-path, opacity, filter, translate;
    transition-duration: calc((var(--text-speed) * 0.6s)), calc((var(--text-speed) * 1s));
    transition-timing-function: ease-out;
  }
}

.add-to-cart-text {
  /* stylelint-disable-next-line plugin/no-unsupported-browser-features */
  clip-path: circle(100% at 50% 50%);
}

@keyframes atc-slide {
  to {
    opacity: var(--atc-opacity, 1);
    translate: 0px var(--atc-destination, 0px);
  }
}
/* PRODUCTS PAGE CLEANUP */

/* Center and widen product page */
.collection {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 24px;
}

/* Better page title */
.collection-hero__title,
.title--primary {
  font-size: 42px;
  font-weight: 500;
  letter-spacing: -1px;
  margin-bottom: 35px;
}

/* Product grid spacing */
.product-grid {
  column-gap: 24px !important;
  row-gap: 42px !important;
}

/* Product cards */
.card-wrapper {
  background: rgba(255, 255, 255, 0.04);
  border-radius: 18px;
  padding: 12px;
  transition: 0.25s ease;
}

.card-wrapper:hover {
  transform: translateY(-4px);
  background: rgba(255, 255, 255, 0.07);
}

/* Product images */
.card__media,
.card__inner {
  border-radius: 14px !important;
  overflow: hidden;
}

.card__media img {
  object-fit: cover;
}

/* Product titles */
.card__heading {
  font-size: 15px;
  line-height: 1.25;
  margin-top: 12px;
}

/* Price */
.price {
  font-size: 14px;
  margin-top: 6px;
}

/* Sale badge */
.badge {
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
}

/* Filters/sort cleaner */
.facets-container {
  margin-bottom: 28px;
}

.facets__summary,
.product-count,
.facet-filters__label,
.facet-filters__sort {
  font-size: 13px;
}

/* Mobile fix */
@media screen and (max-width: 749px) {
  .collection {
    padding: 28px 16px;
  }

  .collection-hero__title,
  .title--primary {
    font-size: 34px;
  }

  .product-grid {
    column-gap: 14px !important;
    row-gap: 28px !important;
  }

  .card-wrapper {
    padding: 8px;
    border-radius: 14px;
  }

  .card__heading {
    font-size: 13px;
  }
}
/* ORYNNE PRODUCT PAGE - STRONGER OVERRIDE */

.product-grid,
.collection ul,
ul.grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 48px 32px !important;
}

.grid__item {
  width: 100% !important;
  max-width: 100% !important;
}

.card-wrapper,
.product-card-wrapper {
  padding: 14px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,0.045) !important;
  transition: all 0.25s ease !important;
}

.card-wrapper:hover,
.product-card-wrapper:hover {
  transform: translateY(-5px) !important;
  background: rgba(255,255,255,0.08) !important;
}

.card__inner,
.card__media,
.media {
  border-radius: 14px !important;
  overflow: hidden !important;
}

.card__heading,
.card-information,
.card-information * {
  font-size: 16px !important;
  line-height: 1.25 !important;
}

.price,
.price * {
  font-size: 15px !important;
}

@media screen and (max-width: 749px) {
  .product-grid,
  .collection ul,
  ul.grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 28px 14px !important;
  }

  .card-wrapper,
  .product-card-wrapper {
    padding: 8px !important;
  }
}
/* Hide original Shopify collection title */
.collection-hero,
.collection-hero__inner,
.collection-hero__title,
.collection-title,
h1.collection-hero__title {
  display: none !important;
}
/* ORYNNE COLLECTION HERO */

.collection-hero,
.collection-hero__inner,
.collection-hero__title,
.collection-title,
h1.collection-hero__title {
  display: none !important;
}

.orynne-collection-hero {
  margin: 0 24px 40px;
  padding: 56px 64px 34px;
  background:
    radial-gradient(circle at 12% 20%, rgba(199,162,124,0.12), transparent 28%),
    rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
}

.orynne-kicker {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: 11px;
  margin: 0 0 18px;
}

.orynne-collection-hero h1 {
  color: #f4efe3;
  font-size: clamp(52px, 6vw, 82px);
  line-height: 1;
  font-weight: 400;
  letter-spacing: -2px;
  margin: 0;
}

.orynne-subtitle {
  color: rgba(244,239,227,0.72);
  font-size: 17px;
  margin: 22px 0 48px;
  max-width: 620px;
}

.orynne-category-nav {
  display: flex;
  justify-content: center;
  gap: 30px;
  overflow-x: auto;
  white-space: nowrap;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.orynne-category-nav a {
  color: rgba(244,239,227,0.66);
  text-decoration: none;
  font-size: 15px;
  transition: 0.2s ease;
  flex-shrink: 0;
}

.orynne-category-nav a:hover {
  color: #f4efe3;
}

.orynne-category-nav a.sale {
  color: #c7a27c;
}

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

  .orynne-collection-hero {
    margin: 0 16px 28px;
    padding: 38px 22px 26px;
  }

  .orynne-collection-hero h1 {
    font-size: 46px;
  }

  .orynne-category-nav {
    justify-content: flex-start;
    gap: 24px;
  }

  .orynne-category-nav a {
    font-size: 14px;
  }
}
/* STRONG MOBILE FIX - ORYNNE COLLECTION HERO */
@media screen and (max-width: 749px) {
  .orynne-collection-hero {
    margin: 18px 16px 28px !important;
    padding: 28px 18px 20px !important;
    max-width: calc(100vw - 32px) !important;
    box-sizing: border-box !important;
  }

  .orynne-kicker {
    font-size: 8px !important;
    letter-spacing: 2.4px !important;
    line-height: 1.4 !important;
    margin-bottom: 14px !important;
  }

  .orynne-collection-hero h1 {
    font-size: 38px !important;
    line-height: 1.05 !important;
  }

  .orynne-subtitle {
    font-size: 15px !important;
    line-height: 1.45 !important;
    margin: 16px 0 28px !important;
  }

  .orynne-category-nav {
    display: flex !important;
    justify-content: flex-start !important;
    gap: 22px !important;
    overflow-x: scroll !important;
    padding: 16px 0 4px !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    scrollbar-width: none !important;
  }

  .orynne-category-nav::-webkit-scrollbar {
    display: none !important;
  }

  .orynne-category-nav a {
    font-size: 14px !important;
    flex: 0 0 auto !important;
  }
}
/* ORYNNE HOMEPAGE BUILD */

.orynne-home-build {
  background: #171b13;
  color: #f4efe3;
  padding: 70px 7vw;
}

.orynne-kicker {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: 11px;
  margin-bottom: 18px;
}

.orynne-kicker.center {
  text-align: center;
}

.orynne-editorial {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  gap: 48px;
  align-items: center;
  margin-bottom: 80px;
}

.orynne-editorial h2,
.orynne-final-banner h2 {
  font-size: clamp(36px, 4vw, 64px);
  font-weight: 400;
  line-height: 1.08;
  margin: 0 0 24px;
}

.orynne-editorial p {
  color: rgba(244,239,227,0.68);
  font-size: 16px;
  line-height: 1.7;
  max-width: 420px;
}

.orynne-editorial a,
.orynne-final-banner a {
  color: #c7a27c;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
}

.orynne-editorial-image {
  min-height: 430px;
  background:
    linear-gradient(rgba(0,0,0,0.25), rgba(0,0,0,0.25)),
    url("https://images.unsplash.com/photo-1618220179428-22790b461013?auto=format&fit=crop&w=1400&q=80");
  background-size: cover;
  background-position: center;
}

.orynne-shop-room {
  margin-bottom: 80px;
}

.orynne-room-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

.orynne-room-card {
  min-height: 260px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  text-decoration: none;
  color: #f4efe3;
  border: 1px solid rgba(255,255,255,0.08);
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}

.orynne-room-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.78), rgba(0,0,0,0.18));
}

.orynne-room-card span,
.orynne-room-card small {
  position: relative;
  z-index: 1;
}

.orynne-room-card span {
  text-transform: uppercase;
  letter-spacing: 3px;
  font-size: 13px;
}

.orynne-room-card small {
  margin-top: 10px;
  color: rgba(244,239,227,0.7);
}

.orynne-room-card.living {
  background-image: url("https://images.unsplash.com/photo-1600210492493-0946911123ea?auto=format&fit=crop&w=900&q=80");
}

.orynne-room-card.bedroom {
  background-image: url("https://images.unsplash.com/photo-1616594039964-ae9021a400a0?auto=format&fit=crop&w=900&q=80");
}

.orynne-room-card.dining {
  background-image: url("https://images.unsplash.com/photo-1617806118233-18e1de247200?auto=format&fit=crop&w=900&q=80");
}

.orynne-room-card.outdoor {
  background-image: url("https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=900&q=80");
}

.orynne-standard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 80px;
}

.orynne-standard div {
  padding: 36px;
  border-right: 1px solid rgba(255,255,255,0.08);
}

.orynne-standard div:last-child {
  border-right: none;
}

.orynne-standard h3 {
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 13px;
  margin: 0 0 12px;
}

.orynne-standard p {
  color: rgba(244,239,227,0.62);
  line-height: 1.6;
  margin: 0;
}

.orynne-final-banner {
  min-height: 430px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 60px;
  background:
    linear-gradient(to right, rgba(0,0,0,0.15), rgba(0,0,0,0.82)),
    url("https://images.unsplash.com/photo-1616486338812-3dadae4b4ace?auto=format&fit=crop&w=1500&q=80");
  background-size: cover;
  background-position: center;
}

.orynne-final-banner div {
  max-width: 440px;
}

@media screen and (max-width: 749px) {
  .orynne-home-build {
    padding: 48px 20px;
  }

  .orynne-editorial,
  .orynne-room-grid,
  .orynne-standard {
    grid-template-columns: 1fr;
  }

  .orynne-editorial-image {
    min-height: 280px;
  }

  .orynne-room-card {
    min-height: 220px;
  }

  .orynne-standard div {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  .orynne-final-banner {
    min-height: 360px;
    padding: 34px;
    justify-content: flex-start;
  }
}
/* ORYNNE LUXE HOMEPAGE */

.orynne-luxe-home {
  background: #0f120d;
  color: #f4efe3;
  padding: 70px 7vw 90px;
}

.olh-kicker {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: 11px;
  margin: 0 0 20px;
}

.olh-kicker.center {
  text-align: center;
}

.olh-philosophy {
  display: grid;
  grid-template-columns: 0.85fr 1.35fr;
  gap: 48px;
  align-items: center;
  margin-bottom: 90px;
}

.olh-copy h2,
.olh-standard h2 {
  font-size: clamp(38px, 4.5vw, 70px);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -1px;
  margin: 0 0 24px;
}

.olh-copy p {
  color: rgba(244,239,227,0.68);
  font-size: 16px;
  line-height: 1.7;
  max-width: 430px;
}

.olh-copy a,
.olh-standard a {
  color: #c7a27c;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
}

.olh-image {
  min-height: 470px;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,0.08);
}

.olh-img-1 {
  background-image:
    linear-gradient(rgba(0,0,0,0.28), rgba(0,0,0,0.28)),
    url("https://images.unsplash.com/photo-1618220179428-22790b461013?auto=format&fit=crop&w=1600&q=80");
}

.olh-shop-room {
  margin-bottom: 80px;
}

.olh-room-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

.olh-room {
  min-height: 285px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #f4efe3;
  text-decoration: none;
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,0.08);
  position: relative;
  overflow: hidden;
}

.olh-room::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.82), rgba(0,0,0,0.15));
}

.olh-room span,
.olh-room small {
  position: relative;
  z-index: 1;
}

.olh-room span {
  text-transform: uppercase;
  letter-spacing: 3px;
  font-size: 13px;
}

.olh-room small {
  margin-top: 10px;
  color: rgba(244,239,227,0.7);
}

.olh-room.living {
  background-image: url("https://images.unsplash.com/photo-1600210492493-0946911123ea?auto=format&fit=crop&w=900&q=80");
}

.olh-room.bedroom {
  background-image: url("https://images.unsplash.com/photo-1616594039964-ae9021a400a0?auto=format&fit=crop&w=900&q=80");
}

.olh-room.dining {
  background-image: url("https://images.unsplash.com/photo-1617806118233-18e1de247200?auto=format&fit=crop&w=900&q=80");
}

.olh-room.outdoor {
  background-image: url("https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=900&q=80");
}

.olh-trust {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid rgba(255,255,255,0.08);
  margin-bottom: 90px;
}

.olh-trust div {
  padding: 34px;
  border-right: 1px solid rgba(255,255,255,0.08);
}

.olh-trust div:last-child {
  border-right: none;
}

.olh-trust h3 {
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 13px;
  margin: 0 0 12px;
}

.olh-trust p {
  color: rgba(244,239,227,0.62);
  line-height: 1.6;
  margin: 0;
}

.olh-standard {
  min-height: 430px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 60px;
  background:
    linear-gradient(to right, rgba(0,0,0,0.12), rgba(0,0,0,0.86)),
    url("https://images.unsplash.com/photo-1616486338812-3dadae4b4ace?auto=format&fit=crop&w=1600&q=80");
  background-size: cover;
  background-position: center;
  border: 1px solid rgba(255,255,255,0.08);
}

.olh-standard div {
  max-width: 460px;
}

@media screen and (max-width: 749px) {
  .orynne-luxe-home {
    padding: 46px 20px 60px;
  }

  .olh-philosophy,
  .olh-room-grid,
  .olh-trust {
    grid-template-columns: 1fr;
  }

  .olh-philosophy {
    gap: 28px;
    margin-bottom: 60px;
  }

  .olh-image {
    min-height: 280px;
  }

  .olh-room {
    min-height: 230px;
  }

  .olh-trust div {
    border-right: none;
    border-bottom: 1px solid rgba(255,255,255,0.08);
  }

  .olh-standard {
    min-height: 360px;
    padding: 34px;
    justify-content: flex-start;
  }
}
/* ORYNNE HERO REDESIGN */

.orynne-hero-redesign {
  min-height: 82vh;
  display: flex;
  align-items: center;
  padding: 0 7vw;
  color: #f4efe3;
  background:
    linear-gradient(to right, rgba(10,12,8,0.92), rgba(10,12,8,0.45), rgba(10,12,8,0.12)),
    url("https://images.unsplash.com/photo-1600566753190-17f0baa2a6c3?auto=format&fit=crop&w=1800&q=85");
  background-size: cover;
  background-position: center;
}

.orynne-hero-content {
  max-width: 680px;
}

.orynne-hero-content p {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: 11px;
  margin: 0 0 22px;
}

.orynne-hero-content h1 {
  font-size: clamp(58px, 8vw, 118px);
  font-weight: 400;
  line-height: 0.92;
  letter-spacing: -3px;
  margin: 0 0 28px;
  color: #f4efe3;
}

.orynne-hero-content span {
  display: block;
  color: rgba(244,239,227,0.74);
  font-size: 18px;
  line-height: 1.65;
  max-width: 520px;
  margin-bottom: 38px;
}

.orynne-hero-content a {
  display: inline-block;
  color: #f4efe3;
  border: 1px solid rgba(244,239,227,0.45);
  padding: 15px 28px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
  transition: 0.25s ease;
}

.orynne-hero-content a:hover {
  background: #f4efe3;
  color: #11140d;
}

@media screen and (max-width: 749px) {
  .orynne-hero-redesign {
    min-height: 76vh;
    padding: 0 24px;
    background-position: center;
  }

  .orynne-hero-content h1 {
    font-size: 54px;
    letter-spacing: -1.5px;
  }

  .orynne-hero-content span {
    font-size: 15px;
  }
}
/* ORYNNE STORY SECTION */

.orynne-story-grid {
  display: grid;
  grid-template-columns: 1fr 1.3fr;
  align-items: stretch;
  background: #0f120d;
  margin: 0;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.orynne-story-text {
  padding: 90px 70px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.orynne-story-text .orynne-kicker {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 4px;
  font-size: 11px;
  margin-bottom: 28px;
}

.orynne-story-text h2 {
  font-size: 54px;
  line-height: 1.05;
  font-weight: 300;
  color: #f4efe3;
  margin-bottom: 28px;
  max-width: 520px;
}

.orynne-description {
  color: rgba(244,239,227,0.72);
  font-size: 18px;
  line-height: 1.7;
  max-width: 480px;
  margin-bottom: 34px;
}

.orynne-link {
  color: #c7a27c;
  text-decoration: none;
  letter-spacing: 2px;
  text-transform: uppercase;
  font-size: 12px;
  transition: 0.25s ease;
}

.orynne-link:hover {
  opacity: 0.7;
}

.orynne-story-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* MOBILE */

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

  .orynne-story-grid {
    grid-template-columns: 1fr;
  }

  .orynne-story-text {
    padding: 50px 28px;
  }

  .orynne-story-text h2 {
    font-size: 38px;
  }

  .orynne-description {
    font-size: 16px;
  }

  .orynne-story-image img {
    height: 420px;
  }

}
/* ORYNNE HEADER + FOOTER POLISH */

/* HEADER */
.header-wrapper,
.shopify-section-header-sticky,
header.header {
  background: rgba(10, 12, 8, 0.78) !important;
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

.header {
  padding-top: 22px !important;
  padding-bottom: 22px !important;
}

.header__heading-link,
.header__heading,
.header__heading-logo-wrapper {
  color: #f4efe3 !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  letter-spacing: 0.2px !important;
}

.header__menu-item,
.header__menu-item span,
.list-menu__item {
  color: rgba(244,239,227,0.72) !important;
  font-size: 14px !important;
  letter-spacing: 0.4px !important;
  transition: 0.2s ease;
}

.header__menu-item:hover span,
.header__menu-item:hover,
.list-menu__item:hover {
  color: #f4efe3 !important;
}

.header__icons svg,
.header__icon svg {
  color: #f4efe3 !important;
  stroke-width: 1.5px !important;
}

.header__icon {
  color: #f4efe3 !important;
}

.header__active-menu-item {
  color: #c7a27c !important;
  text-decoration: none !important;
}

/* FOOTER */
.footer {
  background: #080a07 !important;
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  padding-top: 70px !important;
}

.footer,
.footer * {
  color: rgba(244,239,227,0.72) !important;
}

.footer-block__heading {
  color: #f4efe3 !important;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-size: 12px !important;
  font-weight: 400 !important;
  margin-bottom: 22px !important;
}

.footer-block__details-content,
.footer-block__details-content p,
.footer-block__details-content a {
  font-size: 13px !important;
  line-height: 1.8 !important;
  color: rgba(244,239,227,0.58) !important;
}

.footer-block__details-content a:hover {
  color: #c7a27c !important;
}

.footer__content-top {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 40px !important;
  padding-right: 40px !important;
}

.footer__content-bottom {
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  margin-top: 50px;
  padding-top: 24px !important;
}

.footer__copyright,
.footer__copyright small,
.footer__copyright a,
.policies li a {
  color: rgba(244,239,227,0.42) !important;
  font-size: 12px !important;
}

.newsletter-form__field-wrapper input,
.field__input {
  background: transparent !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  color: #f4efe3 !important;
}

.newsletter-form__button {
  color: #c7a27c !important;
}

/* MOBILE */
@media screen and (max-width: 749px) {
  .header {
    padding-top: 16px !important;
    padding-bottom: 16px !important;
  }

  .header__heading-link,
  .header__heading {
    font-size: 22px !important;
  }

  .footer__content-top {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }

  .footer {
    padding-top: 48px !important;
  }
}
/* ORYNNE CUSTOM FOOTER */

.orynne-custom-footer {
  background: #080907;
  color: #f4efe3;
  padding: 90px 7vw 34px;
  border-top: 1px solid rgba(255,255,255,0.06);
}

.ocf-top {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 0.8fr 1fr;
  gap: 70px;
  margin-bottom: 70px;
}

.ocf-brand h2 {
  font-size: 38px;
  font-weight: 400;
  margin-bottom: 18px;
}

.ocf-brand p {
  color: rgba(244,239,227,0.62);
  line-height: 1.8;
  max-width: 260px;
}

.ocf-socials {
  display: flex;
  gap: 16px;
  margin-top: 28px;
  color: rgba(244,239,227,0.5);
  font-size: 13px;
}

.ocf-links h3,
.ocf-newsletter h3 {
  text-transform: uppercase;
  letter-spacing: 2px;
  font-size: 12px;
  color: #f4efe3;
  margin-bottom: 24px;
}

.ocf-links {
  display: flex;
  flex-direction: column;
}

.ocf-links a {
  color: rgba(244,239,227,0.58);
  text-decoration: none;
  margin-bottom: 14px;
  font-size: 14px;
  transition: 0.2s ease;
}

.ocf-links a:hover {
  color: #c7a27c;
}

.ocf-newsletter p {
  color: rgba(244,239,227,0.58);
  line-height: 1.7;
  margin-bottom: 26px;
}

.ocf-input {
  display: flex;
  border: 1px solid rgba(255,255,255,0.14);
}

.ocf-input input {
  flex: 1;
  background: transparent;
  border: none;
  color: #f4efe3;
  padding: 16px;
  font-size: 14px;
  outline: none;
}

.ocf-input button {
  width: 58px;
  background: transparent;
  border: none;
  color: #c7a27c;
  font-size: 18px;
  cursor: pointer;
}

.ocf-bottom {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.ocf-bottom span,
.ocf-bottom a {
  color: rgba(244,239,227,0.42);
  font-size: 12px;
  text-decoration: none;
}

.ocf-bottom div {
  display: flex;
  gap: 24px;
}

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

  .orynne-custom-footer {
    padding: 60px 24px 24px;
  }

  .ocf-top {
    grid-template-columns: 1fr;
    gap: 44px;
  }

  .ocf-bottom {
    flex-direction: column;
  }

}
/* ORYNNE TOP HEADER */

.orynne-topbar {
  position: relative;
  z-index: 1000;

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

  padding: 22px 70px;
  background: rgba(23, 27, 19, 0.92);
  backdrop-filter: blur(14px);

  border-bottom: 1px solid rgba(255,255,255,0.08);
  box-sizing: border-box;
}

.orynne-logo a{
  color:#f4efe3;
  text-decoration:none;
  font-size:58px;
  font-weight:300;
  letter-spacing:-2px;
}

.orynne-nav{
  display:flex;
  align-items:center;
  gap:42px;
}

.orynne-nav a{
  color:#d7d0c4;
  text-decoration:none;
  font-size:18px;
  font-weight:400;
  transition:0.25s ease;
}

.orynne-nav a:hover{
  color:#ffffff;
}

.sale-link{
  color:#c7a27c !important;
}

.orynne-icons{
  display:flex;
  align-items:center;
  gap:22px;
}

.orynne-icons a{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#f4efe3;
  text-decoration:none;
}

.orynne-icons svg{
  width:22px;
  height:22px;
  opacity:0.9;
  transition:0.25s ease;
}

.orynne-icons a:hover svg{
  opacity:1;
  transform:translateY(-1px);
}

/* MOBILE */

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

  .orynne-topbar{
    padding:20px 22px;
    flex-wrap:wrap;
    gap:18px;
  }

  .orynne-logo{
    width:100%;
  }

  .orynne-logo a{
    font-size:42px;
  }

  .orynne-nav{
    gap:18px;
    flex-wrap:wrap;
  }

  .orynne-nav a{
    font-size:15px;
  }

  .orynne-icons{
    margin-left:auto;
  }
}
.orynne-dropdown {
  position: relative;
}

.orynne-dropdown-menu {
  position: absolute;
  top: 130%;
  left: 0;
  min-width: 210px;
  padding: 14px 0;
  background: rgba(8, 10, 7, 0.96);
  border: 1px solid rgba(255,255,255,0.1);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: 0.22s ease;
  backdrop-filter: blur(12px);
}

.orynne-dropdown:hover .orynne-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.orynne-dropdown-menu a {
  display: block;
  padding: 11px 18px;
  font-size: 14px !important;
  color: rgba(244,239,227,0.72) !important;
}

.orynne-dropdown-menu a:hover {
  color: #f4efe3 !important;
  background: rgba(255,255,255,0.04);
}
/* FORCE HEADER SIZING FIX */

.orynne-topbar{
  padding: 26px 70px !important;
}

.orynne-logo a{
  font-size: 30px !important;
  line-height: 1 !important;
  letter-spacing: -1px !important;
  font-weight: 400 !important;
}

.orynne-nav{
  gap: 38px !important;
}

.orynne-nav a{
  font-size: 16px !important;
  line-height: 1.2 !important;
}

.orynne-icons svg{
  width: 21px !important;
  height: 21px !important;
}

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

  .orynne-topbar{
    padding: 18px 20px !important;
  }

  .orynne-logo a{
    font-size: 22px !important;
  }

  .orynne-nav a{
    font-size: 14px !important;
  }

  .orynne-nav{
    gap: 16px !important;
  }
}
/* CLEAN COLLECTION HEADER - NO TABS */

.orynne-category-nav {
  display: none !important;
}

.orynne-collection-hero {
  margin: 42px 64px 70px !important;
  padding: 78px 72px 82px !important;
  background:
    radial-gradient(circle at 12% 25%, rgba(199,162,124,0.13), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,0.035), rgba(255,255,255,0.008));
  border: 1px solid rgba(255,255,255,0.075);
  color: #f4efe3;
}

.orynne-collection-hero .orynne-kicker {
  color: #c7a27c;
  text-transform: uppercase;
  letter-spacing: 5px;
  font-size: 11px;
  margin: 0 0 26px;
}

.orynne-collection-hero h1 {
  font-size: clamp(58px, 6.5vw, 110px);
  line-height: 0.95;
  font-weight: 300;
  letter-spacing: -3px;
  margin: 0 0 30px;
  color: #f4efe3;
}

.orynne-subtitle {
  color: rgba(244,239,227,0.72);
  font-size: 21px;
  line-height: 1.6;
  max-width: 700px;
  margin: 0;
}

/* tighten product area below header */
.facets-container {
  margin-top: 0 !important;
}

.collection {
  padding-top: 0 !important;
}

/* empty state polish */
.collection--empty,
.collection .title-wrapper {
  color: #f4efe3;
}

.collection--empty h2,
.collection .title--primary {
  color: #f4efe3 !important;
  font-weight: 300 !important;
  letter-spacing: -1px;
}

@media screen and (max-width: 749px) {
  .orynne-collection-hero {
    margin: 24px 18px 42px !important;
    padding: 44px 24px 46px !important;
  }

  .orynne-collection-hero .orynne-kicker {
    font-size: 9px;
    letter-spacing: 3px;
  }

  .orynne-collection-hero h1 {
    font-size: 48px;
    letter-spacing: -1.5px;
  }

  .orynne-subtitle {
    font-size: 16px;
  }
}
/* SHRINK COLLECTION TITLE BOX */

.orynne-collection-hero {
  margin: 24px 64px 42px !important;
  padding: 42px 56px 44px !important;
}

.orynne-collection-hero .orynne-kicker {
  font-size: 10px !important;
  margin-bottom: 16px !important;
}

.orynne-collection-hero h1 {
  font-size: clamp(42px, 5vw, 72px) !important;
  margin-bottom: 18px !important;
}

.orynne-subtitle {
  font-size: 17px !important;
}
/* ============================================================
   ORYNNE LIVING — UPDATED CSS
   Changes:
   1. Fix: Lighting nav item matches other nav links
   2. Trust bar above header (shipping, returns, discount)
   3. Tighter, more professional header
   4. Stronger CTA button styles
   5. Product card price / urgency polish
   6. Announcement bar improvements
   7. Mobile nav improvements
   8. General conversion polish
   ============================================================ */


/* ── 1. FIX: LIGHTING DROPDOWN SPAN MATCHES NAV LINKS ─────── */

/* The Lighting item uses <span> inside a div instead of <a>.
   This makes it match perfectly. */

.orynne-dropdown > span {
  color: #d7d0c4;
  font-size: 16px !important;
  font-weight: 400;
  cursor: pointer;
  transition: 0.25s ease;
  letter-spacing: 0px;
  font-family: inherit;
}

.orynne-dropdown:hover > span {
  color: #ffffff;
}

/* Add a subtle caret after Lighting so users know it's a dropdown */
.orynne-dropdown > span::after {
  content: " ↓";
  font-size: 11px;
  opacity: 0.55;
  margin-left: 2px;
  transition: 0.2s ease;
}

.orynne-dropdown:hover > span::after {
  opacity: 1;
}


/* ── 2. TRUST BAR (add above your header HTML) ─────────────── */
/* Paste this HTML right above <section class="orynne-topbar">:

<div class="orynne-trust-bar">
  <span>✦ Free shipping on orders $75+</span>
  <span>✦ Buy 2 save 10% · Buy 3+ save 15%</span>
  <span>✦ Easy 30-day returns</span>
</div>

*/

.orynne-trust-bar {
  background: #c7a27c;
  color: #0f120d;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 9px 24px;
  font-size: 12px;
  letter-spacing: 0.5px;
  font-weight: 500;
  flex-wrap: wrap;
}

.orynne-trust-bar span {
  white-space: nowrap;
}

@media screen and (max-width: 749px) {
  .orynne-trust-bar {
    gap: 0;
    font-size: 11px;
    overflow: hidden;
    white-space: nowrap;
  }

  /* On mobile, only show the first message */
  .orynne-trust-bar span:not(:first-child) {
    display: none;
  }
}


/* ── 3. HEADER REFINEMENT ──────────────────────────────────── */

.orynne-topbar {
  padding: 20px 64px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
}

/* Make nav items feel slightly more premium — tighter spacing */
.orynne-nav {
  gap: 36px !important;
}

.orynne-nav a,
.orynne-dropdown > span {
  font-size: 15px !important;
  letter-spacing: 0.2px !important;
}

/* Reviews link — give it a subtle gold tint to stand out */
.orynne-nav a[href*="reviews"] {
  color: rgba(199, 162, 124, 0.85) !important;
}

.orynne-nav a[href*="reviews"]:hover {
  color: #c7a27c !important;
}


/* ── 4. STRONGER PRIMARY CTA BUTTONS ───────────────────────── */

/* Make "Shop Collection" and similar CTAs more clickable */
.orynne-hero-content a,
.orynne-link-btn {
  display: inline-block;
  background: #c7a27c;
  color: #0f120d !important;
  border: none !important;
  padding: 16px 34px !important;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-size: 12px;
  font-weight: 500;
  transition: 0.25s ease;
  cursor: pointer;
}

.orynne-hero-content a:hover,
.orynne-link-btn:hover {
  background: #b8916a !important;
  color: #0f120d !important;
  transform: translateY(-1px);
}

/* Secondary outlined buttons */
.orynne-link {
  color: #c7a27c !important;
  border-bottom: 1px solid rgba(199, 162, 124, 0.35);
  padding-bottom: 2px;
}

.orynne-link:hover {
  border-bottom-color: #c7a27c;
  opacity: 1 !important;
}


/* ── 5. PRODUCT CARD POLISH ─────────────────────────────────── */

/* Sale badge — make it pop more */
.badge--sale,
.badge--on-sale {
  background: #c7a27c !important;
  color: #0f120d !important;
  font-weight: 600 !important;
  letter-spacing: 0.5px;
}

/* Price — sale price in gold */
.price--on-sale .price-item--sale {
  color: #c7a27c !important;
}

/* Product card hover — slightly warmer glow */
.card-wrapper:hover,
.product-card-wrapper:hover {
  box-shadow: 0 8px 32px rgba(199, 162, 124, 0.1) !important;
}

/* Quick-add button style */
.quick-add__submit,
.product-form__submit {
  background: #c7a27c !important;
  color: #0f120d !important;
  border: none !important;
  letter-spacing: 1px;
  font-weight: 500 !important;
}

.quick-add__submit:hover,
.product-form__submit:hover {
  background: #b8916a !important;
}


/* ── 6. HOMEPAGE TRUST SECTION (add this HTML block) ────────── */
/*
Paste this HTML anywhere on your homepage, ideally just above the footer section:

<div class="orynne-social-proof">
  <div class="osp-inner">
    <div class="osp-stat">
      <span class="osp-number">4.9★</span>
      <span class="osp-label">Average Rating</span>
    </div>
    <div class="osp-divider"></div>
    <div class="osp-stat">
      <span class="osp-number">47+</span>
      <span class="osp-label">Verified Reviews</span>
    </div>
    <div class="osp-divider"></div>
    <div class="osp-stat">
      <span class="osp-number">500+</span>
      <span class="osp-label">Orders Shipped</span>
    </div>
    <div class="osp-divider"></div>
    <div class="osp-stat">
      <span class="osp-number">30</span>
      <span class="osp-label">Day Returns</span>
    </div>
  </div>
</div>

*/

.orynne-social-proof {
  background: #0f120d;
  border-top: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: 48px 7vw;
}

.osp-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  max-width: 900px;
  margin: 0 auto;
  flex-wrap: wrap;
}

.osp-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0 60px;
  flex: 1;
  min-width: 140px;
}

.osp-number {
  font-size: 38px;
  font-weight: 300;
  color: #f4efe3;
  letter-spacing: -1px;
  line-height: 1;
}

.osp-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(244,239,227,0.5);
}

.osp-divider {
  width: 1px;
  height: 50px;
  background: rgba(255,255,255,0.1);
  flex-shrink: 0;
}

@media screen and (max-width: 749px) {
  .osp-inner {
    gap: 32px;
  }

  .osp-divider {
    display: none;
  }

  .osp-stat {
    padding: 0 20px;
    min-width: 120px;
  }

  .osp-number {
    font-size: 30px;
  }
}


/* ── 7. MOBILE NAV IMPROVEMENTS ─────────────────────────────── */

@media screen and (max-width: 900px) {
  .orynne-topbar {
    padding: 16px 20px !important;
    position: sticky !important;
    top: 0 !important;
  }

  /* Stack logo on top, nav below */
  .orynne-topbar {
    flex-wrap: wrap;
    gap: 14px;
  }

  .orynne-logo {
    flex: 1;
  }

  .orynne-nav {
    order: 3;
    width: 100%;
    gap: 20px !important;
    padding-bottom: 4px;
    overflow-x: auto;
    flex-wrap: nowrap !important;
    scrollbar-width: none;
  }

  .orynne-nav::-webkit-scrollbar {
    display: none;
  }

  .orynne-nav a,
  .orynne-dropdown > span {
    font-size: 14px !important;
    white-space: nowrap;
    flex-shrink: 0;
  }
}


/* ── 8. DROPDOWN REFINEMENT ─────────────────────────────────── */

.orynne-dropdown-menu {
  min-width: 190px;
  padding: 10px 0;
  background: rgba(10, 12, 8, 0.98);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 16px 40px rgba(0,0,0,0.4);
}

.orynne-dropdown-menu a {
  padding: 12px 20px !important;
  font-size: 14px !important;
  color: rgba(244,239,227,0.7) !important;
  transition: 0.15s ease;
}

.orynne-dropdown-menu a:hover {
  color: #f4efe3 !important;
  background: rgba(199,162,124,0.06) !important;
  padding-left: 26px !important;
}


/* ── 9. COLLECTION PAGE HEADER POLISH ───────────────────────── */

.orynne-collection-hero {
  margin: 28px 48px 48px !important;
  padding: 52px 60px 54px !important;
}

.orynne-collection-hero h1 {
  font-size: clamp(40px, 5vw, 68px) !important;
  letter-spacing: -2px !important;
  margin-bottom: 16px !important;
}

.orynne-subtitle {
  font-size: 16px !important;
  color: rgba(244,239,227,0.65) !important;
}


/* ── 10. FOOTER — REVIEWS LINK ──────────────────────────────── */

/* If you add Reviews to your footer links, style it to stand out */
.ocf-links a[href*="reviews"] {
  color: #c7a27c !important;
}


/* ── 11. SCROLLBAR REFINEMENT ───────────────────────────────── */

::-webkit-scrollbar-thumb {
  background-color: rgba(199, 162, 124, 0.3) !important;
}

::-webkit-scrollbar-thumb:hover {
  background-color: rgba(199, 162, 124, 0.5) !important;
}


/* ── 12. SMOOTH PAGE TRANSITIONS ────────────────────────────── */

a {
  transition: color 0.2s ease, opacity 0.2s ease !important;
}

/* Prevent jarring color flash on nav links */
.orynne-nav a,
.orynne-dropdown > span {
  will-change: color;
}
/* ── 1. FIX: LIGHTING DROPDOWN SPAN MATCHES NAV LINKS ─────── */

.orynne-dropdown > span {
  color: #d7d0c4;
  font-size: 16px !important;
  font-weight: 400;
  cursor: pointer;
  transition: 0.25s ease;
  letter-spacing: 0px;
  font-family: inherit;
}

.orynne-dropdown:hover > span {
  color: #ffffff;
}

.orynne-dropdown > span::after {
  content: " ↓";
  font-size: 11px;
  opacity: 0.55;
  margin-left: 2px;
  transition: 0.2s ease;
}

.orynne-dropdown:hover > span::after {
  opacity: 1;
}

/* ── 2. TRUST BAR ──────────────────────────────────────────── */

.orynne-trust-bar {
  background: #c7a27c;
  color: #0f120d;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  padding: 9px 24px;
  font-size: 12px;
  letter-spacing: 0.5px;
  font-weight: 500;
  flex-wrap: wrap;
}

.orynne-trust-bar span { white-space: nowrap; }

@media screen and (max-width: 749px) {
  .orynne-trust-bar {
    gap: 0;
    font-size: 11px;
  }
  .orynne-trust-bar span:not(:first-child) { display: none; }
}

/* ── 3. HEADER ─────────────────────────────────────────────── */

.orynne-topbar {
  padding: 20px 64px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
}

.orynne-nav { gap: 36px !important; }

.orynne-nav a,
.orynne-dropdown > span {
  font-size: 15px !important;
  letter-spacing: 0.2px !important;
}

.orynne-nav a[href*="reviews"] { color: rgba(199,162,124,0.85) !important; }
.orynne-nav a[href*="reviews"]:hover { color: #c7a27c !important; }

/* ── 4. CTA BUTTONS ────────────────────────────────────────── */

.orynne-hero-content a,
.orynne-link-btn {
  display: inline-block;
  background: #c7a27c;
  color: #0f120d !important;
  border: none !important;
  padding: 16px 34px !important;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-size: 12px;
  font-weight: 500;
  transition: 0.25s ease;
  cursor: pointer;
}

.orynne-hero-content a:hover,
.orynne-link-btn:hover {
  background: #b8916a !important;
  color: #0f120d !important;
  transform: translateY(-1px);
}

.orynne-link {
  color: #c7a27c !important;
  border-bottom: 1px solid rgba(199,162,124,0.35);
  padding-bottom: 2px;
}

.orynne-link:hover { border-bottom-color: #c7a27c; opacity: 1 !important; }

/* ── 5. PRODUCT CARDS ──────────────────────────────────────── */

.badge--sale,
.badge--on-sale {
  background: #c7a27c !important;
  color: #0f120d !important;
  font-weight: 600 !important;
}

.price--on-sale .price-item--sale { color: #c7a27c !important; }

.card-wrapper:hover,
.product-card-wrapper:hover {
  box-shadow: 0 8px 32px rgba(199,162,124,0.1) !important;
}

.quick-add__submit,
.product-form__submit {
  background: #c7a27c !important;
  color: #0f120d !important;
  border: none !important;
  font-weight: 500 !important;
}

.quick-add__submit:hover,
.product-form__submit:hover { background: #b8916a !important; }

/* ── 6. SOCIAL PROOF STRIP ─────────────────────────────────── */

.orynne-social-proof {
  background: #0f120d;
  border-top: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
  padding: 48px 7vw;
}

.osp-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 900px;
  margin: 0 auto;
  flex-wrap: wrap;
}

.osp-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 0 60px;
  flex: 1;
  min-width: 140px;
}

.osp-number {
  font-size: 38px;
  font-weight: 300;
  color: #f4efe3;
  letter-spacing: -1px;
  line-height: 1;
}

.osp-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: rgba(244,239,227,0.5);
}

.osp-divider {
  width: 1px;
  height: 50px;
  background: rgba(255,255,255,0.1);
  flex-shrink: 0;
}

@media screen and (max-width: 749px) {
  .osp-inner { gap: 32px; }
  .osp-divider { display: none; }
  .osp-stat { padding: 0 20px; min-width: 120px; }
  .osp-number { font-size: 30px; }
}

/* ── 7. MOBILE NAV ─────────────────────────────────────────── */

@media screen and (max-width: 900px) {
  .orynne-topbar {
    padding: 16px 20px !important;
    position: sticky !important;
    top: 0 !important;
    flex-wrap: wrap;
    gap: 14px;
  }
  .orynne-logo { flex: 1; }
  .orynne-nav {
    order: 3;
    width: 100%;
    gap: 20px !important;
    padding-bottom: 4px;
    overflow-x: auto;
    flex-wrap: nowrap !important;
    scrollbar-width: none;
  }
  .orynne-nav::-webkit-scrollbar { display: none; }
  .orynne-nav a,
  .orynne-dropdown > span {
    font-size: 14px !important;
    white-space: nowrap;
    flex-shrink: 0;
  }
}

/* ── 8. DROPDOWN ───────────────────────────────────────────── */

.orynne-dropdown-menu {
  background: rgba(10,12,8,0.98);
  box-shadow: 0 16px 40px rgba(0,0,0,0.4);
}

.orynne-dropdown-menu a:hover {
  background: rgba(199,162,124,0.06) !important;
  padding-left: 26px !important;
}

/* ── 9. SCROLLBAR ──────────────────────────────────────────── */

::-webkit-scrollbar-thumb {
  background-color: rgba(199,162,124,0.3) !important;
}
::-webkit-scrollbar-thumb:hover {
  background-color: rgba(199,162,124,0.5) !important;
}
/* ============================================================
   ORYNNE LIVING — MOBILE OVERRIDES
   All styles are scoped to max-width: 900px
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Outfit:wght@300;400;500&display=swap');

/* ── MOBILE TRUST BAR ─────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .orynne-trust-bar {
    padding: 7px 0 !important;
    gap: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    display: block !important;
    font-size: 10px !important;
    letter-spacing: 2px !important;
  }
  .orynne-trust-bar span { display: none !important; }
}

/* ── MOBILE HEADER ────────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .orynne-topbar {
    padding: 0 !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
  }

  .orynne-logo { flex: 1; }

  .orynne-logo a {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 26px !important;
    font-weight: 300 !important;
    letter-spacing: -0.5px !important;
    padding-left: 20px;
    display: block;
    line-height: 56px;
  }

  .orynne-nav--desktop { display: none !important; }

  .orynne-icons {
    gap: 4px !important;
    padding-right: 14px;
    height: 56px;
    align-items: center;
  }

  .orynne-icons a {
    width: 36px;
    height: 36px;
    display: flex !important;
    align-items: center;
    justify-content: center;
  }

  .orynne-icons svg {
    width: 19px !important;
    height: 19px !important;
  }

  .orynne-hamburger {
    display: flex !important;
    width: 36px;
    height: 36px;
    gap: 5px !important;
  }

  .orynne-hamburger span {
    width: 20px !important;
    height: 1.2px !important;
  }
}

/* ── MOBILE DRAWER ────────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .orynne-mobile-menu {
    padding: 88px 32px 48px !important;
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
  }

  .orynne-mobile-logo {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 32px !important;
    font-weight: 300 !important;
    letter-spacing: -1px !important;
    margin-bottom: 40px !important;
    padding-bottom: 28px !important;
  }

  .orynne-mobile-nav a {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 40px !important;
    font-weight: 300 !important;
    letter-spacing: -1px !important;
    padding: 14px 0 !important;
    color: #f4efe3 !important;
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .orynne-mobile-nav a::after {
    content: '→';
    font-size: 18px;
    opacity: 0.3;
    font-family: 'Outfit', sans-serif;
  }

  .orynne-mobile-nav .sale-link { color: #c7a27c !important; }

  .orynne-mobile-section-title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 40px !important;
    font-weight: 300 !important;
    letter-spacing: -1px !important;
    padding: 14px 0 8px !important;
    color: #f4efe3 !important;
    border-bottom: none !important;
    display: block !important;
  }

  .orynne-mobile-section {
    border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  }

  .orynne-mobile-sub {
    padding-left: 20px !important;
    padding-bottom: 16px !important;
    gap: 0 !important;
  }

  .orynne-mobile-sub a {
    font-family: 'Outfit', sans-serif !important;
    font-size: 16px !important;
    color: rgba(244,239,227,0.45) !important;
    padding: 10px 0 !important;
    letter-spacing: 0 !important;
    border-bottom: none !important;
  }

  .orynne-mobile-sub a::after { display: none !important; }
}

/* ── MOBILE HERO ──────────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-hero {
    height: 100svh !important;
    min-height: 600px !important;
    align-items: flex-end !important;
  }

  .oh-hero__content {
    margin: 0 !important;
    padding: 0 24px 48px !important;
    max-width: 100% !important;
  }

  .oh-hero__eyebrow {
    font-size: 9px !important;
    letter-spacing: 4px !important;
    margin-bottom: 14px !important;
  }

  .oh-hero__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: clamp(64px, 17vw, 88px) !important;
    letter-spacing: -2px !important;
    line-height: 0.88 !important;
    margin-bottom: 18px !important;
  }

  .oh-hero__sub {
    font-size: 13px !important;
    line-height: 1.75 !important;
    margin-bottom: 28px !important;
    max-width: 300px !important;
  }

  .oh-hero__actions {
    flex-direction: column !important;
    gap: 10px !important;
  }

  .oh-btn--primary, .oh-btn--ghost {
    display: block !important;
    text-align: center !important;
    width: 100% !important;
    padding: 16px 24px !important;
    font-size: 10px !important;
    letter-spacing: 3px !important;
  }

  .oh-hero__scroll-hint { display: none !important; }
}

/* ── MOBILE OFFER BAR ─────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-offer-bar { padding: 12px 0 !important; }
  .oh-offer-track span {
    font-size: 10px !important;
    padding: 0 24px !important;
    letter-spacing: 2px !important;
  }
}

/* ── MOBILE PHILOSOPHY ────────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-philosophy {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
  }

  .oh-philosophy__image { height: 280px !important; }

  .oh-philosophy__image img {
    height: 280px !important;
    object-fit: cover !important;
  }

  .oh-philosophy__text {
    padding: 40px 24px 48px !important;
    border-left: none !important;
    border-top: 1px solid rgba(255,255,255,0.07) !important;
  }

  .oh-philosophy__text h2 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 40px !important;
    letter-spacing: -1.5px !important;
    margin-bottom: 16px !important;
  }

  .oh-philosophy__text .oh-body {
    font-size: 14px !important;
    line-height: 1.8 !important;
    margin-bottom: 24px !important;
  }

  .oh-philosophy__stats {
    padding: 22px 0 !important;
    margin-bottom: 28px !important;
  }

  .oh-stat__n { font-size: 24px !important; }
  .oh-stat__l { font-size: 9px !important; }
}

/* ── MOBILE SHOWROOM CARDS ────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-showroom {
    padding: 52px 0 60px !important;
  }

  .oh-showroom__header {
    padding: 0 24px !important;
    margin-bottom: 32px !important;
    text-align: left !important;
  }

  .oh-showroom__header .oh-eyebrow {
    text-align: left !important;
    margin-bottom: 10px !important;
  }

  .oh-showroom__header h2 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 42px !important;
    letter-spacing: -1.5px !important;
    line-height: 1 !important;
    margin-bottom: 0 !important;
  }

  .oh-showroom__sub { display: none !important; }

  .oh-showroom__cards {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    gap: 12px !important;
    padding: 0 24px 8px !important;
    scrollbar-width: none !important;
    max-width: none !important;
    margin: 0 !important;
  }

  .oh-showroom__cards::-webkit-scrollbar { display: none !important; }

  .oh-scard {
    flex: 0 0 72vw !important;
    max-width: 280px !important;
    scroll-snap-align: start !important;
  }

  .oh-scard--1, .oh-scard--2, .oh-scard--3 { transform: none !important; }
  .oh-scard:hover { transform: none !important; box-shadow: none !important; }

  .oh-scard__img { height: 240px !important; }
  .oh-scard__body { padding: 22px 20px 26px !important; }

  .oh-scard__title {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 26px !important;
  }

  .oh-scard__desc { font-size: 12px !important; }
}

/* ── MOBILE TRUST SECTION ─────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-trust { flex-direction: column !important; }

  .oh-trust__divider {
    width: 100% !important;
    height: 1px !important;
  }

  .oh-trust__item {
    padding: 28px 24px !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 18px !important;
  }

  .oh-trust__icon {
    font-size: 18px !important;
    flex-shrink: 0 !important;
    width: 28px !important;
    margin-bottom: 0 !important;
    margin-top: 2px !important;
  }

  .oh-trust__item h3 { font-size: 11px !important; margin-bottom: 5px !important; }
  .oh-trust__item p { font-size: 12px !important; }
}

/* ── MOBILE FINAL BANNER ──────────────────────────────────── */
@media screen and (max-width: 900px) {
  .oh-standard {
    min-height: 420px !important;
    padding: 0 !important;
    align-items: flex-end !important;
  }

  .oh-standard__bg {
    background-image:
      linear-gradient(to top, rgba(8,10,7,0.97) 0%, rgba(8,10,7,0.55) 55%, rgba(8,10,7,0.2) 100%),
      url('https://images.unsplash.com/photo-1616486338812-3dadae4b4ace?auto=format&fit=crop&w=900&q=80') !important;
  }

  .oh-standard__content {
    padding: 0 24px 44px !important;
    max-width: 100% !important;
  }

  .oh-standard__content h2 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 44px !important;
    letter-spacing: -1.5px !important;
    margin-bottom: 12px !important;
  }

  .oh-standard__content .oh-body {
    font-size: 13px !important;
    margin-bottom: 24px !important;
  }

  .oh-standard__content .oh-btn--primary {
    width: 100% !important;
    display: block !important;
    text-align: center !important;
  }
}

/* ── MOBILE COLLECTION & PRODUCT PAGES ────────────────────── */
@media screen and (max-width: 900px) {
  .collection { padding: 20px 16px !important; }

  .orynne-collection-hero {
    margin: 16px 14px 28px !important;
    padding: 32px 20px 34px !important;
  }

  .orynne-collection-hero h1 {
    font-family: 'Cormorant Garamond', serif !important;
    font-size: 44px !important;
    letter-spacing: -1.5px !important;
  }

  .product-grid,
  .collection ul,
  ul.grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px 10px !important;
  }

  .card-wrapper, .product-card-wrapper {
    padding: 8px !important;
    border-radius: 12px !important;
  }

  .card__heading, .card-information, .card-information * {
    font-size: 13px !important;
  }

  .price, .price * { font-size: 13px !important; }
}

/* ── MOBILE FOOTER TOGGLE ─────────────────────────────────── */
@media screen and (max-width: 900px) {
  .orynne-custom-footer { display: none !important; }
  .orynne-mobile-footer { display: block !important; }
}

/* ── MOBILE FOOTER STYLES ─────────────────────────────────── */
.orynne-mobile-footer {
  display: none;
  background: #080907;
  border-top: 1px solid rgba(255,255,255,0.07);
  font-family: 'Outfit', sans-serif;
}

.omf-brand {
  padding: 44px 24px 32px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.omf-logo {
  font-family: 'Cormorant Garamond', serif;
  font-size: 36px; font-weight: 300;
  color: #f4efe3; letter-spacing: -1px;
  margin-bottom: 12px; display: block;
}

.omf-brand p {
  font-size: 13px; color: rgba(244,239,227,0.42);
  line-height: 1.7; max-width: 280px;
}

.omf-section { border-bottom: 1px solid rgba(255,255,255,0.07); }

.omf-toggle {
  width: 100%; background: none; border: none;
  color: #f4efe3; cursor: pointer;
  display: flex; align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  font-family: 'Outfit', sans-serif;
  font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase; font-weight: 400;
}

.omf-toggle-icon {
  font-size: 18px; color: rgba(244,239,227,0.3);
  transition: transform 0.3s ease; display: inline-block;
}

.omf-section.open .omf-toggle-icon { transform: rotate(45deg); }

.omf-links {
  max-height: 0; overflow: hidden;
  transition: max-height 0.4s cubic-bezier(0.22,1,0.36,1);
}

.omf-section.open .omf-links { max-height: 300px; }

.omf-links a {
  display: block; padding: 10px 24px;
  color: rgba(244,239,227,0.48);
  text-decoration: none; font-size: 14px;
  transition: color 0.2s ease;
}

.omf-links a:last-child { padding-bottom: 20px; }
.omf-links a:active { color: #c7a27c; }

.omf-newsletter {
  padding: 32px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

.omf-newsletter h3 {
  font-size: 10px; letter-spacing: 3px;
  text-transform: uppercase; color: #f4efe3;
  margin-bottom: 10px; font-weight: 400;
}

.omf-newsletter p {
  font-size: 13px; color: rgba(244,239,227,0.42);
  line-height: 1.65; margin-bottom: 18px;
}

.omf-input-row {
  display: flex;
  border: 1px solid rgba(255,255,255,0.12);
}

.omf-input-row input {
  flex: 1; background: transparent; border: none;
  color: #f4efe3; padding: 14px 16px;
  font-size: 14px; outline: none;
  font-family: 'Outfit', sans-serif;
}

.omf-input-row input::placeholder { color: rgba(244,239,227,0.28); }

.omf-input-row button {
  background: #c7a27c; border: none;
  color: #0a0c09; padding: 0 20px;
  font-size: 18px; cursor: pointer;
}

.omf-bottom {
  padding: 20px 24px;
  display: flex; flex-direction: column; gap: 10px;
}

.omf-bottom span { font-size: 11px; color: rgba(244,239,227,0.22); }
.omf-bottom-links { display: flex; gap: 20px; }
.omf-bottom-links a {
  font-size: 11px; color: rgba(244,239,227,0.22);
  text-decoration: none;
}
/* ── PRODUCT DESCRIPTION HEADING FIX ── */
.text-block.rte h1,
.text-block.rte h2,
.text-block.rte h3,
.text-block.rte h4,
.text-block.rte h5,
.text-block.rte h6,
rte-formatter h1,
rte-formatter h2,
rte-formatter h3,
rte-formatter h4,
rte-formatter h5,
rte-formatter h6 {
  font-size: 0.82rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  margin-block: 1.4rem 0.35rem !important;
  line-height: 1.4 !important;
}

/* =========================================================
   ORYNNE LIVING — CUSTOMER-FIRST REVAMP (May 2026)
   ========================================================= */
:root{
  --ol-ink:#191611; --ol-soft-ink:#4d463c; --ol-cream:#fbf7ef; --ol-paper:#fffdf8;
  --ol-stone:#eee5d8; --ol-sand:#d8bea0; --ol-clay:#a97855; --ol-olive:#25291f;
  --ol-moss:#596148; --ol-line:rgba(25,22,17,.13); --ol-shadow:0 24px 80px rgba(43,32,20,.12);
  --ol-radius:26px; --ol-radius-sm:16px; --ol-ease:cubic-bezier(.2,.8,.2,1);
}
html.ol-lock{overflow:hidden}.content-for-layout{background:var(--ol-cream);color:var(--ol-ink)}
body{background:var(--ol-cream)!important;color:var(--ol-ink)}
a{transition:color .22s var(--ol-ease), background .22s var(--ol-ease), border-color .22s var(--ol-ease), transform .22s var(--ol-ease)}
.ol-kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ol-clay);font-weight:800;margin:0 0 14px}.ol-lead{font-size:clamp(17px,2vw,22px);line-height:1.55;color:rgba(25,22,17,.72);max-width:680px}.ol-btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;padding:15px 24px;border-radius:999px;text-decoration:none;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.ol-btn--dark{background:var(--ol-ink);color:#fff!important;box-shadow:0 14px 34px rgba(25,22,17,.18)}.ol-btn--dark:hover{transform:translateY(-2px);background:var(--ol-olive)}.ol-btn--light{background:#fff;color:var(--ol-ink)!important;border:1px solid var(--ol-line)}.ol-btn--light:hover{border-color:var(--ol-clay);transform:translateY(-2px)}.ol-text-link{color:var(--ol-ink)!important;text-decoration:none;font-weight:850}.ol-text-link:hover{color:var(--ol-clay)!important}.ol-cta-row{display:flex;gap:12px;flex-wrap:wrap}
/* Header */
.ol-announcement{display:flex;justify-content:center;gap:34px;background:var(--ol-ink);color:var(--ol-cream);font-size:12px;font-weight:750;letter-spacing:.08em;text-transform:uppercase;padding:10px 18px}.ol-announcement span{position:relative}.ol-announcement span+span:before{content:"";position:absolute;left:-19px;top:50%;width:4px;height:4px;background:var(--ol-sand);border-radius:50%}.ol-header{position:sticky;top:0;z-index:50;display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center;padding:16px clamp(18px,4vw,56px);background:rgba(251,247,239,.88);backdrop-filter:blur(18px);border-bottom:1px solid var(--ol-line)}.ol-logo{font-size:28px;line-height:.9;text-decoration:none;color:var(--ol-ink)!important;letter-spacing:-.06em;font-weight:700}.ol-logo span{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.34em;margin-top:7px;color:var(--ol-clay);font-weight:900}.ol-nav{display:flex;align-items:center;justify-content:center;gap:6px}.ol-nav>a,.ol-nav-drop>button{border:0;background:transparent;text-decoration:none;color:var(--ol-ink);font-size:13px;font-weight:800;padding:12px 13px;border-radius:999px;cursor:pointer}.ol-nav>a:hover,.ol-nav-drop:hover>button{background:#fff;color:var(--ol-clay)}.ol-sale{color:#9c3f2c!important}.ol-nav-drop{position:relative}.ol-mega{position:absolute;left:50%;top:calc(100% + 12px);transform:translate(-50%,10px);width:min(980px,calc(100vw - 48px));display:grid;grid-template-columns:repeat(4,1fr) 1.3fr;gap:22px;background:var(--ol-paper);border:1px solid var(--ol-line);border-radius:24px;padding:24px;box-shadow:var(--ol-shadow);opacity:0;visibility:hidden;pointer-events:none;transition:.25s var(--ol-ease)}.ol-nav-drop:hover .ol-mega,.ol-nav-drop:focus-within .ol-mega{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,0)}.ol-mega p{margin:0 0 10px;color:var(--ol-clay);font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:.15em}.ol-mega a{display:block;text-decoration:none;color:var(--ol-soft-ink);font-weight:650;padding:6px 0}.ol-mega a:hover{color:var(--ol-ink);transform:translateX(3px)}.ol-mega-card{background:linear-gradient(135deg,var(--ol-olive),#111);border-radius:18px;padding:22px!important;color:#fff!important}.ol-mega-card span{font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ol-sand)}.ol-mega-card strong{display:block;font-size:20px;line-height:1.1;margin:12px 0}.ol-mega-card em{font-style:normal;color:var(--ol-sand)}.ol-mega--rooms{grid-template-columns:repeat(3,1fr);width:min(560px,calc(100vw - 48px))}.ol-actions{display:flex;align-items:center;gap:8px}.ol-icon-btn,.ol-menu-btn{width:42px;height:42px;border-radius:50%;border:1px solid var(--ol-line);background:#fff;color:var(--ol-ink);display:grid;place-items:center;position:relative}.ol-icon-btn svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}.ol-cart span{position:absolute;right:-4px;top:-5px;background:var(--ol-clay);color:#fff;border-radius:50%;font-size:10px;min-width:18px;height:18px;display:grid;place-items:center}.ol-menu-btn{display:none}.ol-menu-btn span{width:18px;height:2px;background:var(--ol-ink);display:block}.ol-menu-btn span+span{margin-top:-10px}.ol-search{position:fixed;inset:0;z-index:90;background:rgba(25,22,17,.42);display:grid;place-items:start center;padding:10vh 20px;opacity:0;visibility:hidden;transition:.22s var(--ol-ease)}.ol-search.is-open{opacity:1;visibility:visible}.ol-search__panel{width:min(760px,100%);background:var(--ol-paper);border-radius:30px;padding:34px;box-shadow:var(--ol-shadow);position:relative}.ol-search__close,.ol-drawer__close{position:absolute;right:20px;top:18px;border:0;background:var(--ol-cream);width:38px;height:38px;border-radius:50%;font-size:22px}.ol-search__form{display:flex;gap:10px}.ol-search__form input{flex:1;border:1px solid var(--ol-line);border-radius:999px;padding:16px 18px;background:#fff;color:var(--ol-ink)}.ol-search__form button,.ol-newsletter-form button{border:0;border-radius:999px;background:var(--ol-ink);color:#fff;font-weight:850;padding:0 22px}.ol-search__tags{display:flex;flex-wrap:wrap;gap:9px;margin-top:20px}.ol-search__tags a{background:var(--ol-cream);border:1px solid var(--ol-line);border-radius:999px;color:var(--ol-soft-ink);padding:9px 13px;text-decoration:none}.ol-drawer,.ol-drawer-backdrop{display:none}
/* Homepage */
.ol-home-hero{min-height:calc(100vh - 116px);display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);background:radial-gradient(circle at top left,#fff 0,#fbf7ef 38%,#efe2d0 100%);overflow:hidden}.ol-home-hero__media{order:2;position:relative;min-height:640px;padding:34px 34px 34px 0}.ol-home-hero__media:before{content:"";position:absolute;inset:80px 0 0 70px;background:var(--ol-olive);border-radius:38px 0 0 38px}.ol-home-hero__media img{position:relative;width:100%;height:100%;object-fit:cover;border-radius:38px 0 0 38px;box-shadow:var(--ol-shadow)}.ol-home-hero__content{display:flex;flex-direction:column;justify-content:center;padding:clamp(52px,7vw,110px) clamp(22px,6vw,86px)}.ol-home-hero h1{font-size:clamp(48px,7.6vw,112px);line-height:.88;letter-spacing:-.075em;margin:0 0 24px;color:var(--ol-ink);max-width:780px}.ol-hero-proof{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}.ol-hero-proof span{background:rgba(255,255,255,.68);border:1px solid var(--ol-line);border-radius:999px;padding:10px 14px;color:var(--ol-soft-ink);font-size:13px}.ol-hero-proof strong{color:var(--ol-ink)}.ol-shop-fast{display:flex;gap:10px;overflow:auto;padding:18px clamp(18px,4vw,56px);background:var(--ol-ink);scrollbar-width:none}.ol-shop-fast a{white-space:nowrap;color:var(--ol-cream);text-decoration:none;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:11px 16px;font-weight:750}.ol-shop-fast a:hover{background:var(--ol-cream);color:var(--ol-ink)}.ol-section{padding:clamp(58px,7vw,104px) clamp(18px,4vw,56px)}.ol-section-head{max-width:760px;margin:0 auto 34px;text-align:center}.ol-section-head h2,.ol-editorial h2,.ol-final-cta h2{font-size:clamp(34px,4.8vw,68px);line-height:.98;letter-spacing:-.055em;margin:0 0 16px}.ol-section-head p:not(.ol-kicker){color:var(--ol-soft-ink);font-size:17px}.ol-section-head--split{display:flex;align-items:end;justify-content:space-between;text-align:left;max-width:none}.ol-room-grid{display:grid;grid-template-columns:1.25fr 1fr 1fr;grid-auto-rows:330px;gap:16px}.ol-room-card{position:relative;overflow:hidden;border-radius:var(--ol-radius);text-decoration:none;color:#fff!important;background:var(--ol-olive);box-shadow:0 18px 50px rgba(25,22,17,.08)}.ol-room-card--large{grid-row:span 2}.ol-room-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ol-ease);filter:brightness(.78)}.ol-room-card:hover img{transform:scale(1.05);filter:brightness(.64)}.ol-room-card span,.ol-room-card strong,.ol-room-card em{position:absolute;left:24px;right:24px;z-index:2}.ol-room-card span{top:22px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ol-sand);font-weight:850}.ol-room-card strong{bottom:58px;font-size:clamp(22px,2.3vw,34px);line-height:1.02;max-width:420px}.ol-room-card em{bottom:26px;font-style:normal;font-weight:850;color:#fff}.ol-editorial{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;padding:clamp(58px,7vw,104px) clamp(18px,4vw,56px);background:var(--ol-olive);color:var(--ol-cream)}.ol-editorial__text,.ol-editorial__panel{border:1px solid rgba(255,255,255,.12);border-radius:var(--ol-radius);padding:clamp(28px,5vw,58px)}.ol-editorial p,.ol-editorial li{color:rgba(251,247,239,.72);font-size:16px;line-height:1.75}.ol-editorial ul{padding-left:20px;margin:22px 0}.ol-editorial .ol-text-link{color:var(--ol-sand)!important}.ol-editorial__panel{background:linear-gradient(145deg,#fff7,#fff1);display:flex;flex-direction:column;justify-content:end;min-height:420px}.ol-editorial__panel span{color:var(--ol-sand);font-weight:900;text-transform:uppercase;letter-spacing:.15em;font-size:12px}.ol-editorial__panel h3{font-size:clamp(30px,4vw,54px);line-height:.98;letter-spacing:-.05em;margin:18px 0}.ol-collection-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.ol-collection-grid a{min-height:220px;border-radius:var(--ol-radius);padding:22px;background:#fff;border:1px solid var(--ol-line);text-decoration:none;color:var(--ol-ink)!important;display:flex;flex-direction:column;justify-content:space-between;box-shadow:0 12px 40px rgba(25,22,17,.05)}.ol-collection-grid a:hover{transform:translateY(-4px);box-shadow:var(--ol-shadow)}.ol-collection-grid span{font-size:24px;font-weight:850;letter-spacing:-.04em}.ol-collection-grid em{font-style:normal;color:var(--ol-clay);font-weight:850}.ol-trust-band{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--ol-line);padding:1px}.ol-trust-band div{background:var(--ol-paper);padding:32px;text-align:center}.ol-trust-band strong{display:block;font-size:18px}.ol-trust-band span{display:block;margin-top:7px;color:var(--ol-soft-ink)}.ol-final-cta{text-align:center;padding:clamp(70px,8vw,120px) 20px;background:linear-gradient(180deg,var(--ol-cream),#ead8c4)}.ol-final-cta h2{max-width:800px;margin:0 auto 28px}
/* Footer */
.ol-footer-main{background:var(--ol-ink);color:var(--ol-cream);padding:56px clamp(18px,4vw,56px) 24px}.ol-footer-main a{color:rgba(251,247,239,.72);text-decoration:none}.ol-footer-main a:hover{color:var(--ol-sand)}.ol-footer-main .ol-logo{color:var(--ol-cream)!important}.ol-footer-main__top{display:grid;grid-template-columns:1.4fr repeat(3,.72fr) 1.15fr;gap:34px}.ol-footer-brand p,.ol-footer-newsletter p{color:rgba(251,247,239,.66);line-height:1.7;max-width:320px}.ol-footer-badges{display:flex;gap:8px;flex-wrap:wrap}.ol-footer-badges span{border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:8px 10px;color:var(--ol-sand);font-size:12px}.ol-footer-col h3,.ol-footer-newsletter h3{margin:0 0 15px;color:#fff}.ol-footer-col a{display:block;margin:10px 0}.ol-newsletter-form{display:flex;gap:8px;margin-top:18px}.ol-newsletter-form input{min-width:0;flex:1;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);border-radius:999px;padding:13px 14px;color:#fff}.ol-newsletter-form button{background:var(--ol-sand);color:var(--ol-ink)}.ol-footer-main__bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:42px;padding-top:20px;display:flex;justify-content:space-between;gap:18px;color:rgba(251,247,239,.55);font-size:13px}.ol-footer-main__bottom a{margin-left:16px}
/* Global store page polish */
.product-card,.product-grid__item,.collection-card{border-radius:20px!important;overflow:hidden}.product-card img,.collection-card img{transition:transform .55s var(--ol-ease)}.product-card:hover img,.collection-card:hover img{transform:scale(1.035)}.price,.product-price{font-weight:850;color:var(--ol-ink)}button[type="submit"],.button,.shopify-payment-button__button{border-radius:999px!important;font-weight:850!important;letter-spacing:.04em}.facets,.collection-hero,.product-information,.cart-page,.main-page{background:var(--ol-cream)}.collection-hero{border-bottom:1px solid var(--ol-line)}
@media (max-width:990px){.ol-announcement{gap:14px;justify-content:flex-start;overflow:auto;white-space:nowrap}.ol-announcement span+span:before{display:none}.ol-header{grid-template-columns:auto auto;justify-content:space-between}.ol-nav{display:none}.ol-menu-btn{display:grid}.ol-home-hero{grid-template-columns:1fr}.ol-home-hero__media{order:0;min-height:360px;padding:18px}.ol-home-hero__media:before{display:none}.ol-home-hero__media img{border-radius:26px}.ol-home-hero__content{padding:34px 20px 54px}.ol-room-grid{grid-template-columns:1fr 1fr;grid-auto-rows:280px}.ol-room-card--large{grid-row:span 1;grid-column:span 2}.ol-editorial{grid-template-columns:1fr}.ol-collection-grid,.ol-trust-band{grid-template-columns:1fr 1fr}.ol-footer-main__top{grid-template-columns:1fr 1fr}.ol-footer-brand,.ol-footer-newsletter{grid-column:span 2}.ol-drawer,.ol-drawer-backdrop{display:block}.ol-drawer{position:fixed;right:0;top:0;bottom:0;width:min(390px,88vw);background:var(--ol-paper);z-index:100;transform:translateX(105%);transition:.28s var(--ol-ease);padding:30px;box-shadow:var(--ol-shadow);overflow:auto}.ol-drawer.is-open{transform:none}.ol-drawer-backdrop{position:fixed;inset:0;background:rgba(25,22,17,.42);z-index:99;opacity:0;visibility:hidden;transition:.22s}.ol-drawer-backdrop.is-open{opacity:1;visibility:visible}.ol-drawer>a,.ol-drawer details>a{display:block;padding:14px 0;color:var(--ol-ink);text-decoration:none;font-weight:800;border-bottom:1px solid var(--ol-line)}.ol-drawer summary{padding:14px 0;font-weight:900;cursor:pointer}.ol-drawer__close{background:var(--ol-cream)}}
@media (max-width:640px){.ol-actions .ol-icon-btn[href="/account"]{display:none}.ol-home-hero h1{font-size:52px}.ol-cta-row .ol-btn{width:100%}.ol-room-grid,.ol-collection-grid,.ol-trust-band{grid-template-columns:1fr}.ol-room-card--large{grid-column:auto}.ol-room-card{height:280px}.ol-section-head--split{display:block}.ol-footer-main__top{grid-template-columns:1fr}.ol-footer-brand,.ol-footer-newsletter{grid-column:auto}.ol-footer-main__bottom{display:block}.ol-footer-main__bottom a{display:inline-block;margin:12px 14px 0 0}.ol-search__form{display:block}.ol-search__form button{width:100%;height:48px;margin-top:10px}.ol-search__panel{padding:26px 18px}}

/* =========================================================
   ORYNNE LIVING — REFINEMENTS (May 2026)
   Contrast fixes, mobile-first mobile, product page polish
   ========================================================= */

/* CONTRAST FIXES */
.ol-kicker { color: #8b6f47 !important; font-weight: 900 !important; }
.ol-lead, .ol-section-head p:not(.ol-kicker) { color: #3a3530 !important; }
.ol-soft-ink { color: #3a3530 !important; }
h1, h2, h3, h4, h5, h6 { color: var(--ol-ink) !important; }
.product-title, .product-name { color: var(--ol-ink) !important; font-weight: 900 !important; }
.product-description { color: #3a3530 !important; }
.price, .product-price, .product__price { color: var(--ol-ink) !important; font-weight: 900 !important; }

/* Product page contrast polish */
.product-information { background: var(--ol-cream) !important; }
.product-information h1 { color: var(--ol-ink) !important; font-size: clamp(28px, 5vw, 48px) !important; font-weight: 900 !important; margin-bottom: 16px !important; }
.product-information .price { color: var(--ol-ink) !important; font-size: clamp(18px, 3vw, 28px) !important; font-weight: 900 !important; }
.product-description, .product-meta, .product-form { color: #3a3530 !important; }
.product-form label { color: var(--ol-ink) !important; font-weight: 800 !important; }

/* Collection page contrast */
.collection-hero h1 { color: var(--ol-ink) !important; font-weight: 900 !important; }
.collection-hero p { color: #3a3530 !important; }
.product-card__title { color: var(--ol-ink) !important; font-weight: 850 !important; }
.product-card__price { color: var(--ol-ink) !important; font-weight: 900 !important; }

/* MOBILE-FIRST REFINEMENTS */
@media (max-width: 768px) {
  /* Ensure header is fully sticky and responsive */
  .ol-header { 
    position: sticky !important; 
    top: 0 !important; 
    z-index: 50 !important; 
    padding: 12px clamp(12px, 3vw, 20px) !important; 
  }
  
  /* Announcement bar scrollable on mobile */
  .ol-announcement { 
    font-size: 11px !important; 
    padding: 8px 12px !important; 
    gap: 10px !important; 
  }
  
  /* Hero section mobile-first */
  .ol-home-hero { 
    grid-template-columns: 1fr !important; 
    min-height: auto !important; 
  }
  .ol-home-hero__media { 
    min-height: 280px !important; 
    padding: 12px !important; 
    order: 0 !important; 
  }
  .ol-home-hero__content { 
    padding: 24px 16px 32px !important; 
  }
  .ol-home-hero h1 { 
    font-size: clamp(32px, 7vw, 48px) !important; 
    line-height: 1 !important; 
  }
  
  /* Room cards stack better on mobile */
  .ol-room-grid { 
    grid-template-columns: 1fr !important; 
    grid-auto-rows: 240px !important; 
  }
  .ol-room-card { 
    min-height: 240px !important; 
  }
  .ol-room-card--large { 
    grid-column: auto !important; 
    grid-row: auto !important; 
  }
  
  /* Collection grid mobile */
  .ol-collection-grid { 
    grid-template-columns: 1fr !important; 
  }
  
  /* Trust band mobile */
  .ol-trust-band { 
    grid-template-columns: 1fr !important; 
    gap: 0 !important; 
  }
  .ol-trust-band div { 
    padding: 18px 16px !important; 
    border: 1px solid var(--ol-line) !important; 
  }
  
  /* Footer mobile */
  .ol-footer-main__top { 
    grid-template-columns: 1fr !important; 
  }
  .ol-footer-brand, .ol-footer-newsletter { 
    grid-column: auto !important; 
  }
  
  /* Product card contrast on mobile */
  .product-card { 
    border-radius: 16px !important; 
  }
  .product-card__title { 
    color: var(--ol-ink) !important; 
    font-weight: 850 !important; 
    font-size: 14px !important; 
  }
  
  /* Buttons full width on mobile */
  .ol-cta-row { 
    flex-direction: column !important; 
  }
  .ol-btn { 
    width: 100% !important; 
  }
  
  /* Search form mobile */
  .ol-search__form { 
    display: flex !important; 
    flex-direction: column !important; 
  }
  .ol-search__form button { 
    width: 100% !important; 
    height: 44px !important; 
    margin-top: 8px !important; 
  }
}

@media (max-width: 480px) {
  /* Extra small mobile adjustments */
  .ol-home-hero h1 { 
    font-size: 28px !important; 
  }
  .ol-section-head h2 { 
    font-size: 24px !important; 
  }
  .ol-room-card span { 
    font-size: 10px !important; 
  }
  .ol-room-card strong { 
    font-size: 16px !important; 
  }
  .ol-hero-proof { 
    flex-direction: column !important; 
  }
  .ol-hero-proof span { 
    font-size: 12px !important; 
    width: 100% !important; 
  }
}

/* Ensure product page text is readable */
.product-information * { 
  color: inherit !important; 
}
.product-information h1, 
.product-information h2, 
.product-information h3 { 
  color: var(--ol-ink) !important; 
}
.product-information p, 
.product-information span, 
.product-information li { 
  color: #3a3530 !important; 
}

/* Collection page readability */
.collection-hero * { 
  color: inherit !important; 
}
.collection-hero h1, 
.collection-hero h2 { 
  color: var(--ol-ink) !important; 
}
.collection-hero p { 
  color: #3a3530 !important; 
}

/* DROPDOWN MENU POSITIONING FIX */
.ol-mega {
  top: calc(100% + 6px) !important;
  transform: translate(-50%, 8px) !important;
  transition: all .25s var(--ol-ease) !important;
}

.ol-nav-drop:hover .ol-mega,
.ol-nav-drop:focus-within .ol-mega {
  transform: translate(-50%, 0) !important;
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.ol-mega:hover {
  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: auto !important;
}

.ol-nav-drop {
  position: relative;
}

.ol-nav-drop::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 10px;
  pointer-events: auto;
}


/* =========================================================
   ORYNNE LIVING — FONT COLOR FIXES
   Fix 1: Product card titles on collection pages (invisible cream text on cream bg)
   Fix 2: Product page description/meta text
   Fix 3: Add to Cart button text → white
   ========================================================= */

/* FIX 1 — Collection page: card titles & info text */
.card__heading,
.card__heading a,
.card-information,
.card-information *,
.card-information h3,
.card-information .card__heading {
  color: #191611 !important;
}

/* FIX 2 — Product page: description text below price */
.product__description,
.product-description,
.product__description p,
.product__description li,
.product-single__description,
[class*="product-description"],
.product-form__description {
  color: #3a3530 !important;
}

/* FIX 3 — Add to Cart button: white text */
.product-form__cart-submit,
button.product-form__cart-submit,
[name="add"],
.add-to-cart-button,
button[data-testid="standalone-add-to-cart"] {
  color: #ffffff !important;
}

/* =========================================================
   ORYNNE LIVING — DEFINITIVE COLOR FIX (overrides inline styles)
   The product card inherits scheme-1 (cream text) but sits on a cream page.
   We override the CSS custom property --color-foreground at the component level
   so it beats the inherited scheme value even on inline styles.
   ========================================================= */

/* Product card text on collection page */
.product-card__content,
.product-card__content *,
product-card .product-card__content {
  --color-foreground: #191611 !important;
  --color-foreground-heading: #191611 !important;
  --color: #191611 !important;
  --font-h1--color: #191611 !important;
  --font-h2--color: #191611 !important;
  --font-h3--color: #191611 !important;
  --font-h4--color: #191611 !important;
  --font-h5--color: #191611 !important;
  --font-h6--color: #191611 !important;
}

/* Product page: description, meta text */
.product-information,
.product-information * {
  --color-foreground: #191611 !important;
  --color-foreground-heading: #191611 !important;
}

/* Add to Cart button text — white */
.product-form__cart-submit,
button[name="add"],
.add-to-cart-button,
[data-testid="standalone-add-to-cart"] {
  --color-primary-button-text: #ffffff !important;
  color: #ffffff !important;
}

/* =========================================================
   ORYNNE LIVING — HOMEPAGE & COLLECTION HEADER FIXES
   ========================================================= */

/* FIX 1: Homepage editorial section — remove dark green bg, use cream instead */
.ol-editorial {
  background: var(--ol-stone) !important; /* warm stone #eee5d8 - fits site palette */
  color: var(--ol-ink) !important;
}
.ol-editorial__text,
.ol-editorial__panel {
  border-color: var(--ol-line) !important;
}
.ol-editorial p,
.ol-editorial li {
  color: var(--ol-soft-ink) !important;
}
.ol-editorial h2 {
  color: var(--ol-ink) !important;
}
.ol-editorial .ol-text-link {
  color: var(--ol-clay) !important;
}
.ol-editorial__panel {
  background: rgba(255,255,255,0.7) !important;
}
.ol-editorial__panel span {
  color: var(--ol-clay) !important;
}
.ol-editorial__panel h3 {
  color: var(--ol-ink) !important;
}

/* FIX 2: Collection page hero title — cream/warm white color, bolder weight */
.ory-col-hero__title {
  color: #fbf7ef !important;  /* ol-cream — warm white, readable on dark hero bg */
  font-weight: 600 !important;
}
.ory-col-hero__meta {
  color: rgba(251, 247, 239, 0.65) !important; /* slightly muted cream */
  opacity: 1 !important;
}

/* =========================================================
   ORYNNE LIVING — THREE MORE FIXES
   ========================================================= */

/* FIX 1: Add to Cart button text → black (it was showing white on the light quick-add pill) */
.button[name="add"],
.button[type="submit"],
add-to-cart-component .button,
.add-to-cart-button.button,
.product-form__cart-submit {
  color: #191611 !important;
  --button-color: #191611 !important;
}

/* FIX 2: Trust band headings (Free shipping / 30-day returns / Support that helps)
   The <strong> tags are inheriting a very faded/light color — make them dark */
.ol-trust-band strong {
  color: var(--ol-ink) !important;
  font-weight: 700 !important;
}
.ol-trust-band span {
  color: var(--ol-soft-ink) !important;
}

/* FIX 3: Homepage category pill bar (Bar Stools, Storage, etc.)
   Change background from dark ink to warm cream/stone */
.ol-shop-fast {
  background: var(--ol-ink) !important; /* keep dark — but change pill style */
}
/* Actually per the screenshot the bar IS dark — user wants it changed.
   Switch to a warm stone/tan background with dark text pills */
.ol-shop-fast {
  background: var(--ol-stone) !important;
  border-top: 1px solid var(--ol-line);
  border-bottom: 1px solid var(--ol-line);
}
.ol-shop-fast a {
  color: var(--ol-ink) !important;
  border-color: var(--ol-line) !important;
  background: rgba(255,255,255,0.6);
}
.ol-shop-fast a:hover {
  background: var(--ol-ink) !important;
  color: var(--ol-cream) !important;
  border-color: var(--ol-ink) !important;
}

/* FIX 3b: The dark olive accent shape behind the hero image — change to warm sand/tan */
.ol-home-hero__media:before {
  background: var(--ol-sand) !important; /* warm tan #d8bea0 instead of dark green */
}
/* Cart page text fix */
.cart-page,
.cart-page *,
.main-cart,
.main-cart *,
[id="main-cart-items"],
[id="main-cart-items"] *,
[id="main-cart-footer"],
[id="main-cart-footer"] * {
  --color-foreground: #191611 !important;
  --color: #191611 !important;
  color: #191611 !important;
}

/* Checkout button specifically — white text on dark button */
.cart__checkout-button,
.cart__checkout-button * {
  color: #fbf7ef !important;
  --color: #fbf7ef !important;
}
/* Cart checkout button fix */
.cart__checkout-button,
button.cart__checkout-button {
  background-color: #191611 !important;
  color: #fbf7ef !important;
  --button-color: #fbf7ef !important;
  --button-background-color: #191611 !important;
}
/* Fix collection hero and filter bar text — undo cart page bleed */
.ory-col-hero__title {
  color: #fbf7ef !important;
  font-weight: 600 !important;
}

.ory-col-hero__eyebrow {
  color: #c9a96e !important;
}

.ory-col-hero__meta {
  color: rgba(251, 247, 239, 0.65) !important;
}

/* Fix filter/sort bar text */
.facets,
.facets *,
.facets-container,
.facets-container * {
  --color-foreground: #191611 !important;
  --color: #191611 !important;
  color: #191611 !important;
}
.ory-col-hero__title {
  color: #191611 !important;
  font-weight: 600 !important;
}

.ory-col-hero__meta {
  color: rgba(25, 22, 17, 0.5) !important;
}

/* Mobile*/
.ol-drawer summary {
  color: #191611 !important;
  font-weight: 700 !important;
}
/* Mobile drawer — make Shop Products & Shop Rooms look tappable */
.ol-drawer summary {
  color: #191611 !important;
  font-weight: 700 !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
}

.ol-drawer summary::after {
  content: '+' !important;
  font-size: 22px !important;
  font-weight: 300 !important;
  color: #a97855 !important;
  transition: transform .25s ease !important;
}

.ol-drawer details[open] summary::after {
  content: '−' !important;
}
.ol-announcement-track {
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
  animation: ol-marquee 28s linear infinite !important;
}

.ol-announcement-track span {
  display: inline-flex !important;
  align-items: center !important;
  padding: 10px 0 !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.ol-announcement {
  overflow: hidden !important;
  display: flex !important;
  padding: 0 !important;
  white-space: nowrap !important;
}
