/** Shopify CDN: Minification failed

Line 18:45 Unexpected "*"

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:footer (INDEX:21) */
/* ---------------------------------------------------------
     Make the embedded Klaviyo footer form match the native
     newsletter form. Scoped to .footer-newsletter so other
     Klaviyo forms (popups, etc.) are untouched.

     Anchored on STABLE selectors only (form id, input[type=email],
     .klaviyo-form-button, [data-testid=...]) — never on Klaviyo's
     auto-generated go*/kl-private-reset-css-* classes, which change
     when the form is republished. !important is required because
     Klaviyo sets layout via inline styles.
  --------------------------------------------------------- */

  /* All Klaviyo wrapper layers fill their parent so the form can span the
     full width of the newsletter column. Klaviyo nests:
       .klaviyo-form-XXXX (outer)  >  .needsclick (reset)  >  form  >  column div */
  .footer-newsletter .klaviyo-form,
  .footer-newsletter .klaviyo-form > div,
  .footer-newsletter .klaviyo-form form > div {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* Right-align the form to match the right-aligned heading/description.
     The outer container ([class*=form-version-cid-] = only the outer div,
     never the inner <form> which uses an underscore) becomes a flex row
     that pushes the form to the right; margin-left:auto is a fallback if a
     wrapper ends up capped. On mobile we flip back to the left. */
  .footer-newsletter [class*="form-version-cid-"] {
    display: flex !important;
    justify-content: flex-end !important;
  }
  /* The form's wrapper fills the column to give a full-width track, then the
     form itself is capped and pushed to the right (flex-end / margin-auto). */
  .footer-newsletter [class*="form-version-cid-"] > div {
    flex: 1 1 auto !important;
    width: 100% !important;
  }
  /* Form keeps a contained width and sits on the right. Override Klaviyo's
     inline max-width:450px + margin:0 auto. Tweak the max-width to taste. */
  .footer-newsletter .klaviyo-form form {
    width: 100% !important;
    max-width: 56rem !important;
    margin: 0 0 0 auto !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    background-color: transparent !important;
  }

  @media screen and (max-width: 749px) {
    .footer-newsletter [class*="form-version-cid-"] {
      justify-content: flex-start !important;
    }
    .footer-newsletter .klaviyo-form form {
      max-width: 100% !important;
      margin: 0 !important;
    }
  }

  /* Kill the inline min-height on the form's inner column wrapper */
  .footer-newsletter .klaviyo-form form > div {
    min-height: 0 !important;
  }

  /* The form row becomes the rounded "pill" wrapper */
  .footer-newsletter .klaviyo-form [data-testid="form-row"] {
    width: 100% !important;
    align-items: center !important;
    gap: 0 !important;
    padding: 0.5rem !important;
    border: 1px solid rgba(var(--color-foreground), 0.18) !important;
    border-radius: calc(var(--buttons-radius) + 0.5rem) !important;
    background: rgba(var(--color-foreground), 0.04) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
  }

  .footer-newsletter .klaviyo-form [data-testid="form-row"]:focus-within {
    border-color: rgba(var(--color-foreground), 0.45) !important;
    background: rgba(var(--color-foreground), 0.06) !important;
    box-shadow: 0 0 0 4px rgba(var(--color-foreground), 0.08) !important;
  }

  /* Email field grows, button stays its natural width */
  .footer-newsletter .klaviyo-form [data-testid="form-component"]:first-child {
    flex: 1 1 auto !important;
    min-width: 0 !important;
  }
  .footer-newsletter .klaviyo-form [data-testid="form-component"]:last-child {
    flex: 0 0 auto !important;
  }

  /* Input */
  .footer-newsletter .klaviyo-form input[type="email"] {
    width: 100% !important;
    border: none !important;
    border-radius: var(--buttons-radius) !important;
    padding: 1.2rem 2rem !important;
    background: transparent !important;
    height: auto !important;
    margin: 0 !important;
    color: currentColor !important;
    font-size: 1.4rem !important;
    box-shadow: none !important;
    outline: none !important;
  }
  .footer-newsletter .klaviyo-form input[type="email"]::placeholder {
    color: currentColor;
    opacity: 0.55;
  }
  .footer-newsletter .klaviyo-form input[type="email"]:focus,
  .footer-newsletter .klaviyo-form input[type="email"]:focus-visible {
    border: none !important;
    box-shadow: none !important;
    outline: none !important;
  }

  /* Button — match native filled button */
  .footer-newsletter .klaviyo-form button.klaviyo-form-button {
    border-radius: var(--buttons-radius) !important;
    margin: 0 !important;
    white-space: nowrap !important;
    height: auto !important;
    padding: 1.2rem 3rem !important;
    font-size: 1.3rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    border: none !important;
    cursor: pointer !important;
    background-color: rgb(var(--color-button)) !important;
    color: rgb(var(--color-button-text)) !important;
    transition: transform 0.15s ease, box-shadow 0.2s ease !important;
  }
  .footer-newsletter .klaviyo-form button.klaviyo-form-button:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18) !important;
  }
  .footer-newsletter .klaviyo-form button.klaviyo-form-button:active {
    transform: translateY(0) !important;
    box-shadow: none !important;
  }

  @media screen and (max-width: 749px) {
    .footer-newsletter .klaviyo-form button.klaviyo-form-button {
      padding: 1.2rem 2rem !important;
    }
    .footer-newsletter .klaviyo-form input[type="email"] {
      padding: 1.2rem 1.6rem !important;
    }
  }
