/** Shopify CDN: Minification failed

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

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:announcement-bar (INDEX:1) */
.announcement-bar {
    background-color: var(--announcement-bg);
    color: var(--announcement-fg);
    font-size: 0.8125rem;
    line-height: 1.4;
    text-align: var(--announcement-align);
    padding-block: 0.625rem;
    padding-inline: var(--page-margin);
    margin-bottom: var(--header-banner-gap, 0.75rem);
  }

  .announcement-bar__inner {
    max-width: var(--page-width);
    margin-inline: auto;
  }

  .announcement-bar__text.rte a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 0.125em;
  }

  .announcement-bar__text.rte > * {
    margin-block: 0;
  }

  .announcement-bar__text.rte > * + * {
    margin-block-start: 0.25rem;
  }
/* END_SECTION:announcement-bar */

/* START_SECTION:banner (INDEX:3) */
.banner {
    position: relative;
    width: 100%;
    overflow: hidden;
  }

  /* Breathing room below the fixed header; keep hero in view when header returns. */
  .shopify-section--banner {
    margin-top: var(--header-banner-gap, 0.75rem);
    scroll-margin-top: calc(
      var(--header-height, 4rem) + var(--announcement-height, 0px) + var(--header-banner-gap, 0.75rem)
    );
  }

  .banner__media-shell {
    position: relative;
    width: 100%;
  }

  .banner--mode-aspect .banner__media-shell {
    aspect-ratio: var(--banner-aspect);
  }

  .banner--mode-aspect .banner__media {
    position: absolute;
    inset: 0;
  }

  .banner--mode-intrinsic .banner__media {
    position: relative;
  }

  .banner__media {
    overflow: hidden;
    background: color-mix(in srgb, var(--color-foreground) 6%, var(--color-background));
  }

  .banner__image--cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
  }

  .banner__image--intrinsic {
    width: 100%;
    height: auto;
    vertical-align: middle;
    display: block;
  }

  .banner__video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .banner__media--video-intrinsic .banner__video {
    height: 100%;
    object-fit: cover;
  }

  .banner__placeholder-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 14rem;
    padding: 2rem;
  }

  .banner__placeholder {
    width: 100%;
    max-width: 28rem;
    height: auto;
    opacity: 0.35;
  }

  .banner__overlay {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background: #000;
    opacity: var(--banner-overlay, 0.25);
  }

  .banner__content {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: var(--banner-v-align);
    align-items: var(--banner-h-align);
    padding: clamp(1rem, 4vw, 3rem);
    text-align: var(--banner-text-align);
    pointer-events: none;
  }

  .banner__text {
    max-width: 40rem;
    pointer-events: auto;
  }

  .banner__heading {
    margin: 0 0 0.5rem;
    font-family: var(--banner-content-ff);
    font-size: var(--banner-heading-size);
    font-weight: var(--banner-heading-weight);
    font-style: var(--banner-content-style);
    text-transform: var(--banner-content-transform);
    color: var(--banner-text-color);
    line-height: 1.15;
  }

  .banner__body {
    margin: 0 0 1rem;
    font-family: var(--banner-content-ff);
    font-size: var(--banner-body-size);
    font-weight: var(--banner-body-weight);
    font-style: var(--banner-content-style);
    text-transform: var(--banner-content-transform);
    color: var(--banner-text-color);
    line-height: 1.5;
  }

  .banner__body.rte > *:first-child {
    margin-block-start: 0;
  }

  .banner__body.rte > *:last-child {
    margin-block-end: 0;
  }

  .banner__body.rte a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 0.15em;
  }

  .banner__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 0.25rem;
    padding: 0.65em 1.35em;
    font-family: var(--banner-button-ff);
    font-size: var(--banner-button-size);
    font-weight: var(--banner-button-weight);
    font-style: var(--banner-button-style);
    text-transform: var(--banner-button-transform);
    letter-spacing: 0.02em;
    text-decoration: none;
    color: var(--banner-button-color);
    background-color: var(--banner-button-bg);
    border: var(--banner-button-border-w) solid var(--banner-button-border);
    border-radius: var(--banner-button-radius);
    cursor: pointer;
    transition:
      opacity 0.15s ease,
      transform 0.15s ease;
  }

  @media screen and (max-width: 749px) {
    .banner__content {
      padding: 2.5rem 1.5rem;
    }

    .banner__text {
      max-width: min(17.5rem, 86%);
    }

    .banner__heading {
      font-size: clamp(1.375rem, 6.5vw, 2rem);
      line-height: 1.2;
    }

    .banner__body {
      font-size: min(var(--banner-body-size), 0.9375rem);
      line-height: 1.45;
    }

    .banner__button {
      font-size: min(var(--banner-button-size), 0.8125rem);
      padding: 0.6em 1.15em;
    }
  }

  .banner__button:hover {
    opacity: 0.92;
  }

  .banner__button:focus-visible {
    outline: 2px solid var(--banner-button-color);
    outline-offset: 3px;
  }
/* END_SECTION:banner */

/* START_SECTION:cart (INDEX:5) */
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .cart-page {
    width: 100%;
    background: var(--color-background);
    color: var(--color-foreground);
  }

  .cart-page__inner {
    max-width: var(--page-width);
    margin: 0 auto;
    padding: clamp(1.5rem, 4vw, 2.5rem) var(--page-margin) clamp(2.5rem, 6vw, 4rem);
  }

  .cart-page__header {
    margin-bottom: clamp(1.5rem, 3vw, 2rem);
    padding-bottom: 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .cart-page__title {
    margin: 0;
    font-family: var(--font-primary--family);
    font-size: clamp(1.75rem, 4vw, 2.25rem);
    font-weight: 400;
    letter-spacing: -0.02em;
    color: var(--color-text-bold);
    line-height: 1.15;
  }

  .cart-page__count {
    margin: 0.5rem 0 0;
    font-size: 0.875rem;
    color: color-mix(in srgb, var(--color-foreground) 58%, transparent);
  }

  .cart-page__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 2rem;
    align-items: start;
  }

  @media (min-width: 900px) {
    .cart-page__layout {
      grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.42fr);
      gap: clamp(2rem, 4vw, 3.5rem);
    }
  }

  .cart-page__items {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .cart-page__item {
    display: grid;
    grid-template-columns: 7.5rem minmax(0, 1fr);
    gap: 1rem 1.25rem;
    padding: 1.35rem 0;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
  }

  .cart-page__item:first-child {
    padding-top: 0;
  }

  .cart-page__item-media {
    display: block;
    border-radius: 10px;
    overflow: hidden;
    background: color-mix(in srgb, var(--color-foreground) 5%, transparent);
    aspect-ratio: 1;
  }

  .cart-page__item-image {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .cart-page__item-placeholder {
    width: 100%;
    height: 100%;
    min-height: 7.5rem;
    background: color-mix(in srgb, var(--color-foreground) 8%, transparent);
  }

  .cart-page__item-body {
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    min-width: 0;
  }

  .cart-page__item-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
  }

  .cart-page__item-title {
    font-family: var(--font-primary--family);
    font-size: 1rem;
    line-height: 1.35;
    color: var(--color-text-bold);
    text-decoration: none;
    transition: opacity 0.2s ease;
  }

  .cart-page__item-title:hover {
    opacity: 0.72;
  }

  .cart-page__item-remove {
    flex-shrink: 0;
    font-family: inherit;
    font-size: 0.75rem;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-foreground) 52%, transparent);
    text-decoration: none;
    background: none;
    border: 0;
    border-bottom: 1px solid transparent;
    padding: 0;
    cursor: pointer;
    transition: color 0.2s ease, border-color 0.2s ease;
  }

  .cart-page__item-remove:hover {
    color: var(--color-text-bold);
    border-bottom-color: currentColor;
  }

  .cart-page__item-remove:disabled {
    opacity: 0.5;
    cursor: wait;
  }

  .cart-page__item-variant,
  .cart-page__item-plan,
  .cart-page__item-property {
    margin: 0;
    font-size: 0.8125rem;
    line-height: 1.45;
    color: color-mix(in srgb, var(--color-foreground) 62%, transparent);
  }

  .cart-page__item-discounts {
    margin: 0;
    padding: 0;
    list-style: none;
    font-size: 0.75rem;
    color: #0d7a4d;
  }

  .cart-page__item-discounts li::before {
    content: '✓ ';
  }

  .cart-page__item-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-top: 0.65rem;
  }

  .cart-page__qty {
    display: flex;
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    border-radius: 8px;
    overflow: hidden;
    background: var(--color-background);
  }

  .cart-page__qty-btn {
    width: 2.5rem;
    height: 2.5rem;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 1.05rem;
    line-height: 1;
    color: color-mix(in srgb, var(--color-foreground) 70%, transparent);
    transition: background 0.2s ease;
  }

  .cart-page__qty-btn:hover {
    background: color-mix(in srgb, var(--color-foreground) 6%, transparent);
  }

  .cart-page__qty-value {
    min-width: 1.75rem;
    text-align: center;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text-bold);
  }

  .cart-page__item-prices {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.15rem;
    text-align: right;
  }

  .cart-page__price {
    font-size: 0.9375rem;
    font-weight: 600;
    color: var(--color-text-bold);
    white-space: nowrap;
  }

  .cart-page__price--compare {
    font-size: 0.8125rem;
    font-weight: 400;
    text-decoration: line-through;
    color: color-mix(in srgb, var(--color-foreground) 48%, transparent);
  }

  .cart-page__unit-price {
    font-size: 0.75rem;
    color: color-mix(in srgb, var(--color-foreground) 55%, transparent);
  }

  .cart-page__summary-card {
    position: sticky;
    top: calc(var(--header-height, 4rem) + 1rem);
    padding: 1.5rem;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    background: color-mix(in srgb, var(--color-background) 92%, var(--color-foreground) 3%);
  }

  .cart-page__summary-title {
    margin: 0 0 1.25rem;
    font-family: var(--font-primary--family);
    font-size: 1.125rem;
    font-weight: 400;
    color: var(--color-text-bold);
  }

  .cart-page__note {
    display: block;
    margin-bottom: 1rem;
  }

  .cart-page__note-label {
    display: block;
    margin-bottom: 0.4rem;
    font-size: 0.8125rem;
    color: color-mix(in srgb, var(--color-foreground) 65%, transparent);
  }

  .cart-page__note-input {
    width: 100%;
    min-height: 4.5rem;
    padding: 0.65rem 0.75rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    border-radius: 8px;
    background: var(--color-background);
    font-family: var(--font-body--family);
    font-size: 0.875rem;
    color: var(--color-foreground);
    resize: vertical;
    transition: border-color 0.2s ease;
  }

  .cart-page__note-input:focus {
    outline: none;
    border-color: var(--color-text-bold);
  }

  .cart-page__discounts {
    margin: 0 0 1rem;
    padding: 0;
    list-style: none;
    font-size: 0.8125rem;
  }

  .cart-page__discount-row {
    display: flex;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.35rem 0;
    color: #0d7a4d;
  }

  .cart-page__subtotal-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 1rem;
    padding: 0.85rem 0 0.5rem;
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    font-size: 0.9375rem;
  }

  .cart-page__subtotal-row span:last-child {
    font-family: var(--font-primary--family);
    font-size: 1.25rem;
    color: var(--color-text-bold);
  }

  .cart-page__tax-note {
    margin: 0 0 1.25rem;
    font-size: 0.75rem;
    line-height: 1.5;
    color: color-mix(in srgb, var(--color-foreground) 55%, transparent);
  }

  .cart-page__summary-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .cart-page__checkout {
    width: 100%;
    min-height: 3rem;
    padding: 0.85rem 1.25rem;
    border: 1px solid var(--color-button-border);
    border-radius: 8px;
    background: var(--color-button-bg);
    color: var(--color-button-text);
    font-family: var(--font-body--family);
    font-size: var(--font-size-base);
    cursor: pointer;
    transition: opacity 0.2s ease, transform 0.15s ease;
  }

  .cart-page__checkout:hover {
    opacity: 0.92;
  }

  .cart-page__update {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.7rem 1rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 22%, transparent);
    border-radius: 8px;
    background: transparent;
    color: var(--color-text-bold);
    font-family: var(--font-body--family);
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
  }

  .cart-page__update:hover {
    background: color-mix(in srgb, var(--color-foreground) 5%, transparent);
    border-color: color-mix(in srgb, var(--color-foreground) 35%, transparent);
  }

  .cart-page__continue {
    display: inline-block;
    margin-top: 1rem;
    font-size: 0.8125rem;
    color: color-mix(in srgb, var(--color-foreground) 62%, transparent);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color 0.2s ease, border-color 0.2s ease;
  }

  .cart-page__continue:hover {
    color: var(--color-text-bold);
    border-bottom-color: currentColor;
  }

  .cart-page__dynamic-checkout {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
  }

  .cart-page__empty {
    max-width: 26rem;
    margin: 2rem auto 0;
    text-align: center;
  }

  .cart-page__empty-title {
    margin: 0 0 0.5rem;
    font-family: var(--font-primary--family);
    font-size: 1.25rem;
    color: var(--color-text-bold);
  }

  .cart-page__empty-text {
    margin: 0 0 1.5rem;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: color-mix(in srgb, var(--color-foreground) 62%, transparent);
  }

  .cart-page__empty-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: 0.85rem 1.75rem;
    border-radius: 8px;
    border: 1px solid var(--color-button-border);
    background: var(--color-button-bg);
    color: var(--color-button-text);
    font-size: var(--font-size-base);
    text-decoration: none;
    transition: opacity 0.2s ease;
  }

  .cart-page__empty-btn:hover {
    opacity: 0.92;
  }

  @media (max-width: 599px) {
    .cart-page__item {
      grid-template-columns: 5.5rem minmax(0, 1fr);
      gap: 0.85rem 1rem;
    }

    .cart-page__item-footer {
      flex-wrap: wrap;
    }

    .cart-page__item-prices {
      width: 100%;
      flex-direction: row;
      align-items: center;
      justify-content: flex-start;
      gap: 0.5rem;
      text-align: left;
    }

    .cart-page__summary-card {
      position: static;
    }
  }
