/** Shopify CDN: Minification failed

Line 239:2 Unexpected "}"

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:footer (INDEX:12) */
footer a {
    text-decoration: none;
  }
  footer .footer__links,
  footer .footer__payment {
    display: flex;
    gap: 1rem;
  }
  .shopify-section-group-footer {
    border-top: 1px solid var(--color-section-border);
  }
/* END_SECTION:footer */

/* START_SECTION:header (INDEX:14) */
.shopify-section-header-sticky {
    position: sticky;
    top: 0;
  }

  .shopify-section-header-hidden {
    top: calc(-1 * var(--header-height));
  }

  .section-header.animate {
    transition: top 0.15s ease-out;
  }
/* END_SECTION:header */

/* START_SECTION:product (INDEX:22) */
/* Image zoom functionality */
  .image-zoom-wrapper {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
  }
  
  .image-zoom-wrapper[data-image-zoom] {
    cursor: zoom-in;
    user-select: none;
    -webkit-user-select: none;
    -webkit-touch-callout: none;
  }
  
  .image-zoom-wrapper[data-image-zoom].zoomed {
    cursor: grab;
    z-index: 2;
  }
  
  .image-zoom-wrapper img {
    transition: transform 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    will-change: transform;
    transform-origin: center center;
  }
  
  .image-zoom-wrapper.zoomed img {
    transition: none;
  }
  
  /* Reset zoom button */
  .image-zoom-reset {
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border: none;
    border-radius: 50%;
    color: white;
    cursor: pointer;
    z-index: 101;
    transition: all 0.2s ease;
    padding: 0;
    -webkit-tap-highlight-color: rgba(255, 255, 255, 0.1);
    opacity: 0;
    animation: fadeInZoomButton 0.2s ease forwards;
    touch-action: manipulation;
    pointer-events: auto;
  }
  
  @keyframes fadeInZoomButton {
    from {
      opacity: 0;
      transform: scale(0.8);
    }
    to {
      opacity: 1;
      transform: scale(1);
    }
  }
  
  .image-zoom-reset:hover {
    background: rgba(0, 0, 0, 0.8);
    transform: scale(1.1);
  }
  
  .image-zoom-reset:active {
    transform: scale(0.95);
    background: rgba(0, 0, 0, 0.9);
  }
  
  .image-zoom-reset svg {
    width: 20px;
    height: 20px;
    pointer-events: none;
  }
  
  /* Make tap target slightly larger on mobile */
  @media (max-width: 767px) {
    .image-zoom-reset {
      width: 44px;
      height: 44px;
    }
    
    .image-zoom-reset svg {
      width: 22px;
      height: 22px;
    }
  }
  
  /* Hide reset button on desktop (optional - can double-click to exit) */
  @media (min-width: 768px) {
    .image-zoom-reset {
      opacity: 0.7;
    }
    
    .image-zoom-reset:hover {
      opacity: 1;
    }
  }
/* END_SECTION:product */

/* CSS from block stylesheet tags */
/* START_BLOCK:_collection-promo (INDEX:45) */
.collection-promo__card {
    isolation: isolate;
  }

  /* Ensure video fills container */
  .collection-promo__card video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
/* END_BLOCK:_collection-promo */

/* START_BLOCK:_fast-filters (INDEX:54) */
/* When swiper is initialized, remove grid display */
  .fast-filters-swiper.swiper-initialized .swiper-wrapper {
    display: flex;
  }

  /* Ensure swiper-slide works in both modes */
  .fast-filters-swiper:not(.swiper-initialized) .swiper-slide {
    width: auto;
    height: auto;
    flex-shrink: 0;
  }
  .fast-filters-swiper.swiper-initialized .swiper-slide {
    height: auto;
  }
/* END_BLOCK:_fast-filters */

/* START_BLOCK:_filters (INDEX:56) */
/* Accordion animations */
  details[open] summary svg {
    transform: rotate(180deg);
  }
  
  /* Smooth transitions for accordion content */
  details summary {
    transition: color 0.2s ease;
  }
  
  details[open] summary {
    color: var(--color-accent);
  }
  
  /* Ensure proper spacing for vertical layout */
  .filters-vertical details:not(:last-child) {
    border-bottom: 1px solid #e5e7eb;
  }
/* END_BLOCK:_filters */

/* START_BLOCK:group (INDEX:121) */
.group-container {
    padding-top: var(--group-padding-top, 0px);
    padding-bottom: var(--group-padding-bottom, 0px);
    padding-left: var(--group-padding-left, 0px);
    padding-right: var(--group-padding-right, 0px);
    @media (max-width: 768px) {
      padding-top: var(--group-padding-top-mobile, 0px);
      padding-bottom: var(--group-padding-bottom-mobile, 0px);
      padding-left: var(--group-padding-left-mobile, 0px);
      padding-right: var(--group-padding-right-mobile, 0px);
    }
  }
/* END_BLOCK:group */

/* START_BLOCK:image (INDEX:124) */
.content-image img[loading='lazy'] {
    opacity: 0;
  }

.content-image img[loading='lazy'].loaded,
.content-image img[loading='eager'] {
  opacity: 1;
}

@media screen and (max-width: 749px) {
  .mobile-badge-fix * {
    font-size: 12px !important;
    line-height: 1.1 !important;
  }

  .mobile-badge-fix * {
    font-size: 13px !important;
    line-height: 1.15 !important;
    text-align: center !important;
  }
}
  }
/* END_BLOCK:image */

