/** Shopify CDN: Minification failed

Line 563:20 Unexpected "{"
Line 563:29 Expected ":"
Line 571:20 Unexpected "{"
Line 571:29 Expected ":"
Line 572:20 Unexpected "{"
Line 572:29 Expected ":"
Line 573:20 Unexpected "{"
Line 573:29 Expected ":"
Line 580:20 Unexpected "{"
Line 580:29 Expected ":"
... and 4 more hidden warnings

**/
/* UTILITY CLASSES */

.underline {
  text-decoration: underline;
}

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

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

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

.d-flex {
  display: flex;
}

/* MEGA MENU */

.mega-menu__linklist {
  flex-direction: column;
  gap: 20px;
}

.mega-menu__linklist .h6 {
  font-weight: bold;
}

.mega-menu__promo {
  flex: auto;
  min-height: 300px;
}

.mega-menu__promo a {
  flex: 50%;
  min-width: unset;
  max-width: 50%;
  position: relative;
}

.mega-menu__promo img {
  position: absolute;
  top: 0;
  left: 0;
}

.mega-menu__promo a .text-center {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  transform: translate(-50%, -50%);
  color: #fff;
  max-height: 100%;
}

.mega-menu__promo img {
  object-fit: cover;
  object-position: center;
  height: 100%;
  width: 100%;
}

.mega-menu {
  gap: 5rem;
  align-items: stretch;
}

.mega-menu__linklist {
  padding-right: 5rem;
  border-right: 1px solid #000;
  width: 20%;
}

.mega-menu { 
  padding-inline: clamp(5rem, 9vw, 9rem) !important; 
}

/* Make mega menu paragraph links smaller */
.mega-menu__linklist a {
  font-size: 0.85rem;  /* tweak 0.85–0.95rem depending on your layout */
  line-height: 1.4;
  font-family: var(--font-body-family); /* ensures it uses the body font */
  font-weight: 400;
  text-transform: none;
}

/* Make only the first item in the mega menu bold */
/* fake a “semi-bold” look without new weights */
.mega-menu__linklist li:first-child a {
  font-weight: 700;
  opacity: 0.75;              /* softens the bold look */
  letter-spacing: 0.02em;     /* keeps it tidy */
}

/* HEADER */

.header {
  padding-block: 15px;
}

@media screen and (min-width: 700px) and (max-width: 1200px) {
  .header {
    column-gap: 0.5rem;
    padding-inline: 20px;
  }
  .header__primary-nav {
    column-gap: 1rem;
  }
}

/* FOOTER */

.localization-selectors x-popover {
  right: 0;
  left: unset;
}

.social-media--list {
  gap: 1.25rem;
}

@media screen and (max-width: 999px) {
  .footer__aside.footer__aside-end {
    display: flex;
  }
  .footer__aside:not(.footer__aside-end) {
    display: flex;
    flex-direction: column-reverse;
  }
}

@media screen and (min-width: 1000px) {
  .footer__aside.footer__aside-end {
    justify-content: flex-end;
  }
}

/* PRODUCT CARDS */

.product-card__image {
  object-fit: cover;
}

.product-card__figure > .badge-list {
  inset-block-start: 0;
  inset-inline-start: 0;
  max-width: 100%;
}

.badge {
  max-width: 100%;
}

/* PRODUCT PAGE */

.afterpay-logo {
  display: inline-block;
}

.product-gallery__image-list {
  position: relative;
}

.product-gallery__image-list > .badge-list {
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (min-width: 1000px) {
  .product > product-gallery {
    position: sticky;
    top: 100px
  }
}

/* COLLECTION PAGE */

.shopify-section--main-collection {
  position: relative;
}

.shopify-section--main-collection.collection-loading::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(255, 255, 255, 1) 20%,
    rgba(255, 255, 255, 0.6) 50%,
    rgba(255, 255, 255, 1) 80%
  );
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
  pointer-events: none;
}

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

.collection-filters-top {
  padding-inline: 1.875rem;
}

.collection-filters-top .accordion-list {
  display: flex;
  align-items: center;
  gap: 20px;
}

.collection-filters-top .price-range {
  min-width: 300px;
}

.collection-filters-top .facets .accordion-list .accordion {
  border: none;
  position: relative;
}