/* END_SECTION:cart */

/* START_SECTION:collection (INDEX:6) */
.collection-listing {
    width: min(100%, var(--page-width));
    max-width: var(--page-width);
    margin: 0 auto;
    padding: 2rem var(--page-margin) 3rem;
    box-sizing: border-box;
  }

  .collection-listing__header {
    margin-bottom: 1.25rem;
  }

  .collection-listing__title {
    margin: 0;
    font-family: var(--font-primary--family);
    font-size: clamp(1.75rem, 4vw, 2.5rem);
    line-height: 1.1;
  }

  .collection-listing__count {
    margin: 0.45rem 0 0;
    font-size: 0.84rem;
    color: color-mix(in srgb, var(--color-foreground) 62%, transparent);
  }

  .collection-listing__bar {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--color-background);
    border-top: 1px solid #e5e5e5;
    border-bottom: 1px solid #e5e5e5;
    border-radius: 0;
    padding: 0.62rem 0.75rem;
    margin-bottom: 1.3rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.65rem;
    width: 100%;
    box-sizing: border-box;
    flex-wrap: wrap;
  }

  .collection-listing__inline-filters {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    flex-wrap: wrap;
    min-width: 0;
  }

  .collection-listing__inline-filter {
    display: block;
    font-size: 0.78rem;
  }

  .collection-listing__inline-label { display: none; }

  .collection-listing__inline-filter select,
  .collection-listing__sort-label select {
    border: 1px solid #d8d8d8;
    background: var(--color-background);
    border-radius: 7px;
    padding: 0.43rem 0.62rem;
    font-size: 0.87rem;
    min-height: 2.05rem;
    color: #2d2d2d;
    max-width: 100%;
  }

  .collection-listing__actions {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-left: auto;
    min-width: 0;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .collection-listing__sort-label {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    font-size: 0.87rem;
    font-weight: 500;
    border: 1px solid #d8d8d8;
    border-radius: 7px;
    padding: 0.43rem 0.65rem;
    min-height: 2.05rem;
    background: var(--color-background);
  }

  .collection-listing__sort-icon,
  .collection-listing__filters-icon {
    font-size: 0.84rem;
    color: #555;
    line-height: 1;
  }

  .collection-listing__sort-label select {
    border: 0;
    padding: 0;
    min-height: auto;
    background: transparent;
    font-size: 0.87rem;
  }

  .collection-listing__all-filters {
    border: 1px solid #d8d8d8;
    background: var(--color-background);
    border-radius: 7px;
    padding: 0.43rem 0.68rem;
    font-size: 0.87rem;
    min-height: 2.05rem;
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    cursor: pointer;
  }

  .collection-listing__active-count {
    width: 1.05rem;
    height: 1.05rem;
    border-radius: 999px;
    background: var(--color-foreground);
    color: var(--color-background);
    font-size: 0.63rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
  }

  .collection-listing__drawer[hidden] {
    display: none;
  }

  .collection-listing__drawer {
    position: fixed;
    inset: 0;
    z-index: 40;
  }

  .collection-listing__drawer-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.34);
    border: 0;
    width: 100%;
    padding: 0;
  }

  .collection-listing__drawer-panel {
    position: absolute;
    right: 0;
    top: 0;
    width: min(92vw, 24rem);
    height: 100%;
    background: var(--color-background);
    border-left: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    display: flex;
    flex-direction: column;
  }

  .collection-listing__drawer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.95rem 1rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
  }

  .collection-listing__drawer-head h2 {
    margin: 0;
    font-size: 1rem;
  }

  .collection-listing__drawer-head button {
    border: 0;
    background: transparent;
    font-size: 1.35rem;
    cursor: pointer;
    line-height: 1;
  }

  .collection-listing__drawer-form {
    padding: 0.65rem 1rem 1rem;
    overflow: auto;
  }

  .collection-listing__filter-block {
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 9%, transparent);
    padding: 0.5rem 0;
  }

  .collection-listing__filter-block summary {
    cursor: pointer;
    font-size: 0.88rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .collection-listing__filter-body {
    margin-top: 0.45rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
  }

  .collection-listing__filter-body label {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    font-size: 0.8rem;
  }

  .collection-listing__filter-body input[type='number'] {
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    border-radius: 8px;
    padding: 0.45rem 0.55rem;
  }

  .collection-listing__check {
    display: grid !important;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 0.45rem;
  }

  .collection-listing__muted {
    color: color-mix(in srgb, var(--color-foreground) 58%, transparent);
    font-size: 0.74rem;
  }

  .collection-listing__drawer-actions {
    position: sticky;
    bottom: 0;
    background: var(--color-background);
    padding-top: 0.6rem;
  }

  .collection-listing__drawer-actions button {
    width: 100%;
    border: 0;
    background: var(--color-foreground);
    color: var(--color-background);
    border-radius: 8px;
    min-height: 2.5rem;
    font-weight: 600;
  }

  .collection-listing__grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;
  }

  @media screen and (min-width: 580px) {
    .collection-listing__grid {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }

  @media screen and (min-width: 980px) {
    .collection-listing__grid {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }

  .collection-listing__pagination {
    margin-top: 1.15rem;
  }

  .collection-listing__pagination .pagination {
    justify-content: center;
  }

  .collection-listing :where(button, select, input, a):focus-visible {
    outline: 2px solid color-mix(in srgb, var(--color-foreground) 60%, transparent);
    outline-offset: 2px;
  }

  @media screen and (max-width: 749px) {
    .collection-listing__inline-filters {
      display: none;
    }

    .collection-listing__bar {
      top: 0.25rem;
    }
  }
/* END_SECTION:collection */

/* START_SECTION:collections (INDEX:7) */
.collections {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(var(--collection-card-size), 100%), 1fr));
    gap: var(--grid-gap);
  }
  .collections--compact {
    --collection-card-size: 160px;
  }
  .collections--full {
    --collection-card-size: 280px;
  }
  .collection-card {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
/* END_SECTION:collections */

/* START_SECTION:feature-cards (INDEX:9) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;700&display=swap');

  .features-section {
    padding: var(--features-padding-y, 48px) var(--features-padding-x, 24px);
    background: transparent;
  }

  .features-section__header {
    max-width: 1400px;
    margin: 0 auto clamp(1.5rem, 3vw, 2.5rem);
    padding-inline: var(--page-margin);
  }

  .features-section__heading {
    margin: 0 0 0.5rem;
    font-family: var(--font-primary--family);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 700;
    line-height: 1.2;
    color: #0f172a;
  }

  .features-section__subheading {
    margin: 0;
    font-family: 'Inter', var(--font-body--family), ui-sans-serif, system-ui, sans-serif;
    font-size: 1.0625rem;
    line-height: 1.5;
    color: #64748b;
  }

  .features-section__empty {
    margin: 0;
    text-align: center;
    color: #64748b;
    font-size: 0.9375rem;
  }

  .features-grid {
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--features-gap, 16px);
  }

  .feature-card {
    text-align: center;
    position: relative;
    max-width: 11.5rem;
    margin-inline: auto;
    width: 100%;
  }

  .feature-image-wrapper {
    border-radius: 14px;
    overflow: hidden;
    background: #f8fafc;
    aspect-ratio: 3 / 4;
  }

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

  .feature-image-wrapper__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 100%;
    background: #f8fafc;
  }

  .feature-image-wrapper__placeholder svg {
    width: 40%;
    height: auto;
    opacity: 0.4;
  }

  .feature-icon {
    width: 48px;
    height: 48px;
    background: #ffffff;
    border-radius: 50%;
    margin: -24px auto 0;
    position: relative;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 21px;
    line-height: 1;
    box-shadow:
      0 5px 15px rgba(15, 23, 42, 0.08),
      0 1px 5px rgba(15, 23, 42, 0.04);
    border: 1px solid #e5e7eb;
  }

  .feature-content {
    padding-top: 14px;
  }

  .feature-content h3 {
    font-size: 15px;
    line-height: 1.25;
    font-weight: 700;
    color: #283455;
    margin: 0 0 8px;
    letter-spacing: -0.3px;
    font-family: 'Inter', var(--font-primary--family), ui-sans-serif, system-ui, sans-serif;
  }

  .feature-content p {
    font-size: 13px;
    line-height: 1.6;
    color: #283455;
    margin: 0;
    font-weight: 400;
    font-family: 'Inter', var(--font-body--family), ui-sans-serif, system-ui, sans-serif;
  }

  @media screen and (max-width: 1100px) {
    .features-grid {
      grid-template-columns: repeat(2, 1fr);
    }
  }

  @media screen and (max-width: 768px) {
    .features-section {
      padding: calc(var(--features-padding-y, 40px) * 0.75) 20px;
    }

    .features-grid {
      grid-template-columns: repeat(2, 1fr);
      max-width: 22rem;
      gap: max(var(--features-gap, 16px), 24px);
    }

    .feature-card {
      max-width: 10rem;
    }

    .feature-content h3 {
      font-size: 14px;
    }

    .feature-content p {
      font-size: 12px;
    }

    .feature-icon {
      width: 40px;
      height: 40px;
      margin-top: -20px;
      font-size: 17px;
    }
  }
/* END_SECTION:feature-cards */

/* START_SECTION:footer (INDEX:10) */
.site-footer {
    width: 100%;
    box-sizing: border-box;
    background: var(--footer-bg, #f7f3ed);
    color: #102033;
    padding: 64px max(40px, var(--page-margin)) 28px;
    font-family: Arial, Helvetica, sans-serif;
    margin-top: clamp(2rem, 5vw, 3.5rem);
  }

  .footer-container {
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: 80px;
  }

  .footer-links {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 48px;
  }

  .footer-column--dropdown {
    border: 0;
    margin: 0;
    padding: 0;
  }

  .footer-column__summary {
    display: none;
    list-style: none;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0;
    font-size: 15px;
    font-weight: 700;
    color: #0f1f33;
  }

  .footer-column__summary::-webkit-details-marker {
    display: none;
  }

  .footer-column__chevron {
    flex-shrink: 0;
    width: 0.55rem;
    height: 0.55rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    transform: rotate(45deg);
    transition: transform 0.2s ease;
    margin-top: -0.2rem;
  }

  .footer-column--dropdown[open] .footer-column__chevron {
    transform: rotate(-135deg);
    margin-top: 0.15rem;
  }

  .footer-column__heading {
    font-size: 15px;
    font-weight: 700;
    margin: 0 0 20px;
    color: #0f1f33;
  }

  .footer-column a {
    display: block;
    color: #26384d;
    text-decoration: none;
    font-size: 15px;
    margin-bottom: 14px;
  }

  .footer-column a:hover,
  .footer-column a:focus-visible {
    text-decoration: underline;
  }

  .footer-column__html {
    font-size: 15px;
    line-height: 1.5;
    color: #26384d;
  }

  .footer-column__html a {
    display: block;
    color: #26384d;
    text-decoration: none;
    margin-bottom: 14px;
  }

  .footer-column__html a:hover {
    text-decoration: underline;
  }

  .footer-newsletter h3 {
    font-size: 30px;
    line-height: 1.2;
    margin: 0 0 12px;
    color: #0f1f33;
  }

  .footer-newsletter p {
    font-size: 16px;
    line-height: 1.6;
    color: #405065;
    margin: 0 0 22px;
  }

  .newsletter-form {
    margin-bottom: 0;
  }

  .newsletter-form__row {
    display: flex;
    border-bottom: 1px solid #102033;
    margin-bottom: 18px;
  }

  .newsletter-form input[type='email'] {
    flex: 1;
    min-width: 0;
    border: 0;
    background: transparent;
    padding: 14px 0;
    font-size: 16px;
    outline: none;
    color: #102033;
    font-family: inherit;
  }

  .newsletter-form input[type='email']::placeholder {
    color: #405065;
    opacity: 0.85;
  }

  .newsletter-form button {
    border: 0;
    background: transparent;
    color: #102033;
    font-weight: 700;
    cursor: pointer;
    padding-left: 20px;
    font-family: inherit;
    font-size: 16px;
    white-space: nowrap;
  }

  .newsletter-form button:hover,
  .newsletter-form button:focus-visible {
    text-decoration: underline;
  }

  .newsletter-check {
    display: flex;
    gap: 10px;
    align-items: flex-start;
    font-size: 12px;
    line-height: 1.5;
    color: #405065;
    cursor: pointer;
  }

  .newsletter-check input {
    margin-top: 0.2rem;
    flex-shrink: 0;
  }

  .footer-newsletter__message {
    margin: 0 0 12px;
    font-size: 14px;
    line-height: 1.5;
  }

  .footer-newsletter__message--success {
    color: #0f1f33;
  }

  .footer-newsletter__message--error {
    color: #b42318;
  }

  .footer-bottom__payments {
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-start;
    min-width: 0;
  }

  .footer-bottom__payment-list {
    justify-content: center;
  }

  .footer-bottom__meta {
    margin: 0;
    flex: 1 1 auto;
    text-align: center;
    color: #405065;
  }

  .payment-icons {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .payment-icons__item {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .payment-icons__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    min-width: 3.25rem;
    height: 2.25rem;
    padding: 0.25rem 0.5rem;
    border: 1px solid rgba(16, 32, 51, 0.14);
    border-radius: 6px;
    background: #fff;
  }

  .payment-icons__img {
    display: block;
    width: auto;
    height: auto;
    max-height: 1.75rem;
    max-width: 4.5rem;
    object-fit: contain;
  }

  .footer-bottom {
    max-width: 1280px;
    margin: 56px auto 0;
    padding-top: 24px;
    border-top: 1px solid rgba(16, 32, 51, 0.18);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    font-size: 13px;
  }

  .footer-legal,
  .footer-social {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
  }

  .footer-bottom a {
    color: #26384d;
    text-decoration: none;
  }

  .footer-bottom a:hover,
  .footer-bottom a:focus-visible {
    text-decoration: underline;
  }

  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  @media screen and (min-width: 901px) {
    .footer-column--dropdown {
      display: block;
    }

    .footer-column__summary {
      display: none !important;
      pointer-events: none;
    }

    .footer-column__heading {
      display: block;
    }

    .footer-column--dropdown > .footer-column__panel,
    .footer-column--dropdown:not([open]) > .footer-column__panel {
      display: block !important;
    }
  }

  @media screen and (max-width: 900px) {
    .site-footer {
      padding: 48px max(20px, var(--page-margin)) 24px;
    }

    .footer-container {
      grid-template-columns: 1fr;
      gap: 48px;
    }

    .footer-links {
      display: flex;
      flex-direction: column;
      gap: 0;
      border-top: 1px solid rgba(16, 32, 51, 0.14);
    }

    .footer-column--dropdown {
      border-bottom: 1px solid rgba(16, 32, 51, 0.14);
    }

    .footer-column__summary {
      display: flex;
      min-height: 3.25rem;
      padding: 0.85rem 0;
    }

    .footer-column__heading {
      display: none;
    }

    .footer-column__panel {
      padding-bottom: 1rem;
    }

    .footer-column a {
      margin-bottom: 12px;
    }

    .footer-column a:last-child {
      margin-bottom: 0;
    }

    .footer-bottom {
      flex-direction: column;
      align-items: flex-start;
    }

    .footer-legal,
    .footer-social {
      flex-wrap: wrap;
    }
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:11) */
.header {
    --icon-stroke-width: 1.25px;
  }

  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .header-spacer {
    display: block;
    height: var(--header-height, 4rem);
    pointer-events: none;
    transition: height 0.28s ease;
  }

  @media (prefers-reduced-motion: reduce) {
    .header-spacer {
      transition: none;
    }
  }

  .header {
    position: fixed;
    top: var(--header-fixed-top, 0);
    left: 0;
    right: 0;
    z-index: 20;
    background-color: var(--color-background);
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    transition: transform 0.28s ease;
    will-change: transform;
  }

  .header.header--scroll-hidden {
    transform: translateY(calc(-100% - var(--header-fixed-top, 0px)));
    pointer-events: none;
  }

  @media (prefers-reduced-motion: reduce) {
    .header {
      transition: none;
    }
  }

  .header__inner {
    max-width: var(--page-width);
    margin-inline: auto;
    padding-block: 0.75rem;
    padding-inline: var(--page-margin);
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 0.75rem;
  }

  .header__menu-toggle {
    flex: 0 0 auto;
  }

  /* Hide hamburger whenever primary nav is shown (desktop layout). */
  @media screen and (min-width: 990px) {
    .header__menu-toggle {
      display: none !important;
    }
  }

  .header__menu-icon {
    display: block;
    width: 1.25rem;
    height: 2px;
    background: currentcolor;
    position: relative;
    border-radius: 1px;
  }

  .header__menu-icon::before,
  .header__menu-icon::after {
    content: '';
    position: absolute;
    left: 0;
    width: 1.25rem;
    height: 2px;
    background: currentcolor;
    border-radius: 1px;
  }

  .header__menu-icon::before {
    top: -6px;
  }

  .header__menu-icon::after {
    top: 6px;
  }

  .header__logo {
    flex: 1 1 auto;
    display: flex;
    justify-content: center;
    text-align: center;
    min-width: 0;
  }

  @media screen and (min-width: 990px) {
    .header__logo {
      flex: 0 0 auto;
      justify-content: flex-start;
      text-align: start;
    }
  }

  .header__logo-link,
  .header__logo-text {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: var(--color-text-bold);
    font-family: var(--font-heading--family);
    font-weight: normal;
    letter-spacing: 0.02em;
    font-size: 1.125rem;
  }

  .header__logo-image {
    width: auto;
    height: auto;
    max-height: 2.25rem;
    max-width: min(200px, 40vw);
    object-fit: contain;
  }

  .header__nav--desktop {
    display: none;
  }

  @media screen and (min-width: 990px) {
    .header__nav--desktop {
      display: block;
      flex: 1 1 auto;
      padding-inline: 1rem;
    }
  }

  .header-menu__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.25rem 1.25rem;
  }

  .header__nav--desktop .header-menu__item {
    position: relative;
  }

  .header__nav--desktop .header-menu__link {
    display: inline-block;
    padding: 0.5rem 0.25rem;
    text-decoration: none;
    color: var(--color-text-regular);
    font-family: var(--font-nav--family);
    font-size: var(--font-size-nav);
    font-weight: normal;
    white-space: nowrap;
  }

  .header__nav--desktop .header-menu__item--parent > .header-menu__list {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 12rem;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 0.5rem 0;
    background: var(--color-background);
    border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    border-radius: var(--style-border-radius-inputs, 4px);
    box-shadow: 0 8px 24px color-mix(in srgb, var(--color-foreground) 8%, transparent);
    opacity: 0;
    visibility: hidden;
    transform: translateY(0.35rem);
    transition:
      opacity 0.15s ease,
      visibility 0.15s ease,
      transform 0.15s ease;
    z-index: 30;
  }

  .header__nav--desktop .header-menu__list .header-menu__item--parent > .header-menu__list {
    left: 100%;
    top: 0;
    margin-left: 0.25rem;
  }

  .header__nav--desktop .header-menu__item--parent:hover > .header-menu__list,
  .header__nav--desktop .header-menu__item--parent:focus-within > .header-menu__list {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  .header__nav--desktop .header-menu__list .header-menu__link {
    padding: 0.4rem 0.75rem;
    white-space: normal;
  }

  .header__nav--drawer .header-menu__list {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }

  .header__nav--drawer .header-menu__link {
    display: block;
    padding: 0.65rem 0;
    text-decoration: none;
    color: var(--color-text-regular);
    font-family: var(--font-nav--family);
    font-size: var(--font-size-nav);
    font-weight: normal;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 8%, transparent);
  }

  .header__nav--drawer .header-menu__item--parent > .header-menu__list {
    position: static;
    opacity: 1;
    visibility: visible;
    transform: none;
    border: none;
    box-shadow: none;
    padding: 0 0 0.5rem 1rem;
    margin: 0;
  }

  .header__actions {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    flex: 0 0 auto;
    margin-inline-start: auto;
  }

  .header__icon-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--color-foreground);
    cursor: pointer;
    text-decoration: none;
    border-radius: var(--style-border-radius-inputs, 4px);
  }

  .header__icon-btn:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .header__icon {
    display: flex;
    width: 1.35rem;
    height: 1.35rem;
  }

  .header__icon svg {
    width: 100%;
    height: 100%;
  }

  .header__account {
    display: inline-flex;
    align-items: center;
  }

  .header__account .header__icon--account {
    width: 1.35rem;
    height: 1.35rem;
  }

  .header__cart {
    position: relative;
  }

  .header__cart-badge {
    position: absolute;
    top: 0.2rem;
    right: 0.15rem;
    min-width: 1.125rem;
    height: 1.125rem;
    padding: 0 0.3rem;
    border-radius: 999px;
    font-size: 0.625rem;
    font-weight: 700;
    line-height: 1.125rem;
    text-align: center;
    letter-spacing: 0;
    color: var(--color-background);
    background: var(--color-foreground);
    box-shadow: 0 0 0 2px var(--color-background);
    pointer-events: none;
  }

  .header__dialog {
    width: min(100vw - 2rem, 36rem);
    max-height: min(90vh, 32rem);
    margin: auto;
    padding: 0;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-radius: var(--style-border-radius-inputs, 6px);
    background: var(--color-background);
    color: var(--color-foreground);
    box-shadow: 0 16px 48px color-mix(in srgb, var(--color-foreground) 18%, transparent);
  }

  .header__dialog::backdrop {
    background: color-mix(in srgb, var(--color-foreground) 35%, transparent);
  }

  /*
    Mobile + tablet: menu is a left edge sheet (not a floating centered card).
    Native dialog is fixed to the start edge, full viewport height.
  */
  .header__dialog--menu {
    position: fixed;
    inset-block: 0;
    inset-inline-start: 0;
    inset-inline-end: auto;
    width: min(22rem, 100vw);
    max-width: 100%;
    height: 100vh;
    height: 100dvh;
    max-height: none;
    margin: 0;
    border-radius: 0;
    border-width: 0;
    border-inline-end: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-inline-start: none;
    box-shadow: 0.35rem 0 1.5rem color-mix(in srgb, var(--color-foreground) 14%, transparent);
  }

  .header__dialog-panel {
    padding: 1rem 1.25rem 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }

  .header__dialog-panel--menu {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    padding-block-end: max(1.25rem, env(safe-area-inset-bottom, 0px));
    padding-inline-start: max(1.25rem, env(safe-area-inset-left, 0px));
    padding-inline-end: 1.25rem;
    padding-block-start: max(1rem, env(safe-area-inset-top, 0px));
  }

  .header__dialog--menu .header__dialog-head {
    flex-shrink: 0;
  }

  .header__dialog-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }

  .header__dialog-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin: 0;
  }

  .header__dialog-close {
    border: none;
    background: transparent;
    color: inherit;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    padding: 0.25rem 0.5rem;
    border-radius: var(--style-border-radius-inputs, 4px);
  }

  .header__search-form {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }

  .header__search-input {
    flex: 1 1 12rem;
    min-width: 0;
    padding: 0.65rem 0.75rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 20%, transparent);
  }

  .header__search-submit {
    padding: 0.65rem 1rem;
    border-radius: var(--style-border-radius-inputs, 4px);
    font-weight: normal;
  }

  .header__menu-empty {
    margin: 0;
    font-size: 0.9375rem;
    color: color-mix(in srgb, var(--color-foreground) 75%, transparent);
  }