/* END_SECTION:footer */

/* START_SECTION:returns (INDEX:58) */
.returns__wrapper {
    text-align: var(--content-align, center);
  }

  .returns__heading {
    margin-block: 0 1rem;
  }

  .returns__subtext {
    max-width: 60rem;
    margin-inline: auto;
    margin-block: 0 4rem;
  }

  .returns__wrapper[style*='left'] .returns__subtext {
    margin-inline: 0;
  }

  .returns__steps {
    list-style: none;
    counter-reset: returns-step;
    display: grid;
    gap: 2.4rem;
    max-width: 64rem;
    margin: 0 auto 4rem;
    padding: 0;
    text-align: left;
  }

  .returns__step {
    display: flex;
    align-items: flex-start;
    gap: 1.6rem;
  }

  .returns__step-number {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    border: 0.1rem solid currentColor;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1;
  }

  .returns__step-title {
    margin: 0 0 0.4rem;
    font-size: 1.8rem;
  }

  .returns__step-text {
    margin: 0;
  }

  .returns__button-wrapper {
    margin-top: 1rem;
  }

  .returns__footnote {
    margin-top: 2.4rem;
    font-size: 1.4rem;
    opacity: 0.75;
  }

  @media screen and (min-width: 750px) {
    .returns__steps {
      gap: 3.2rem;
    }
  }