.collection-filters-top .facets .accordion-list .accordion:first-child .accordion__toggle {
  padding-block: 1.25rem;
}

.collection-filters-top .accordion__content  {
  position: absolute;
  top: 100%;
  left: 0;
  background-color: #fff;
  min-width: 150px;
  box-shadow: rgba(22, 22, 22, 0.16) 0px 2px 4px;
  border: 1px solid rgb(var(--border-color));
  padding: 10px 10px !important;
  max-height: 500px;
  overflow: auto;
}

.collection-filters-top .accordion__content > .h-stack {
  justify-content: center;
}

.collection-filters-top [data-tooltip]:after {
  display: none;
}

.collection-filters-top .color-swatch {
  border-color: rgb(var(--border-color));
}

@media screen and (min-width: 700px) {
  .collection-toolbar {
    flex-direction: row;
  }
}

/* MISC */

.media-grid.media-grid--fixed-ar {
  --media-grid-row-height: auto;
}

.media-grid.media-grid--fixed-ar > .media-grid__item {
  aspect-ratio: 5 / 7;
}

.button.button-white {
  --button-background: 255 255 255;
  --button-outline-color: 255 255 255;
  --button-text-color: 28 28 28;
}

.newsletter .form {
  max-width: 100%;
}
/* ================== WISHLIST / HEARTS ================== */

/* Small heart buttons (collection / PDP / wishlist cards) */
.sm-wishlist-card-heart .sm-wishlist-btn,
.buy-buttons__primary-row .sm-wishlist-btn {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 24px;
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  cursor: pointer;
  vertical-align: middle;
}

/* kill focus outline / weird browser styling */
.sm-wishlist-btn:focus,
.sm-wishlist-btn:focus-visible {
  outline: none;
}

/* stack both icons exactly in the same box */
.sm-wishlist-btn .heart-icon {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transition: opacity 0.15s ease;
}

/* default: empty heart visible */
.heart-icon--empty {
  opacity: 1;
}
.heart-icon--filled {
  opacity: 0;
}

/* active state: show filled, hide empty */
.sm-wishlist-btn.is-active .heart-icon--empty {
  opacity: 0;
}
.sm-wishlist-btn.is-active .heart-icon--filled {
  opacity: 1;
}

.product-card__figure {
  position: relative;
}

.sm-wishlist-card-heart {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 1;
}

/* ================== PDP ADD TO CART ROW ================== */

.buy-buttons__primary-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* Make the ATC take the row, heart stays compact */
.buy-buttons__primary-row .button,
.buy-buttons__primary-row .button--primary,
.buy-buttons__primary-row .button--stretch {
  flex: 1 1 auto;
}