/* END_SECTION:header */

/* START_SECTION:hello-world (INDEX:12) */
.welcome {
    display: grid;
    grid-template-columns: var(--content-grid);
    background-color: #f6f6f7;
    padding: 72px 0;
  }

  .welcome-content {
    grid-column: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    width: 100%;
    padding: 0 24px;
  }

  .welcome-description {
    max-width: 80ch;
    line-height: 1.4;
    margin-top: 1.5rem;
  }

  .icon {
    width: 300px;
  }

  .highlights {
    display: grid;
    gap: 2rem;
    grid-template-columns: repeat(3, 1fr);
    margin-top: 50px;
  }

  @media (max-width: 1100px) {
    .highlights {
      grid-template-columns: 1fr;
    }
  }

  .highlight {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 24px;
    border-radius: 8px;
    background-color: #eef3ff;
    color: rgb(92, 95, 98);
    line-height: 1.4;
  }

  .highlight > * + * {
    margin-top: 1rem;
  }

  .highlight h3 {
    font-size: 1rem;
    color: rgb(32, 34, 35);
  }

  .highlight-description {
    flex: 1 1;
  }

  .highlight a {
    display: flex;
    width: fit-content;
    background-color: rgb(250, 251, 251);
    box-shadow: rgba(0, 0, 0, 0.2) 0px -3px 0px 0px inset, rgba(255, 255, 255, 0.9) 0px 2px 0px 0px inset;
    border: 1px solid rgb(140, 145, 150);
    border-radius: 4px;
    color: rgb(92, 95, 98);
    padding: 3px 10px 5px;
    text-decoration: none;
  }