/* END_SECTION:returns */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:card-product (INDEX:73) */
/* Product card: category badges on image, then Rating > Title > Price */
  .product-card-wrapper .card__content {
    text-align: left;
  }

  /* Category badges overlaid on the bottom-left of the image
     (.card__media is already position:absolute, so it anchors the overlay) */
  .product-card-wrapper .card__media-categories {
    position: absolute;
    left: 0.8rem;
    bottom: 0.8rem;
    z-index: 2;
    pointer-events: none;
  }

  .product-card-wrapper .card__media-categories .product__categories-grid {
    gap: 0.4rem;
  }

  .product-card-wrapper .card__media-categories .category-box {
    pointer-events: auto;
    font-size: 1rem;
    line-height: 1;
    padding: 0.4rem 0.7rem;
    backdrop-filter: blur(2px);
  }

  /* Text block: even rhythm between rating, title and price */
  .product-card-wrapper .card__information {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.6rem;
    padding-top: 1rem;
  }

  .product-card-wrapper .card__rating {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0;
  }

  .product-card-wrapper .card__rating .rating {
    margin: 0;
  }

  /* Golden filled stars, grayish unfilled (overrides theme black) */
  .product-card-wrapper .rating-star {
    --color-rating-star: #e0a02d;
  }

  .product-card-wrapper .rating-star::before {
    background: linear-gradient(
      90deg,
      #e0a02d var(--percent),
      #cbcfd4 var(--percent)
    );
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .product-card-wrapper .card__rating-count {
    opacity: 0.7;
  }

  .product-card-wrapper .card__heading {
    margin: 0;
  }

  .product-card-wrapper .card-information {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.4rem;
    width: 100%;
  }

  .product-card-wrapper .card__price-wrapper {
    margin: 0;
  }

  /* Sale / sold-out badge: the theme hides .card__content .card__badge for standard/card
     styles, so surface it over the image instead (top-left; category badges sit bottom-left). */
  .card-wrapper.product-card-wrapper .card {
    position: relative;
  }

  .card-wrapper.product-card-wrapper .card .card__content .card__badge {
    display: flex;
    position: absolute;
    top: 0.8rem;
    left: 0.8rem;
    margin: 0;
    z-index: 3;
  }

  /* Compare-at "was" price: small but readable, clearly smaller than the current price */
  .card-wrapper.product-card-wrapper .price--on-sale .price-item--regular {
    font-size: 1.1rem;
  }
/* END_SNIPPET:card-product */

/* START_SNIPPET:sticky-atc (INDEX:121) */
.sticky-atc {
    position: fixed;
    top: 0.4rem;
    left: 0;
    right: 0;
    /* Sit behind the header (z-index 3/4) so the header covers the card when it appears */
    z-index: 2;
    padding: 0 1.2rem;
    transform: translateY(-150%);
    visibility: hidden;
    pointer-events: none;
    transition: transform 0.3s ease, visibility 0.3s ease;
  }

  .sticky-atc.sticky-atc--active {
    transform: translateY(0);
    visibility: visible;
    pointer-events: auto;
  }

  /* The visible card: centered, max-width, rounded 4px */
  .sticky-atc__inner {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    max-width: 78rem;
    margin: 0 auto;
    padding: 0.6rem 1.2rem;
    background: rgb(var(--color-background));
    border: 0.1rem solid rgba(var(--color-foreground), 0.14);
    border-radius: 0.4rem;
    box-shadow: 0 0.4rem 1.2rem rgba(var(--color-foreground), 0.1);
  }

  .sticky-atc__media {
    flex: 0 0 auto;
    line-height: 0;
  }

  .sticky-atc__media img {
    display: block;
    width: 5rem;
    height: 5rem;
    object-fit: cover;
    border-radius: 0.4rem;
  }

  .sticky-atc__info {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    min-width: 0;
    margin-right: auto;
  }

  .sticky-atc__title {
    font-weight: 600;
    font-size: 1.4rem;
    text-decoration: none;
    color: rgb(var(--color-foreground));
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 34rem;
  }

  .sticky-atc__price {
    font-size: 1.3rem;
    color: rgba(var(--color-foreground), 0.85);
  }

  .sticky-atc__price-was {
    margin-right: 0.5rem;
    font-size: 1.15rem;
    text-decoration: line-through;
    color: rgba(var(--color-foreground), 0.55);
  }

  .sticky-atc__price-now {
    font-weight: 600;
  }

  .sticky-atc__form {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    margin: 0;
  }

  /* Dropdown and button share the same height so they line up */
  .sticky-atc .sticky-atc__variant,
  .sticky-atc .sticky-atc__add {
    height: 4.4rem;
    min-height: 4.4rem;
    font-size: 1.3rem;
    margin: 0;
  }

  .sticky-atc__variant {
    max-width: 16rem;
    padding: 0 0.8rem;
    border: 0.1rem solid rgba(var(--color-foreground), 0.2);
    border-radius: var(--inputs-radius, 0.4rem);
    background: rgb(var(--color-background));
    color: rgb(var(--color-foreground));
  }

  .sticky-atc__add {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
    padding: 0 1.8rem;
  }

  @media screen and (max-width: 749px) {
    .sticky-atc {
      padding: 0 0.8rem;
    }

    .sticky-atc__inner {
      gap: 0.8rem;
      padding: 0.5rem 0.8rem;
    }

    .sticky-atc__media,
    .sticky-atc__title {
      display: none;
    }

    .sticky-atc .sticky-atc__variant,
    .sticky-atc .sticky-atc__add {
      height: 3.9rem;
      min-height: 3.9rem;
      font-size: 1.2rem;
    }

    .sticky-atc__variant {
      max-width: 12rem;
      padding: 0 0.6rem;
    }

    .sticky-atc__add {
      padding: 0 1.2rem;
    }
  }
/* END_SNIPPET:sticky-atc */

/* START_SNIPPET:tracking (INDEX:124) */
.consent-banner {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000001;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1.6rem;
    padding: 1.6rem 2rem;
    background: rgb(var(--color-background));
    color: rgb(var(--color-foreground));
    border-top: 1px solid rgba(var(--color-foreground), 0.12);
    box-shadow: 0 -8px 24px rgba(0, 0, 0, 0.12);
  }

  .consent-banner[hidden] {
    display: none;
  }

  .consent-banner__message {
    flex: 1 1 320px;
    margin: 0;
    font-size: 1.3rem;
    line-height: 1.5;
  }

  .consent-banner__actions {
    display: flex;
    gap: 1rem;
    flex-shrink: 0;
  }

  .consent-banner__actions .button {
    margin: 0;
  }

  @media screen and (max-width: 749px) {
    .consent-banner {
      flex-direction: column;
      align-items: stretch;
      text-align: center;
    }

    .consent-banner__actions {
      justify-content: center;
    }
  }
/* END_SNIPPET:tracking */