/* PDP wishlist button styling */
.buy-buttons__primary-row .wishlist-button {
  padding: 0;
  margin: 0;
  border: none;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

/* Icon size */
.buy-buttons__primary-row .wishlist-button__icon,
.buy-buttons__primary-row .wishlist-button svg {
  width: 18px;
  height: 18px;
}

/* Optional hover micro-effect */
.buy-buttons__primary-row .wishlist-button:hover svg {
  transform: scale(1.05);
}

/* ================== WISHLIST PAGE LAYOUT ================== */

/* Less gap under header – override theme section spacing */
section.sm-wishlist.section-spacing {
  padding-top: 1.5rem !important;
}

/* HEADER: title + actions on one row */
.sm-wishlist__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.sm-wishlist__title {
  margin: 0;
}

/* Text below header */
.sm-wishlist__empty {
  margin-top: 0.5rem;
  color: var(--color-text-subdued, #777);
}

.sm-wishlist__note,
.sm-wishlist__status {
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: var(--color-text-subdued, #777);
}

/* BUTTON GROUP (CLEAR + COPY) */
.sm-wishlist-buttons {
  display: flex;
  align-items: center;
  gap: 16px;
}

/* Same width buttons on desktop */
.sm-wishlist-buttons .button {
  min-width: 220px;
  text-align: center;
  margin: 0; /* kill theme margins */
}


/* COPY WISHLIST LINK: keep theme's filled style via .button button--primary */

/* Hide actions when wishlist is empty (JS toggles this class) */
.sm-wishlist-buttons--hidden {
  display: none !important;
}

/* Mobile: stack buttons */
@media (max-width: 768px) {
  .sm-wishlist-buttons {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .sm-wishlist-buttons .button {
    width: 100%;
    min-width: 0;
  }
}

/* ================== GRID – mimic collection cards ================== */

.sm-wishlist__grid {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  column-gap: 2.4rem;
  row-gap: 3.2rem;
  justify-items: center;
}

/* Make each wishlist card behave like a standard product card */
.sm-wishlist__grid > .product-card {
  width: 100%;
  max-width: 320px;
}

/* 3 per row on medium screens */
@media (max-width: 1200px) {
  .sm-wishlist__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* 2 per row on tablet */
@media (max-width: 900px) {
  .sm-wishlist__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* 2 per row on small mobile */
@media (max-width: 600px) {
  .sm-wishlist__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 768px) {
  /* Stack everything vertically */
  .sm-wishlist__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 1rem;
  }

  /* Center only the title */
  .sm-wishlist__title {
    width: 100%;
    text-align: center;
  }

  /* Buttons stacked and full width */
  .sm-wishlist-buttons {
    width: 100%;
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }

  .sm-wishlist-buttons .button {
    width: 100%;
    min-width: 0;
    margin: 0 !important;
  }
}
/* WISHLIST ICON BADGE */
.header__wishlist-link {
  position: relative; /* so badge can be positioned relative to it */
}

.sm-wishlist-count-badge {
  position: absolute;
  top: -4px;
  right: -6px;
  min-width: 16px;
  padding: 2px 5px;
  border-radius: 999px;

  background: #000;
  color: #fff;
  font-size: 10px;
  line-height: 1;
  text-align: center;

  display: none; /* hidden when count = 0 */
}
price-list:has(compare-at-price) sale-price {
  color: #af1010 !important;
}

price-list:not(:has(compare-at-price)) sale-price {
  color: inherit !important;
}
 /* DESKTOP ONLY: keep nav on one line */
@media screen and (min-width: 1000px) {
  #shopify-section-{{ section.id }} .header__primary-nav > ul {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 1.6rem;              /* space between items */
    align-items: center;
  }

  /* prevent "NEW / IN" etc. from breaking into 2 lines */
  #shopify-section-{{ section.id }} .header__primary-nav-item,
  #shopify-section-{{ section.id }} .header__primary-nav-item a,
  #shopify-section-{{ section.id }} .header__primary-nav-item summary {
    white-space: nowrap;
  }
}

/* NARROW DESKTOPS: tighten font + gaps so it fits */
@media screen and (min-width: 1000px) and (max-width: 1400px) {
  #shopify-section-{{ section.id }} .header__primary-nav > ul {
    gap: 1.1rem;              /* tighter gap on smaller desktops */
  }

  #shopify-section-{{ section.id }} .header__primary-nav-item a,
  #shopify-section-{{ section.id }} .header__primary-nav-item summary {
    font-size: 11px;
    letter-spacing: 0.06em;   /* reduce tracking so words aren’t stupidly wide */
    padding-inline: 0;
  }
}
@media screen and (max-width: 999px) {
  .header-sidebar .card,
  .header-sidebar [class*="promo"],
  .header-sidebar [class*="promotion"] {
    display: none !important;
  }
}
/* DESKTOP ONLY — Force stable mega menu height */
@media screen and (min-width: 1000px) {

  /* Fix the mega menu overall height */
  .mega-menu {
    align-items: stretch !important;
  }

  /* Force image column to have a consistent height */
  .mega-menu__promo {
    min-height: 360px !important;   /* adjust 320–420px based on your visuals */
    display: flex !important;
    gap: 2rem;
  }

  /* Make each promo-card fill the height */
  .mega-menu__promo .promo-card {
    height: 100% !important;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }

  /* Make the image inside promo-card fill the container */
  .mega-menu__promo .promo-image,
  .mega-menu__promo .promo-image img {
    height: 100% !important;
    width: 100% !important;
    object-fit: cover !important;
  }

  /* Prevent text column from collapsing to smaller height than promo column */
  .mega-menu__linklist {
    align-self: stretch;
  }
}