/* END_SECTION:hello-world */

/* START_SECTION:product (INDEX:15) */
.product-detail {
    --product-detail-sticky-top: 5.25rem;
    width: 100%;
    max-width: min(100%, var(--page-width));
    margin: 0 auto;
    padding: 2rem var(--page-margin) 3rem;
    box-sizing: border-box;
    overflow-x: clip;
  }

  .product-detail__breadcrumb {
    margin-bottom: 1rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
    font-size: 0.8125rem;
    color: color-mix(in srgb, var(--color-foreground) 65%, transparent);
  }

  .product-detail__breadcrumb a {
    color: inherit;
    text-decoration: none;
  }

  .product-detail__layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 1.5rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .product-detail__media-col,
  .product-detail__media,
  .product-detail__info--panel,
  .product-detail__form,
  .product-detail__gallery,
  .product-detail__gallery-main {
    min-width: 0;
    max-width: 100%;
  }

  @media screen and (min-width: 900px) {
    .product-detail__layout {
      grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
      gap: 3rem;
      align-items: stretch;
    }

    /*
      Stretch the media column to match the info column height so position:sticky
      keeps the gallery pinned while the right column (title → tabs) scrolls.
    */
    .product-detail__media-col {
      align-self: stretch;
      min-height: 0;
    }

    .product-detail__media--sticky {
      position: sticky;
      top: var(--product-detail-sticky-top);
      z-index: 1;
    }
  }

  .product-detail__info--panel {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
  }

  .product-detail__header {
    margin: 0;
  }

  .product-detail__vendor {
    margin: 0.35rem 0 0;
    font-size: 0.8125rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: color-mix(in srgb, var(--color-foreground) 55%, transparent);
  }

  .product-detail__price-panel {
    padding: 1rem 0;
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .product-detail__price-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 0.75rem;
  }

  .product-detail__price-current {
    display: inline-block;
    margin: 0 0.375rem 0 0;
    line-height: normal;
  }

  .product-detail__price-current .money {
    display: inline-block;
    font-family: var(--font-heading--family);
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: -0.01rem;
    line-height: normal;
    color: #283455;
    margin: 0;
  }

  .product-detail__price-compare-wrap[hidden],
  .product-detail__price-badge[hidden],
  .product-detail__price-savings[hidden] {
    display: none !important;
  }

  .product-detail__price-compare {
    font-family: var(--font-body--family);
    font-size: 16px;
    font-weight: 400;
    text-decoration: line-through;
    color: #6e6e6e;
    margin-right: 0.375rem;
  }

  .product-detail__price-compare .money {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
  }

  .product-detail__price-badge {
    display: inline-block;
    background: #eff0ed;
    color: #417823;
    padding: 0.1875rem 0.5rem 0.125rem;
    border-radius: 0.375rem;
    margin: 0 0.375rem 0.375rem 0;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: normal;
  }

  .product-detail__price-savings {
    margin: 0.375rem 0 0;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: normal;
    color: #417823;
  }

  .product-detail__buy-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.65rem;
    align-items: stretch;
    width: 100%;
    min-width: 0;
  }

  .product-detail__qty-stepper {
    display: flex;
    align-items: center;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 20%, transparent);
    border-radius: 8px;
    overflow: hidden;
    background: var(--color-background);
    flex-shrink: 0;
  }

  .product-detail__qty-btn {
    width: 2.75rem;
    height: 2.75rem;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-size: 1.125rem;
    line-height: 1;
    color: color-mix(in srgb, var(--color-foreground) 70%, transparent);
  }

  .product-detail__qty-btn:hover {
    background: color-mix(in srgb, var(--color-foreground) 6%, transparent);
  }

  .product-detail__qty-value {
    min-width: 2rem;
    text-align: center;
    font-size: 0.875rem;
    font-weight: 600;
  }

  .product-detail__purchase-actions {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    margin-bottom: 1rem;
  }

  .product-detail__form .shopify-payment-button {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .product-detail__form .shopify-payment-button__button,
  .product-detail__form .shopify-payment-button__button--unbranded {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.75rem 1.25rem;
    border-radius: 8px;
    border: 0.0625rem solid #1990c6;
    background-color: #1990c6;
    color: #fff;
    font-family: var(--font-body--family);
    font-size: var(--font-size-base);
    font-weight: normal;
    line-height: normal;
    cursor: pointer;
    transition: opacity 0.2s ease;
    box-shadow: none;
  }

  .product-detail__form .shopify-payment-button__button:hover:not(:disabled),
  .product-detail__form .shopify-payment-button__button--unbranded:hover:not(:disabled) {
    opacity: 0.92;
    background-color: #1990c6;
  }

  .product-detail__accordion--card + .product-detail__accordion--card {
    margin-top: 0.65rem;
  }

  .product-detail__accordion--card .product-detail__accordion-summary {
    padding: 1rem 0;
  }

  .product-detail__accordion--card .product-detail__accordion-body {
    padding: 1rem 0;
    border: 0;
  }

  .product-detail__accordions {
    padding-top: 0.5rem;
  }

  .product-detail__gallery {
    display: flex;
    align-items: flex-start;
    gap: 0.65rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .product-detail__thumbs-rail {
    flex: 0 0 4rem;
    width: 4rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.4rem;
    min-height: 0;
    align-self: flex-start;
    max-height: 100%;
  }

  .product-detail__thumbs-viewport {
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    min-width: 0;
    overflow: hidden;
  }

  .product-detail__thumbs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0.5rem;
    width: 4rem;
    will-change: transform;
    transition: transform 0.28s cubic-bezier(0.33, 1, 0.68, 1);
  }

  .product-detail__thumbs li {
    flex: 0 0 4rem;
    width: 4rem;
    height: 4rem;
    max-height: 4rem;
    display: flex;
  }

  .product-detail__thumb {
    border: 0.125rem solid transparent;
    border-radius: 0.125rem;
    transition: border-color 0.25s cubic-bezier(0.33, 1, 0.68, 1);
    aspect-ratio: 4 / 4;
    overflow: hidden;
    cursor: pointer;
    width: 100%;
    max-width: 4rem;
    padding: 0;
    background: var(--color-background);
    display: block;
  }

  .product-detail__thumb[aria-current='true'] {
    border-color: #283455;
    box-shadow: none;
  }

  .product-detail__thumb-image {
    width: 100%;
    height: 100%;
    aspect-ratio: 4 / 4;
    object-fit: cover;
    display: block;
  }

  .product-detail__gallery-main {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
  }

  .product-detail__carousel-main {
    position: relative;
    flex: 1 1 auto;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-radius: 7px;
    overflow: hidden;
    background: linear-gradient(
      135deg,
      var(--color-background) 0%,
      color-mix(in srgb, var(--color-foreground) 4%, var(--color-background)) 100%
    );
  }

  .product-detail__slide {
    aspect-ratio: 4 / 4;
  }

  .product-detail__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }

  .product-detail__carousel-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.2rem;
    height: 2.2rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 16%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-background) 92%, transparent);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
  }

  .product-detail__carousel-nav--prev {
    left: 0.55rem;
  }

  .product-detail__carousel-nav--next {
    right: 0.55rem;
  }

  .product-detail__carousel-nav span,
  .product-detail__thumbs-nav span {
    width: 0.48rem;
    height: 0.48rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .product-detail__carousel-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.12rem;
  }

  .product-detail__carousel-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.12rem;
  }

  .product-detail__dots {
    margin-top: 0.55rem;
    display: flex;
    justify-content: center;
    gap: 0.35rem;
  }

  .product-detail__dot {
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 999px;
    border: 0;
    background: color-mix(in srgb, var(--color-foreground) 24%, transparent);
    cursor: pointer;
    padding: 0;
  }

  .product-detail__dot[aria-current='true'] {
    background: #283455;
  }

  .product-detail__zoom-open {
    position: absolute;
    right: 0.65rem;
    bottom: 0.65rem;
    z-index: 3;
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid color-mix(in srgb, var(--color-background) 55%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-background) 62%, transparent);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    color: var(--color-foreground);
    cursor: pointer;
    box-shadow: 0 4px 18px color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .product-detail__zoom-open:hover {
    background: color-mix(in srgb, var(--color-background) 78%, transparent);
  }

  .product-detail__thumbs-nav {
    flex: 0 0 auto;
    width: 1.75rem;
    height: 1.75rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 16%, transparent);
    border-radius: 999px;
    background: var(--color-background);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .product-detail__thumbs-nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
  }

  .product-detail__thumbs-nav--prev span {
    transform: rotate(-135deg);
    margin-top: 0.12rem;
  }

  .product-detail__thumbs-nav--next span {
    transform: rotate(45deg);
    margin-bottom: 0.12rem;
  }

  .product-detail__dots--main {
    margin-top: 0.55rem;
    flex-shrink: 0;
  }

  @media screen and (max-width: 749px) {
    .product-detail {
      padding: 1rem var(--page-margin) 2rem;
    }

    .product-detail__title {
      overflow-wrap: anywhere;
    }

    .product-detail__variant-selector-buttons,
    .product-detail__product-colors-buttons {
      max-width: 100%;
    }
  }

  @media screen and (max-width: 599px) {
    .product-detail__gallery {
      flex-direction: column;
    }

    .product-detail__thumbs-rail {
      flex: 0 0 auto;
      width: 100%;
      max-width: 100%;
      flex-direction: row;
      order: 2;
      align-self: stretch;
      min-width: 0;
    }

    .product-detail__thumbs-viewport {
      flex: 1 1 auto;
      width: auto;
      min-width: 0;
      max-width: 100%;
      overflow-x: auto;
      overflow-y: hidden;
      -webkit-overflow-scrolling: touch;
    }

    .product-detail__thumbs {
      flex-direction: row;
      width: max-content;
      min-width: 0;
    }

    .product-detail__thumbs li {
      flex: 0 0 4rem;
      width: 4rem;
      height: 4rem;
      max-height: 4rem;
    }

    .product-detail__thumbs-nav--prev span {
      transform: rotate(135deg);
      margin-top: 0;
      margin-left: 0.12rem;
    }

    .product-detail__thumbs-nav--next span {
      transform: rotate(-45deg);
      margin-bottom: 0;
      margin-right: 0.12rem;
    }
  }

  .product-detail__lightbox {
    width: min(100%, 72rem);
    max-width: 100%;
    max-height: 100dvh;
    margin: auto;
    padding: 0;
    border: 0;
    background: transparent;
    overflow: visible;
  }

  .product-detail__lightbox::backdrop {
    background: color-mix(in srgb, var(--color-foreground) 55%, transparent);
    backdrop-filter: blur(6px);
  }

  .product-detail__lightbox-backdrop {
    position: fixed;
    inset: 0;
    z-index: -1;
  }

  .product-detail__lightbox-panel {
    position: relative;
    padding: 1.25rem;
    background: var(--color-background);
    border-radius: 10px;
    box-shadow: 0 24px 64px color-mix(in srgb, var(--color-foreground) 22%, transparent);
  }

  .product-detail__lightbox-close {
    position: absolute;
    top: 0.65rem;
    right: 0.65rem;
    z-index: 4;
    width: 2.25rem;
    height: 2.25rem;
    border: 0;
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-foreground) 8%, var(--color-background));
    cursor: pointer;
  }

  .product-detail__lightbox-close span {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
  }

  .product-detail__lightbox-close::before,
  .product-detail__lightbox-close::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0.95rem;
    height: 2px;
    background: currentcolor;
    transform-origin: center;
  }

  .product-detail__lightbox-close::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }

  .product-detail__lightbox-close::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }

  .product-detail__lightbox-carousel {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .product-detail__lightbox-slide {
    aspect-ratio: 4 / 4;
  }

  .product-detail__lightbox-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    background: color-mix(in srgb, var(--color-foreground) 4%, var(--color-background));
  }

  .product-detail__lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.4rem;
    height: 2.4rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 16%, transparent);
    border-radius: 999px;
    background: color-mix(in srgb, var(--color-background) 92%, transparent);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
  }

  .product-detail__lightbox-nav--prev {
    left: 0.75rem;
  }

  .product-detail__lightbox-nav--next {
    right: 0.75rem;
  }

  .product-detail__lightbox-nav span {
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .product-detail__lightbox-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.12rem;
  }

  .product-detail__lightbox-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.12rem;
  }

  .product-detail__dots--lightbox {
    margin-top: 0.75rem;
  }

  .product-detail__title {
    margin: 0 0 0.55rem;
    font-family: var(--font-heading--family);
    font-size: var(--font-size-product-title);
    font-weight: normal;
    color: var(--color-text-bold);
    line-height: 1.3;
  }

  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  .product-detail__pdp-price-wrap {
    margin: 0 0 1.1rem;
  }

  .product-detail__pdp-price-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem;
  }

  .product-detail__price-compare-row[hidden] {
    display: none !important;
  }

  .product-detail__pdp-price-final .money {
    display: inline-block;
    font-family: var(--font-heading--family);
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: -0.01rem;
    line-height: normal;
    color: #283455;
    margin: 0 0.375rem 0 0;
  }

  .product-detail__variant-groups {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
    margin-bottom: 1.25rem;
  }

  .product-detail__variant-heading {
    margin: 0 0 0.65rem;
    font-size: 0.875rem;
    font-weight: 400;
    line-height: 1.35;
  }

  .product-detail__variant-heading span {
    margin-right: 0.25rem;
  }

  .product-detail__variant-heading strong {
    font-family: var(--font-heading--family);
    font-weight: normal;
    color: var(--color-text-bold);
  }

  .product-detail__variant-selector-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
  }

  .product-detail__variant-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 2.75rem;
    min-height: 2.75rem;
    padding: 0.35rem 0.65rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 22%, transparent);
    border-radius: 4px;
    background: var(--color-background);
    cursor: pointer;
    transition:
      border-color 0.15s ease,
      box-shadow 0.15s ease;
  }

  .product-detail__variant-label:hover:not(.is-unavailable) {
    border-color: color-mix(in srgb, var(--color-foreground) 45%, transparent);
  }

  .product-detail__variant-selector-button-text {
    font-size: 0.875rem;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
  }

  .product-detail__variant-label.is-selected {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .product-detail__variant-label.is-unavailable {
    opacity: 0.38;
    cursor: not-allowed;
    text-decoration: line-through;
  }

  .product-detail__product-colors-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .product-detail__product-colors-button {
    display: block;
    width: 4.75rem;
    height: 4.75rem;
    padding: 2px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 22%, transparent);
    border-radius: 4px;
    cursor: pointer;
    transition:
      border-color 0.15s ease,
      box-shadow 0.15s ease;
    overflow: hidden;
    background: var(--color-background);
  }

  .product-detail__product-colors-button:hover:not(.is-unavailable) {
    border-color: color-mix(in srgb, var(--color-foreground) 45%, transparent);
  }

  .product-detail__product-colors-button.is-selected {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .product-detail__product-colors-button.is-unavailable {
    opacity: 0.38;
    cursor: not-allowed;
  }

  .product-detail__product-colors-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 2px;
  }

  .product-detail__color-dot-fallback {
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 2px;
    background: color-mix(in srgb, var(--color-foreground) 12%, var(--color-background));
    border: 1px dashed color-mix(in srgb, var(--color-foreground) 28%, transparent);
  }

  .product-detail__qty-row {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    margin-bottom: 1rem;
  }

  .product-detail__qty-label {
    font-size: 0.875rem;
    font-weight: 500;
  }

  .product-detail__qty-input {
    width: 4rem;
    padding: 0.45rem 0.5rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 22%, transparent);
    border-radius: 4px;
    font-size: 0.875rem;
    background: var(--color-background);
  }

  .product-detail__submit {
    flex: 1 1 12rem;
    min-width: 0;
    max-width: 100%;
    min-height: 2.75rem;
    padding: 0.75rem 1.25rem;
    border-radius: 8px;
    font-weight: normal;
    line-height: normal;
    transition: opacity 0.2s ease;
  }

  .product-detail__submit:hover:not(:disabled) {
    opacity: 0.92;
  }

  .product-detail__submit:disabled {
    opacity: 0.55;
    cursor: not-allowed;
  }

  .product-detail__form {
    margin-bottom: 1rem;
  }

  .product-detail__accordion {
    border: 0;
  }

  .product-detail__accordion-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 0;
    font-weight: 600;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    min-width: 0;
  }

  .product-detail__accordion-summary > span:first-child {
    flex: 1 1 auto;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .product-detail__accordion-summary::-webkit-details-marker {
    display: none;
  }

  .product-detail__accordion-icon {
    width: 0.65rem;
    height: 0.65rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    transform: rotate(45deg);
    transition: transform 0.2s ease;
    flex-shrink: 0;
  }

  .product-detail__accordion[open] .product-detail__accordion-icon {
    transform: rotate(-135deg);
  }

  .product-detail__accordion-body {
    padding: 1rem 0;
    border: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .product-detail__rte {
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .product-detail__rte :is(table, pre, iframe, video, embed) {
    display: block;
    max-width: 100%;
  }

  .product-detail__rte table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .product-detail__rte > *:first-child {
    margin-top: 0;
  }

  .product-detail__rte > *:last-child {
    margin-bottom: 0;
  }

  .product-content-tab__figure {
    margin: 0 0 1rem;
  }

  .product-content-tab__image {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: var(--style-border-radius-inputs, 6px);
  }

  .product-detail__rte img {
    display: block;
    max-width: 100%;
    width: auto;
    height: auto;
    margin: 1rem 0;
    border-radius: var(--style-border-radius-inputs, 6px);
  }

  .product-detail__rte img:first-child {
    margin-top: 0;
  }

  .product-detail__rte img:last-child {
    margin-bottom: 0;
  }

  .product-detail__rte figure {
    margin: 1rem 0;
    max-width: 100%;
  }

  .product-detail__rte figure img {
    margin: 0;
  }
/* END_SECTION:product */

/* START_SECTION:related-products (INDEX:16) */
.related-products {
    margin-top: clamp(2.5rem, 6vw, 4rem);
    padding-block: clamp(2rem, 5vw, 3rem);
    padding-inline: var(--page-margin);
    background: var(--color-background);
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    box-sizing: border-box;
    overflow-x: clip;
  }

  .related-products__inner {
    width: 100%;
    max-width: min(100%, var(--page-width));
    margin-inline: auto;
    min-width: 0;
  }

  .related-products__heading {
    margin: 0 0 clamp(1.25rem, 3vw, 2rem);
    color: #283455;
    font-family: 'Roboto', ui-sans-serif, system-ui, sans-serif;
    font-weight: 700;
    font-size: 1.75rem;
    line-height: 1.15;
    letter-spacing: -0.01em;
  }

  @media screen and (min-width: 500px) {
    .related-products__heading {
      font-size: 2.25rem;
    }
  }

  @media screen and (min-width: 769px) {
    .related-products__heading {
      font-size: 2.8125rem;
    }
  }

  @media screen and (min-width: 1025px) {
    .related-products__heading {
      font-size: 2.8125rem;
    }
  }

  .related-products__shell {
    display: flex;
    align-items: center;
    gap: 0.65rem;
  }

  .related-products__viewport {
    flex: 1 1 auto;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    container-type: inline-size;
  }

  .related-products__viewport::-webkit-scrollbar {
    display: none;
  }

  .related-products__track {
    display: flex;
    gap: 1rem;
    width: max-content;
    padding-block: 0.15rem;
  }

  .related-products__slide {
    flex: 0 0 clamp(14rem, 74cqw, 18rem);
    scroll-snap-align: start;
  }

  @container (min-width: 580px) {
    .related-products__slide {
      flex-basis: clamp(14rem, 45cqw, 18rem);
    }
  }

  @container (min-width: 990px) {
    .related-products__slide {
      flex-basis: clamp(14rem, 30cqw, 18rem);
    }
  }

  @container (min-width: 1200px) {
    .related-products__slide {
      flex-basis: clamp(14rem, 24cqw, 18rem);
    }
  }

  .related-products__nav {
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    background: var(--color-background);
    color: var(--color-foreground);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
  }

  @media screen and (min-width: 750px) {
    .related-products__nav {
      display: inline-flex;
    }
  }

  .related-products__nav-icon {
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .related-products__nav--prev .related-products__nav-icon {
    transform: rotate(135deg);
    margin-left: 0.12rem;
  }

  .related-products__nav--next .related-products__nav-icon {
    transform: rotate(-45deg);
    margin-right: 0.12rem;
  }

  .related-products__empty {
    margin: 0;
    font-size: 0.9375rem;
    color: color-mix(in srgb, var(--color-foreground) 65%, transparent);
  }
/* END_SECTION:related-products */

/* START_SECTION:search (INDEX:17) */
.listing { max-width: var(--page-width); margin: 0 auto; padding: 1.5rem var(--page-margin) 3rem; }
  .listing__title { margin: 0 0 1rem; font-size: clamp(1.5rem, 3vw, 2rem); font-family: var(--font-primary--family); }
  .listing__search-form { display: flex; gap: .5rem; margin-bottom: .8rem; }
  .listing__search-form input { flex: 1; border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent); border-radius: 8px; padding: .6rem .7rem; }
  .listing__search-form button { border: 0; border-radius: 8px; padding: .6rem .9rem; background: var(--color-foreground); color: var(--color-background); }
  .listing__bar { position: sticky; top: 0; z-index: 8; background: var(--color-background); border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent); border-radius: 10px; padding: .75rem; display: flex; gap: .75rem; justify-content: space-between; align-items: center; margin-bottom: 1.25rem; }
  .listing__inline-filters { display: flex; gap: .5rem; flex-wrap: wrap; }
  .listing__inline-filter { display: flex; gap: .35rem; align-items: center; font-size: .8125rem; }
  .listing__inline-filter select, .listing__sort select { border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent); background: var(--color-background); border-radius: 999px; padding: .38rem .65rem; font-size: .8125rem; }
  .listing__bar-actions { display: flex; align-items: center; gap: .55rem; }
  .listing__filters-toggle { border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent); background: color-mix(in srgb, var(--color-foreground) 6%, var(--color-background)); padding: .45rem .7rem; border-radius: 999px; font-size: .8125rem; cursor: pointer; }
  .listing__sort label { display: flex; align-items: center; gap: .35rem; font-size: .8125rem; }
  .listing__drawer[hidden] { display: none; }
  .listing__drawer { position: fixed; inset: 0; z-index: 25; }
  .listing__drawer-overlay { position: absolute; inset: 0; background: rgba(0,0,0,.3); }
  .listing__drawer-panel { position: absolute; left: 0; top: 0; bottom: 0; width: min(92vw, 24rem); background: var(--color-background); padding: 1rem; overflow: auto; }
  .listing__drawer-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: .75rem; }
  .listing__drawer-head h2 { margin: 0; font-size: 1rem; }
  .listing__drawer-head button { border: 0; background: transparent; font-size: 1.4rem; cursor: pointer; }
  .listing__filter-block { border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent); padding: .45rem 0; }
  .listing__filter-block summary { cursor: pointer; font-weight: 600; font-size: .875rem; }
  .listing__filter-body { margin-top: .45rem; display: flex; flex-direction: column; gap: .4rem; }
  .listing__check { display: flex; align-items: center; gap: .45rem; font-size: .8125rem; }
  .listing__drawer-actions { margin-top: .8rem; }
  .listing__drawer-actions button { width: 100%; border: 0; border-radius: 8px; padding: .62rem .8rem; background: var(--color-foreground); color: var(--color-background); }
  .listing__grid { display: grid; grid-template-columns: repeat(1, minmax(0,1fr)); gap: .9rem; }
  @media screen and (min-width: 640px) { .listing__grid { grid-template-columns: repeat(2, minmax(0,1fr)); } }
  @media screen and (min-width: 900px) { .listing__grid { grid-template-columns: repeat(4, minmax(0,1fr)); } }
  .listing__card { border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent); border-radius: 10px; padding: .45rem; background: color-mix(in srgb, var(--color-background) 98%, transparent); }
  .listing__card-media { position: relative; display: block; text-decoration: none; overflow: hidden; border-radius: 8px; border: 1px solid color-mix(in srgb, var(--color-foreground) 8%, transparent); background: color-mix(in srgb, var(--color-foreground) 5%, var(--color-background)); }
  .listing__card-media .image { aspect-ratio: 4 / 5; }
  .listing__card-media img { transition: transform .28s ease; }
  .listing__card:hover .listing__card-media img { transform: scale(1.02); }
  .listing__card-badge { position: absolute; top: .55rem; left: .55rem; z-index: 2; font-size: .68rem; letter-spacing: .04em; text-transform: uppercase; padding: .2rem .42rem; background: var(--color-background); border: 1px solid color-mix(in srgb, var(--color-foreground) 16%, transparent); border-radius: 999px; }
  .listing__card-body { padding: .62rem .35rem .25rem; border: 1px solid color-mix(in srgb, var(--color-foreground) 8%, transparent); border-radius: 8px; margin-top: .45rem; background: var(--color-background); }
  .listing__card-title { margin: 0 0 .36rem; font-size: .95rem; font-weight: 650; line-height: 1.35; }
  .listing__card-title a { color: inherit; text-decoration: none; }
  .listing__card-price { margin: 0; display: flex; gap: .45rem; align-items: baseline; font-size: .9rem; font-weight: 700; }
  .listing__card-price-old { font-size: .78rem; color: color-mix(in srgb, var(--color-foreground) 52%, transparent); text-decoration: line-through; font-weight: 500; }
  .listing__pagination { margin-top: 1rem; }
  @media screen and (max-width: 749px) { .listing__inline-filters { display: none; } .listing__bar { top: .25rem; } }