/* START_BLOCK:newsletter-signup (INDEX:130) */
.newsletter-border-wrapper {
    border: var(--border-width, 1px) solid transparent;
  }

  .newsletter-border-wrapper::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    padding: var(--border-width, 1px);
    background: var(--border-background);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    pointer-events: none;
  }

  /* Solid border styles */
  .newsletter-border-wrapper[style*='--border-style: solid'] {
    --border-background: var(--border-color-1, #e5e7eb);
  }

  /* Gradient border styles */
  .newsletter-border-wrapper[style*='--border-style: gradient'] {
    --border-background: linear-gradient(90deg, var(--border-color-1, #ffcc65) 0%, var(--border-color-2, #ffffff) 100%);
  }

  /* No border style */
  .newsletter-border-wrapper[style*='--border-style: none'] {
    border: none;
  }

  .newsletter-border-wrapper[style*='--border-style: none']::before {
    display: none;
  }
/* END_BLOCK:newsletter-signup */

/* START_BLOCK:rotating-text-image (INDEX:142) */
@keyframes rotate {
    from {
      transform: rotate(0deg);
    }
    to {
      transform: rotate(360deg);
    }
  }

  .rotating-text-group {
    animation: rotate 10s linear infinite;
    transform-origin: 50% 50%;
    will-change: transform;
  }
/* END_BLOCK:rotating-text-image */

/* START_BLOCK:row (INDEX:143) */
.row-container {
    padding-top: var(--row-padding-top, 0px);
    padding-bottom: var(--row-padding-bottom, 0px);
    @media (max-width: 768px) {
      padding-top: var(--row-padding-top-mobile, 0px);
      padding-bottom: var(--row-padding-bottom-mobile, 0px);
    }
  }
/* END_BLOCK:row */

/* START_BLOCK:stack (INDEX:147) */
.stack-container {
    padding-top: var(--stack-padding-top, 0px);
    padding-bottom: var(--stack-padding-bottom, 0px);
    @media (max-width: 768px) {
      padding-top: var(--stack-padding-top-mobile, 0px);
      padding-bottom: var(--stack-padding-bottom-mobile, 0px);
    }
  }
/* END_BLOCK:stack */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:accordion (INDEX:153) */
.shopify-block-accordion {
    width: 100%;
  }
/* END_SNIPPET:accordion */

/* START_SNIPPET:background-image (INDEX:158) */
.responsive-image img[loading="lazy"] {
    opacity: 0;
  }
  
  .responsive-image img[loading="lazy"].loaded,
  .responsive-image img[loading="eager"] {
    opacity: 1;
  }
  
  /* Desktop breakpoint */
  @media (min-width: 768px) {
    .responsive-image {
      aspect-ratio: var(--desktop-aspect-ratio) !important;
    }
  }
/* END_SNIPPET:background-image */

/* START_SNIPPET:cart-notes (INDEX:176) */
.cart-notes__toggle[aria-expanded="true"] .cart-notes__icon {
    transform: rotate(180deg);
  }
  
  .cart-notes__content[hidden] {
    display: none;
  }
  
  /* Smooth height transitions */
  .cart-notes__content:not([hidden]) {
    max-height: 300px;
  }
/* END_SNIPPET:cart-notes */

/* START_SNIPPET:cart-upsell (INDEX:177) */
/* Cart Upsell Swiper Customizations */

  .cart-upsell-swiper .swiper-slide {
    height: auto; /* Maintain product card height */
  }

  /* Hide pagination when there's only one slide */
  .cart-upsell-swiper[data-product-count='1'] .cart-upsell-pagination {
    display: none;
  }

  /* Custom pagination styles - pill-shaped active indicator */
  .cart-upsell-pagination .swiper-pagination-bullet {
    width: 10px;
    height: 10px;
    background: #d7d7d7;
    opacity: 1;
    margin: 0 7px;
    border-radius: 100px;
    transition: width 0.3s ease, background-color 0.3s ease;
  }

  .cart-upsell-pagination .swiper-pagination-bullet-active {
    width: 40px;
    background: var(--color-primary);
    border-radius: 100px;
  }
/* END_SNIPPET:cart-upsell */

/* START_SNIPPET:product-media-gallery (INDEX:217) */
/*
    Swiper’s default CSS uses .swiper-slide { width: 100% } until init() runs and sets
    inline widths. That first paint vs post-init mismatch drives most CLS on the desktop
    thumb strip and the main gallery. These rules mirror initProductMediaSwipers() in
    assets/swiper.js (spaceBetween + slidesPerView). Inline styles from Swiper override
    once the instance is ready.
  */
  .product-media-navigation__wrapper-desktop .swiper-wrapper .swiper-slide {
    width: calc((100% - 42px) / 4);
    margin-right: 14px;
    height: auto;
  }

  .product-media__wrapper .swiper-wrapper .swiper-slide {
    width: 100%;
    margin-right: 16px;
    height: auto;
  }

  @media (min-width: 768px) {
    .product-media__wrapper .swiper-wrapper .swiper-slide {
      width: calc((100% - 16px) / 2);
    }
  }

  .product-media-navigation__wrapper-mobile .swiper-wrapper .swiper-slide {
    width: calc((100% - 26px) / 4.25);
    margin-right: 8px;
    height: auto;
  }
/* END_SNIPPET:product-media-gallery */

/* START_SNIPPET:slideshow-controls-styles (INDEX:228) */
.swiper-pagination {
      position: relative;
    }

    .swiper-pagination-bullet-active {
      width:4rem;
      border-radius: 10rem;
      transition: width .2s ease-in-out;
    }
/* END_SNIPPET:slideshow-controls-styles */

/* START_SNIPPET:text (INDEX:238) */
.text {
    text-align: var(--text-align);
  }
/* END_SNIPPET:text */