/* END_SECTION:search */

/* START_SECTION:showcase-tabs (INDEX:18) */
.showcase {
    max-width: var(--page-width);
    margin-inline: auto;
    padding-inline: var(--page-margin);
    padding-block: clamp(1.5rem, 4vw, 3rem);
    min-width: 0;
    width: 100%;
    box-sizing: border-box;
  }

  .showcase__top,
  .showcase__tabpanel {
    min-width: 0;
    max-width: 100%;
  }

  .showcase__tablist {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    margin-bottom: 1.25rem;
  }

  .showcase__tab {
    appearance: none;
    border: none;
    background: transparent;
    color: var(--color-foreground);
    font-family: var(--font-primary--family);
    font-size: 0.9375rem;
    font-weight: 600;
    padding: 0.65rem 1rem;
    margin-bottom: -1px;
    cursor: pointer;
    border-bottom: 2px solid transparent;
    border-radius: var(--style-border-radius-inputs, 4px) var(--style-border-radius-inputs, 4px) 0 0;
  }

  .showcase__tab[aria-selected='true'] {
    border-bottom-color: var(--color-foreground);
  }

  .showcase__tab:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__chips {
    display: flex;
    flex-wrap: nowrap;
    gap: 0.75rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    margin-bottom: 1.5rem;
    scroll-snap-type: x proximity;
  }

  .showcase__chip {
    flex: 0 0 auto;
    scroll-snap-align: start;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
    width: 5.5rem;
    padding: 0.35rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 15%, transparent);
    border-radius: var(--style-border-radius-inputs, 6px);
    background: var(--color-background);
    color: var(--color-foreground);
    cursor: pointer;
    text-align: center;
  }

  .showcase__chip:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__chip[aria-pressed='true'] {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .showcase__chip-img {
    width: 4.5rem;
    height: 4.5rem;
    object-fit: cover;
    border-radius: calc(var(--style-border-radius-inputs, 4px) - 2px);
  }

  .showcase__chip-title {
    font-size: 0.6875rem;
    line-height: 1.25;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .showcase__empty {
    margin: 0 0 1rem;
    font-size: 0.9375rem;
    color: color-mix(in srgb, var(--color-foreground) 65%, transparent);
  }

  .showcase__collections-wrap {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-bottom: 1.25rem;
    overflow: hidden;
  }

  .showcase__collections-carousel {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    position: relative;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .showcase__collections-viewport {
    flex: 1 1 0%;
    min-width: 0;
    overflow-x: hidden;
    overflow-y: hidden;
  }

  .showcase__collections-carousel--scrollable .showcase__collections-viewport {
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
  }

  .showcase__collections-carousel--scrollable .showcase__collections-viewport::-webkit-scrollbar {
    display: none;
  }

  .showcase__collections {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 0.75rem;
    margin: 0;
    padding-block: 0.1rem;
    padding-inline: 0;
    list-style: none;
  }

  .showcase__collections-carousel--scrollable .showcase__collections {
    flex-wrap: nowrap;
    width: max-content;
    max-width: none;
  }

  .showcase__collections .showcase__collection-card {
    flex: 0 0 auto;
    min-width: auto;
    max-width: none;
  }

  .showcase__collections-carousel--scrollable .showcase__collection-card {
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }

  .showcase__collections-nav {
    flex: 0 0 auto;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    background: var(--color-background);
    color: var(--color-foreground);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 0;
  }

  .showcase__collections-carousel--scrollable .showcase__collections-nav {
    display: inline-flex;
  }

  .showcase__collections-carousel--scrollable .showcase__collections-nav[hidden] {
    display: none;
  }

  .showcase__collections-nav span {
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .showcase__collections-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.12rem;
  }

  .showcase__collections-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.12rem;
  }

  .showcase__collections-nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
  }

  .showcase__collections-dots {
    display: none;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.65rem;
    padding: 0;
  }

  .showcase__collections-dots--active:not([hidden]) {
    display: flex;
  }

  .showcase__collections-dot {
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 999px;
    border: 0;
    padding: 0;
    background: color-mix(in srgb, var(--color-foreground) 24%, transparent);
    cursor: pointer;
  }

  .showcase__collections-dot[aria-current='true'] {
    background: var(--color-foreground);
  }

  .showcase__collections-dot:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__collection-card {
    display: flex;
    flex-direction: column;
    flex: 1 1 7.5rem;
    min-width: 7rem;
    max-width: 11rem;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-radius: var(--style-border-radius-inputs, 6px);
    background: var(--color-background);
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    text-align: left;
    padding: 0;
  }

  .showcase__collection-card:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__collection-card-title {
    padding: 0.4rem 0.5rem 0.55rem;
    font-size: 0.8125rem;
    font-weight: 600;
    line-height: 1.25;
  }

  .showcase__collection-card[aria-pressed='true'] {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .showcase__product-grid-wrap {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin-bottom: 1.25rem;
    overflow: hidden;
  }

  .showcase__product-grid-carousel {
    --showcase-products-visible: 2;
    --showcase-products-gap: 0.65rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  @media screen and (min-width: 600px) {
    .showcase__product-grid-carousel {
      --showcase-products-visible: 3;
    }
  }

  @media screen and (min-width: 900px) {
    .showcase__product-grid-carousel {
      --showcase-products-visible: 5;
    }
  }

  .showcase__product-grid-viewport {
    flex: 1 1 0%;
    min-width: 0;
    overflow-x: hidden;
    overflow-y: hidden;
    container-type: inline-size;
  }

  .showcase__product-grid-carousel--scrollable .showcase__product-grid-viewport {
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
  }

  .showcase__product-grid-carousel--scrollable .showcase__product-grid-viewport::-webkit-scrollbar {
    display: none;
  }

  .showcase__product-grid {
    display: grid;
    grid-template-columns: repeat(var(--showcase-products-visible), minmax(0, 1fr));
    gap: var(--showcase-products-gap);
    margin: 0;
    padding-block: 0.1rem;
    padding-inline: 0;
    width: 100%;
    list-style: none;
  }

  .showcase__product-grid-carousel--scrollable .showcase__product-grid {
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    width: max-content;
    max-width: none;
  }

  .showcase__product-grid .showcase__grid-item {
    width: 100%;
    min-width: 0;
    min-height: 100%;
    box-sizing: border-box;
  }

  .showcase__product-grid-carousel--scrollable .showcase__grid-item {
    flex: 0 0 var(--showcase-product-slide-width, 9.5rem);
    width: var(--showcase-product-slide-width, 9.5rem);
    min-width: var(--showcase-product-slide-width, 9.5rem);
    max-width: var(--showcase-product-slide-width, 9.5rem);
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }

  .showcase__product-grid-nav {
    flex: 0 0 auto;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 18%, transparent);
    background: var(--color-background);
    color: var(--color-foreground);
    cursor: pointer;
    display: none;
    align-items: center;
    justify-content: center;
    padding: 0;
  }

  .showcase__product-grid-carousel--scrollable .showcase__product-grid-nav {
    display: inline-flex;
  }

  .showcase__product-grid-carousel--scrollable .showcase__product-grid-nav[hidden] {
    display: none;
  }

  .showcase__product-grid-nav span {
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .showcase__product-grid-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.12rem;
  }

  .showcase__product-grid-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.12rem;
  }

  .showcase__product-grid-nav:disabled {
    opacity: 0.35;
    cursor: not-allowed;
  }

  .showcase__product-grid-dots {
    display: none;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-top: 0.65rem;
    padding: 0;
  }

  .showcase__product-grid-dots--active:not([hidden]) {
    display: flex;
  }

  .showcase__product-grid-dot {
    width: 0.48rem;
    height: 0.48rem;
    border-radius: 999px;
    border: 0;
    padding: 0;
    background: color-mix(in srgb, var(--color-foreground) 24%, transparent);
    cursor: pointer;
  }

  .showcase__product-grid-dot[aria-current='true'] {
    background: var(--color-foreground);
  }

  .showcase__product-grid-dot:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__intro {
    text-align: center;
    margin-inline: auto;
    max-width: 42rem;
  }

  .showcase__intro.related-products__heading {
    margin: 0 auto clamp(1.25rem, 3vw, 2rem);
    color: #283455;
    font-family: 'Roboto', ui-sans-serif, system-ui, sans-serif;
    font-weight: 700;
    font-size: 1.75rem;
    line-height: 1.15;
    letter-spacing: -0.01em;
  }

  @media screen and (min-width: 500px) {
    .showcase__intro.related-products__heading {
      font-size: 2.25rem;
    }
  }

  @media screen and (min-width: 769px) {
    .showcase__intro.related-products__heading {
      font-size: 2.8125rem;
    }
  }

  .showcase__collection-card--text {
    padding: 0.55rem 1rem;
    justify-content: center;
    text-align: center;
    max-width: min(14rem, 78vw);
  }

  .showcase__collection-card--text .showcase__collection-card-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .showcase__collection-card--text .showcase__collection-card-title {
    padding: 0;
    font-size: 0.875rem;
  }

  .showcase__grid-item {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 0.4rem;
    padding: 0.45rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 15%, transparent);
    border-radius: var(--style-border-radius-inputs, 6px);
    background: var(--color-background);
    color: var(--color-foreground);
    cursor: pointer;
    text-align: center;
    font: inherit;
    overflow: hidden;
  }

  .showcase__grid-item:focus-visible {
    outline: 2px solid currentcolor;
    outline-offset: 2px;
  }

  .showcase__grid-item[aria-pressed='true'] {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .showcase__grid-item-img {
    width: 100%;
    aspect-ratio: 1;
    height: auto;
    flex: 0 0 auto;
    object-fit: cover;
    border-radius: calc(var(--style-border-radius-inputs, 4px) - 2px);
    display: block;
  }

  .showcase__grid-item-title {
    flex: 1 1 auto;
    margin: 0;
    font-size: 0.6875rem;
    line-height: 1.25;
    min-height: 2.5em;
    max-height: 2.5em;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    word-break: break-word;
  }

  @media screen and (min-width: 900px) {
    .showcase__grid-item {
      padding: 0.5rem;
      gap: 0.45rem;
    }

    .showcase__grid-item-title {
      font-size: 0.75rem;
      min-height: 2.5em;
      max-height: 2.5em;
    }
  }

  .showcase__slider {
    margin-bottom: 1.5rem;
  }

  .showcase__slider-label {
    margin: 0 0 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .showcase__accordion-placeholder,
  .showcase__accordion-empty {
    margin: 0;
    font-size: 0.9375rem;
    color: color-mix(in srgb, var(--color-foreground) 62%, transparent);
  }

  .showcase__detail {
    border: 1px solid color-mix(in srgb, var(--color-foreground) 10%, transparent);
    border-radius: var(--style-border-radius-inputs, 8px);
    padding: clamp(1rem, 3vw, 1.75rem);
    background: color-mix(in srgb, var(--color-foreground) 3%, var(--color-background));
  }

  .showcase__detail-empty {
    text-align: center;
    padding: 2rem 1rem;
    color: color-mix(in srgb, var(--color-foreground) 70%, transparent);
    font-size: 0.9375rem;
  }

  .showcase__detail-inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  @media screen and (min-width: 900px) {
    .showcase__detail-inner {
      grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
      align-items: start;
    }
  }

  .showcase__detail-main-wrap {
    position: relative;
  }

  .showcase__detail-main img {
    width: 100%;
    height: auto;
    border-radius: var(--style-border-radius-inputs, 6px);
    display: block;
  }

  .showcase__detail-main-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 15%, transparent);
    background: color-mix(in srgb, var(--color-background) 88%, transparent);
    color: var(--color-foreground);
    cursor: pointer;
    z-index: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .showcase__detail-main-nav--prev {
    left: 0.5rem;
  }

  .showcase__detail-main-nav--next {
    right: 0.5rem;
  }

  .showcase__detail-main-nav span {
    width: 0.5rem;
    height: 0.5rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .showcase__detail-main-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.15rem;
  }

  .showcase__detail-main-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.15rem;
  }

  .showcase__detail-main-nav:disabled {
    opacity: 0.4;
    cursor: default;
  }

  .showcase__detail-thumbs-wrap {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.4rem;
    margin-top: 0.75rem;
  }

  .showcase__detail-thumbs-viewport {
    overflow: hidden;
    min-width: 0;
    width: 100%;
    container-type: inline-size;
    --showcase-thumbs-per-view: 4;
  }

  @media screen and (max-width: 749px) {
    .showcase__detail-thumbs-viewport {
      --showcase-thumbs-per-view: 2;
    }
  }

  @media screen and (min-width: 750px) and (max-width: 989px) {
    .showcase__detail-thumbs-viewport {
      --showcase-thumbs-per-view: 3;
    }
  }

  .showcase__detail-thumbs {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: nowrap;
    gap: 0.5rem;
    width: max-content;
    will-change: transform;
    transition: transform 0.28s cubic-bezier(0.33, 1, 0.68, 1);
  }

  .showcase__detail-thumbs li {
    flex: 0 0 calc(
      (100cqw - (var(--showcase-thumbs-per-view) - 1) * 0.5rem) / var(--showcase-thumbs-per-view)
    );
    width: calc(
      (100cqw - (var(--showcase-thumbs-per-view) - 1) * 0.5rem) / var(--showcase-thumbs-per-view)
    );
  }

  .showcase__detail-thumbs button {
    padding: 0;
    width: 100%;
    border: 2px solid transparent;
    border-radius: 4px;
    background: none;
    cursor: pointer;
    line-height: 0;
  }

  .showcase__detail-thumbs button[aria-current='true'] {
    border-color: var(--color-foreground);
  }

  .showcase__detail-thumbs img {
    width: 100%;
    aspect-ratio: 1;
    height: auto;
    object-fit: cover;
    border-radius: 2px;
    display: block;
  }

  .showcase__detail-thumbs-nav {
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 15%, transparent);
    background: color-mix(in srgb, var(--color-background) 88%, transparent);
    color: var(--color-foreground);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .showcase__detail-thumbs-nav span {
    width: 0.45rem;
    height: 0.45rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    display: block;
  }

  .showcase__detail-thumbs-nav--prev span {
    transform: rotate(135deg);
    margin-left: 0.1rem;
  }

  .showcase__detail-thumbs-nav--next span {
    transform: rotate(-45deg);
    margin-right: 0.1rem;
  }

  .showcase__detail-thumbs-nav:disabled {
    opacity: 0.4;
    cursor: default;
  }

  .showcase__detail-options-label {
    margin: 0 0 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .showcase__detail-swatches {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 1.25rem;
  }

  .showcase__detail-option-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .showcase__detail-option-name {
    margin: 0;
    font-size: 0.8125rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  .showcase__detail-option-values {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .showcase__detail-option-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.5rem;
    padding: 0.35rem 0.85rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 22%, transparent);
    border-radius: 6px;
    background: var(--color-background);
    color: var(--color-foreground);
    font-size: 0.8125rem;
    font-weight: 600;
    cursor: pointer;
  }

  .showcase__detail-option-btn[aria-pressed='true'] {
    border-color: var(--color-foreground);
    box-shadow: 0 0 0 1px var(--color-foreground);
  }

  .showcase__detail-selectors {
    display: none;
  }

  .showcase__detail-form {
    margin-top: 0.5rem;
  }

  .showcase__detail-submit {
    width: 100%;
    padding: 0.95rem 1.5rem;
    border-radius: var(--style-border-radius-inputs, 6px);
    font-weight: normal;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    min-height: 3rem;
    transition:
      filter 0.18s ease,
      box-shadow 0.18s ease,
      transform 0.18s ease;
  }

  .showcase__detail-submit:hover:not(:disabled) {
    filter: brightness(1.08);
    box-shadow: 0 4px 18px color-mix(in srgb, var(--color-button-bg) 32%, transparent);
  }

  .showcase__detail-submit:focus-visible {
    outline: 2px solid var(--color-button-border);
    outline-offset: 3px;
  }

  .showcase__detail-submit:active:not(:disabled) {
    transform: translateY(1px);
  }

  .showcase__detail-submit:disabled {
    opacity: 0.55;
    cursor: not-allowed;
  }

  .showcase__detail-feedback {
    margin: 0.75rem 0 0;
    font-size: 0.875rem;
  }

  .showcase__detail-payments {
    margin-top: 0.7rem;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0.4rem;
    width: 100%;
  }

  .showcase__detail-payment {
    min-height: 2rem;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 14%, transparent);
    border-radius: 8px;
    background: color-mix(in srgb, var(--color-background) 94%, transparent);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.2rem 0.35rem;
  }

  .showcase__detail-payment svg {
    width: 100%;
    max-width: 2.7rem;
    height: auto;
  }

  @media screen and (max-width: 749px) {
    .showcase__detail-payments {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  .showcase__accordions--standalone {
    margin-top: clamp(1.5rem, 4vw, 2.5rem);
  }

  .showcase__rte a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 0.12em;
  }

  .showcase__rte > *:first-child {
    margin-top: 0;
  }

  .showcase__rte > *:last-child {
    margin-bottom: 0;
  }
/* END_SECTION:showcase-tabs */

/* CSS from block stylesheet tags */
/* START_BLOCK:group (INDEX:21) */
.group {
    display: flex;
    flex-wrap: nowrap;
    overflow: hidden;
    width: 100%;
  }

  .group--horizontal {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    padding: 0 var(--padding);
  }

  .group--vertical {
    flex-direction: column;
    align-items: var(--alignment);
    padding: var(--padding) 0;
  }
/* END_BLOCK:group */

/* START_BLOCK:text (INDEX:22) */
.text {
    text-align: var(--text-align);
  }
  .text--title {
    font-family: var(--font-heading--family);
    font-size: 2rem;
    font-weight: normal;
    color: var(--color-text-bold);
  }
  .text--subtitle {
    font-size: 1.5rem;
  }
/* END_BLOCK:text */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:cart-toast (INDEX:24) */
.cart-toast-host {
    position: fixed;
    z-index: 120;
    top: calc(var(--header-fixed-top, 0px) + var(--header-height, 4rem) + 0.625rem);
    right: 1rem;
    left: auto;
    bottom: auto;
    display: flex;
    justify-content: flex-end;
    padding: 0;
    pointer-events: none;
  }

  .cart-toast {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    max-width: min(22rem, calc(100vw - 2rem));
    padding: 0.8rem 1rem 0.8rem 0.8rem;
    border-radius: 12px;
    border: 1px solid transparent;
    box-shadow:
      0 12px 40px color-mix(in srgb, var(--color-foreground) 14%, transparent),
      0 2px 8px color-mix(in srgb, var(--color-foreground) 8%, transparent);
    opacity: 0;
    transform: translateY(-0.35rem) scale(0.98);
    transition:
      opacity 0.32s cubic-bezier(0.22, 1, 0.36, 1),
      transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
    pointer-events: auto;
  }

  .cart-toast-host.is-visible .cart-toast {
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  .cart-toast--added {
    background: #ecfdf5;
    border-color: #86efac;
    color: #14532d;
  }

  .cart-toast--removed {
    background: #fff7ed;
    border-color: #fdba74;
    color: #9a3412;
  }

  .cart-toast--updated {
    background: #eff6ff;
    border-color: #93c5fd;
    color: #1e3a8a;
  }

  .cart-toast--error {
    background: #fef2f2;
    border-color: #fca5a5;
    color: #991b1b;
  }

  .cart-toast__icon {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.75rem;
    height: 1.75rem;
    border-radius: 999px;
    font-size: 0.875rem;
    font-weight: 700;
    line-height: 1;
    background: color-mix(in srgb, currentColor 12%, transparent);
  }

  .cart-toast__message {
    margin: 0;
    font-size: 0.875rem;
    font-weight: 600;
    line-height: 1.35;
    letter-spacing: 0.01em;
  }

  @media screen and (min-width: 750px) {
    .cart-toast-host {
      top: 1.25rem;
      right: 1.25rem;
    }

    .cart-toast {
      transform: translateY(-0.5rem) scale(0.98);
    }

    .cart-toast-host.is-visible .cart-toast {
      transform: translateY(0) scale(1);
    }
  }

  @media (prefers-reduced-motion: reduce) {
    .cart-toast {
      transition: opacity 0.15s ease;
      transform: none;
    }

    .cart-toast-host.is-visible .cart-toast {
      transform: none;
    }
  }
/* END_SNIPPET:cart-toast */

/* START_SNIPPET:image (INDEX:30) */
.image {
    display: block;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: auto;
  }

  .image > img {
    width: 100%;
    height: auto;
  }
/* END_SNIPPET:image */

/* START_SNIPPET:pdp-ui-styles (INDEX:33) */
.product-detail__title {
    margin: 0 0 0.55rem;
    font-family: var(--font-heading--family);
    font-size: var(--font-size-product-title);
    font-weight: normal;
    color: var(--color-text-bold);
    line-height: 1.3;
  }

  .product-detail__title a {
    color: inherit;
    text-decoration: none;
  }

  .product-detail__title a:hover,
  .product-detail__title a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 0.12em;
  }

  .product-detail__price-panel {
    padding: 1rem 0;
    border-top: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .product-detail__price-row {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 0.75rem;
  }

  .product-detail__price-current {
    display: inline-block;
    margin: 0 0.375rem 0 0;
    line-height: normal;
  }

  .product-detail__price-current .money {
    display: inline-block;
    font-family: var(--font-heading--family);
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: -0.01rem;
    line-height: normal;
    color: #283455;
    margin: 0;
  }

  .product-detail__price-compare-wrap[hidden],
  .product-detail__price-badge[hidden],
  .product-detail__price-savings[hidden] {
    display: none !important;
  }

  .product-detail__price-compare {
    font-family: var(--font-body--family);
    font-size: 16px;
    font-weight: 400;
    text-decoration: line-through;
    color: #6e6e6e;
    margin-right: 0.375rem;
  }

  .product-detail__price-compare .money {
    font-family: inherit;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
  }

  .product-detail__price-badge {
    display: inline-block;
    background: #eff0ed;
    color: #417823;
    padding: 0.1875rem 0.5rem 0.125rem;
    border-radius: 0.375rem;
    margin: 0 0.375rem 0.375rem 0;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: normal;
  }

  .product-detail__price-savings {
    margin: 0.375rem 0 0;
    font-size: 0.75rem;
    font-weight: 600;
    line-height: normal;
    color: #417823;
  }

  .product-detail__accordions {
    padding-top: 0.5rem;
  }

  .product-detail__accordion--card + .product-detail__accordion--card {
    margin-top: 0.65rem;
  }

  .product-detail__accordion {
    border: 0;
  }

  .product-detail__accordion-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 0;
    font-weight: 600;
    border-bottom: 1px solid color-mix(in srgb, var(--color-foreground) 12%, transparent);
  }

  .product-detail__accordion-summary::-webkit-details-marker {
    display: none;
  }

  .product-detail__accordion-icon {
    width: 0.65rem;
    height: 0.65rem;
    border-right: 2px solid currentcolor;
    border-bottom: 2px solid currentcolor;
    transform: rotate(45deg);
    transition: transform 0.2s ease;
    flex-shrink: 0;
  }

  .product-detail__accordion[open] .product-detail__accordion-icon {
    transform: rotate(-135deg);
  }

  .product-detail__accordion-body {
    padding: 1rem 0;
    border: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  .product-detail__rte,
  .showcase__rte {
    max-width: 100%;
    overflow-wrap: anywhere;
  }

  .product-detail__rte :is(table, pre, iframe, video, embed),
  .showcase__rte :is(table, pre, iframe, video, embed) {
    display: block;
    max-width: 100%;
  }

  .product-detail__rte table,
  .showcase__rte table {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .product-detail__accordion-body > *:first-child {
    margin-top: 0;
  }

  .product-detail__accordion-body > *:last-child {
    margin-bottom: 0;
  }

  .product-content-tab__figure {
    margin: 0 0 1rem;
  }

  .product-content-tab__image {
    display: block;
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: var(--style-border-radius-inputs, 6px);
  }

  .product-detail__rte img,
  .showcase__rte img {
    display: block;
    max-width: 100%;
    width: auto;
    height: auto;
    margin: 1rem 0;
    border-radius: var(--style-border-radius-inputs, 6px);
  }

  .product-detail__rte img:first-child,
  .showcase__rte img:first-child {
    margin-top: 0;
  }

  .product-detail__rte img:last-child,
  .showcase__rte img:last-child {
    margin-bottom: 0;
  }

  .product-detail__rte figure,
  .showcase__rte figure {
    margin: 1rem 0;
    max-width: 100%;
  }

  .product-detail__rte figure img,
  .showcase__rte figure img {
    margin: 0;
  }
/* END_SNIPPET:pdp-ui-styles */

/* START_SNIPPET:product-card-styles (INDEX:34) */
.product-card {
    border: 1px solid #e8e5e0;
    border-radius: 12px;
    background: #ffffff;
    overflow: hidden;
    box-shadow: 0 2px 10px color-mix(in srgb, var(--color-foreground) 7%, transparent);
    transition:
      box-shadow 0.2s ease,
      transform 0.2s ease;
  }

  .product-card:hover {
    box-shadow: 0 8px 24px color-mix(in srgb, var(--color-foreground) 12%, transparent);
    transform: translateY(-1px);
  }

  .product-card__media {
    display: block;
    position: relative;
    border-radius: 0;
    overflow: hidden;
    border-bottom: 1px solid #e8e5e0;
    background: color-mix(in srgb, var(--color-foreground) 3%, var(--color-background));
    text-decoration: none;
  }

  .product-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    aspect-ratio: 1 / 1;
  }

  .product-card__image--primary,
  .product-card__image--secondary {
    transition:
      opacity 0.28s ease,
      transform 0.28s ease;
  }

  .product-card__image--secondary {
    position: absolute;
    inset: 0;
    opacity: 0;
    pointer-events: none;
  }

  .product-card__media img {
    transition: transform 0.25s ease;
  }

  .product-card:hover .product-card__image--primary {
    opacity: 0;
    transform: scale(1.02);
  }

  .product-card:hover .product-card__image--secondary {
    opacity: 1;
    transform: scale(1.02);
  }

  .product-card:hover .product-card__media img {
    transform: scale(1.02);
  }

  .product-card__badge {
    position: absolute;
    top: 0.5rem;
    left: 0.5rem;
    z-index: 2;
    border-radius: 7px;
    border: 0;
    background: var(--color-foreground);
    color: var(--color-background);
    padding: 0.26rem 0.48rem;
    font-size: 0.66rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: 600;
  }

  .product-card__info {
    margin-top: 0;
    border: 0;
    border-radius: 0;
    border-top: 1px solid #e5e5e5;
    padding: 1rem;
    background: var(--color-background);
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .product-card__info h3 {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.25;
    font-weight: 600;
  }

  .product-card__info h3 a {
    text-decoration: none;
    color: inherit;
  }

  .product-card__price {
    margin: 0;
    display: flex;
    gap: 0.5rem;
    align-items: center;
  }

  .product-card__price-current {
    font-size: 0.875rem;
    font-weight: 600;
  }

  .product-card__price-old {
    font-size: 0.75rem;
    color: color-mix(in srgb, var(--color-foreground) 58%, transparent);
    text-decoration: line-through;
    font-weight: 400;
  }

  .product-card__swatches {
    margin-top: 0.15rem;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem;
  }

  .product-card__swatch {
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 999px;
    border: 1px solid color-mix(in srgb, var(--color-foreground) 20%, transparent);
    background: var(--swatch-color, #d9d9d9);
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--color-background) 45%, transparent);
    flex-shrink: 0;
    overflow: hidden;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  .product-card__swatch-image {
    width: 100%;
    height: 100%;
    border-radius: inherit;
    display: block;
    object-fit: cover;
  }

  .product-card__sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
/* END_SNIPPET:product-card-styles */