/** Shopify CDN: Minification failed

Line 1606:15 Expected identifier but found whitespace
Line 1606:17 Unexpected "{"
Line 1606:26 Expected ":"
Line 1606:59 Expected ":"
Line 1611:12 Expected identifier but found whitespace
Line 1611:14 Unexpected "{"
Line 1611:23 Expected ":"
Line 1611:50 Expected ":"
Line 1674:14 Expected identifier but found whitespace
Line 1674:16 Unexpected "{"
... and 6 more hidden warnings

**/
/* SHOPIFY_STYLESHEETS_VERSION: 1.0 */


/* CSS from section stylesheet tags */
/* START_SECTION:404 (INDEX:0) */
/* Ensure Montserrat is available */
  /* @import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap'); */

  /* --- Main Container & Layout --- */
  .kv1-404-container {
    position: relative;
    min-height: 100vh; /* Full viewport height */
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    overflow: hidden;
    font-family: 'Montserrat', sans-serif;
  }

  /* --- Background Layers (Shared style) --- */
  .bg-video-wrapper,
  .bg-image-layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .bg-image-layer {
    background-size: cover;
    background-position: center;
  }

  .bg-video-element {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }

  /* --- Content Styling --- */
  .content-wrapper {
    position: relative;
    z-index: 10; /* Above backgrounds */
    width: 100%;
    max-width: 600px;
    padding: 20px;
    border-radius: 24px;
    backdrop-filter: blur(2px);
  }

  .error-logo-slot {
    position: absolute;
    z-index: 20;
    max-width: min(45vw, 360px);
    line-height: 1;
  }
  .error-logo-slot.logo-pos-top_left { top: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .error-logo-slot.logo-pos-top_center { top: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .error-logo-slot.logo-pos-top_right { top: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }
  .error-logo-slot.logo-pos-bottom_left { bottom: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .error-logo-slot.logo-pos-bottom_center { bottom: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .error-logo-slot.logo-pos-bottom_right { bottom: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }

  .error-logo-image {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
  }

  .error-logo-fallback-text {
    display: none;
    font-size: 1.125rem;
    font-weight: 700;
  }

  .error-logo-slot.error-logo-fallback .error-logo-fallback-text {
    display: block;
  }

  /* Typography Utilities */
  .text-center {
    text-align: center;
  }
  .inline-block {
    display: inline-block;
  }
  .mb-10 {
    margin-bottom: 2.5rem;
  }
  .mb-8 {
    margin-bottom: 2rem;
  }
  .mb-4 {
    margin-bottom: 1rem;
  }
  .max-w-md {
    max-width: 28rem;
  }
  .mx-auto {
    margin-left: auto;
    margin-right: auto;
  }

  /* Larger sizes for 404 emphasis */
  .text-4xl {
    font-size: 2.5rem;
    line-height: 1.1;
    letter-spacing: -0.03em;
  }
  .text-3xl {
    font-size: 1.875rem;
    line-height: 1.2;
  }
  .text-base {
    font-size: 1.1rem;
    line-height: 1.6;
  }

  .font-bold {
    font-weight: 700;
  }
  .tracking-tight {
    letter-spacing: -0.025em;
  }
  .opacity-80 {
    opacity: 0.8;
  }

  /* Richtext cleanup */
  .richtext-content p {
    margin-bottom: 1em;
  }
  .richtext-content p:last-child {
    margin-bottom: 0;
  }

  /* --- Premium Pill Button Style --- */
  .kv1-primary-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 18px 40px;
    border-radius: 9999px; /* Full pill shape */
    text-decoration: none;
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 0.02em;
    transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  }

  .kv1-primary-btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-right: 10px;
  }

  .kv1-primary-btn--premium {
    min-width: 220px;
    padding-top: 19px;
    padding-bottom: 19px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
  }

  .kv1-primary-btn:hover {
    transform: scale(1.05) translateY(-2px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
    opacity: 0.95;
  }

  /* Responsive fixes */
  @media (max-width: 640px) {
    .error-logo-slot {
      max-width: min(60vw, 260px);
    }

    .text-4xl {
      font-size: 2rem;
    }
    .text-3xl {
      font-size: 1.5rem;
    }
    .text-base {
      font-size: 1rem;
    }
    .kv1-primary-btn {
      padding: 16px 32px;
    }
  }
/* END_SECTION:404 */

/* START_SECTION:collection (INDEX:4) */
.filter-price-range {
    margin-top: 10px;
  }

  .container.wide-layout {
    max-width: 2000px;
    margin: 0 auto;
    padding: 0 60px;
    padding-top: 100px;
  }

  .collection-page {
    padding-top: 100px !important;
  }

  .collection-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 80px;
    align-items: flex-start;
  }

  .collection-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
  }

  .collection-header-centered {
    text-align: center;
    margin-bottom: 60px;
  }

  .search-form-pill {
    display: flex;
    align-items: center;
    background: #f6f6f6;
    border-radius: 60px;
    padding: 18px 35px;
    max-width: 800px;
    width: 95%;
    margin-bottom: 40px;
    transition: all 0.3s ease;
  }

  .search-form-pill:focus-within {
    background: #f0f0f0;
    box-shadow: 0 4px 25px rgba(0, 0, 0, 0.06);
  }

  .search-input-top {
    flex: 1;
    border: none;
    background: transparent;
    outline: none;
    font-family: 'Montserrat', sans-serif;
    font-size: 17px;
    font-weight: 500;
    margin-left: 15px;
    color: #000;
    letter-spacing: -0.01em;
  }

  .search-clear-btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: #000;
    text-decoration: none;
    opacity: 0.7;
    margin-left: 15px;
    transition: opacity 0.2s ease;
    text-transform: none; /* No uppercase if "Claro" in image is normal */
  }

  .search-clear-btn:hover {
    opacity: 1;
  }

  .search-form-pill svg {
    color: #000;
    opacity: 0.9;
    flex-shrink: 0;
  }

  .collection-header-centered .main-title {
    font-size: 32px;
    font-weight: 600;
    margin-bottom: 30px;
    letter-spacing: -0.02em;
  }

  .search-bar-centered {
    margin: 0 auto;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
  }

  /* Sidebar Filters */
  .filter-group {
    border-bottom: 1px solid #eee;
    margin-bottom: 10px;
    padding-bottom: 10px;
    background: transparent;
    overflow: hidden;
  }

  .filter-group:last-child {
    border-bottom: none;
  }

  .collection-empty-container {
    grid-column: 1 / -1;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 400px;
    padding: 40px;
  }

  .collection-empty-card {
    text-align: center;
    max-width: 500px;
    background: #fdfdfd;
    padding: 60px 40px;
    border-radius: 32px;
    border: 1px solid #eee;
  }

  .empty-icon-wrapper {
    width: 80px;
    height: 80px;
    background: #f4f4f4;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 30px;
    color: #666;
  }

  .empty-title {
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #000;
  }

  .empty-text {
    font-size: 15px;
    opacity: 0.6;
    line-height: 1.6;
    margin-bottom: 40px;
  }

  .empty-reset-btn {
    width: 100%;
    padding: 16px 32px;
  }

  .filter-group {
    border-bottom: 1px solid #eee;
    margin-bottom: 5px;
    padding-bottom: 5px;
    background: transparent;
  }

  .filter-group:last-child {
    border-bottom: none;
  }

  .filter-header {
    width: 100%;
    padding: 20px 0;
    background: transparent;
    border: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 20px;
    font-weight: 400;
    text-align: left;
    color: #000;
    letter-spacing: -0.01em;
    transition: opacity 0.2s ease;
  }

  .filter-header:hover {
    opacity: 0.7;
  }

  .filter-header svg {
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    opacity: 0.8;
  }

  .filter-header svg line {
    transition: transform 0.4s ease, opacity 0.3s ease;
    transform-origin: center;
  }

  .filter-group.active .filter-header svg line:first-child {
    transform: rotate(90deg);
    opacity: 0;
  }

  .filter-content {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s cubic-bezier(0.165, 0.84, 0.44, 1), opacity 0.4s ease, padding 0.4s ease;
    opacity: 0;
    pointer-events: none;
  }

  .filter-group.active .filter-content {
    max-height: 1000px;
    opacity: 1;
    pointer-events: auto;
    padding-bottom: 30px;
  }

  .filter-list {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .filter-checkbox-label {
    display: flex;
    align-items: center;
    gap: 14px;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    color: #333;
    transition: all 0.2s ease;
  }

  .filter-checkbox-label:hover {
    color: #000;
  }

  .filter-checkbox-label input:disabled + .custom-checkbox + .filter-label-text {
    opacity: 0.4;
    text-decoration: line-through;
  }

  .custom-checkbox {
    width: 20px;
    height: 20px;
    border: 1px solid #dcdcdc;
    border-radius: 4px;
    position: relative;
    transition: all 0.2s cubic-bezier(0.165, 0.84, 0.44, 1);
    flex-shrink: 0;
    background: #fff;
  }

  input[type='checkbox'] {
    display: none;
  }

  input[type='checkbox']:checked + .custom-checkbox {
    background: #000;
    border-color: #000;
  }

  input[type='checkbox']:checked + .custom-checkbox::after {
    content: '';
    position: absolute;
    left: 6px;
    top: 2px;
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
  }

  .product-title-link {
    text-decoration: none;
    color: #000;
  }

  .product-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: 8px;
    color: #000;
    text-decoration: none;
  }

  .product-price {
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: #000;
  }

  /* Split Card UI - No Borders, Grey Info Box */
  .product-card {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  .product-image-wrapper {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
  }

  .product-info-wrapper {
    background: #f4f4f4 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    transition: background 0.3s ease;
  }

  /* Refined Product Card Info Box */
  .product-info-wrapper {
    transition: all 0.3s ease;
  }

  .product-card:hover .product-info-wrapper {
    background: #eaeaea !important;
  }

  .field-pill {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f4f4f4;
    border-radius: 50px;
    padding: 0 15px;
    height: 54px;
    transition: background 0.3s ease;
    gap: 10px;
  }

  .field-pill:focus-within {
    background: #ededed;
  }

  .field-currency {
    font-size: 16px;
    font-weight: 500;
    color: #666;
    flex-shrink: 0;
  }

  .field-input-clean {
    width: 100%;
    max-width: 80px; /* Limit width of the number part */
    border: none;
    background: transparent;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    text-align: left;
    color: #000;
    outline: none;
  }

  .price-range-inputs {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .price-range-sep {
    font-size: 14px;
    font-weight: 700;
    opacity: 0.8;
    color: #444;
    padding: 0 10px;
    font-family: 'Montserrat', sans-serif;
  }

  /* Minimalist Filter Styles */
  .field-pill-minimal {
    flex: 1;
    display: flex;
    align-items: center;
    background: #f4f4f4;
    border-radius: 20px;
    padding: 0 15px;
    height: 48px;
    transition: background 0.2s ease;
  }

  .field-pill-minimal:focus-within {
    background: #ededed;
  }

  .field-currency-minimal {
    font-size: 16px;
    font-weight: 400;
    color: #000;
    margin-right: 25px;
  }

  .field-input-minimal {
    width: 100%;
    border: none;
    background: transparent;
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    font-weight: 500;
    text-align: right;
    color: #000;
    outline: none;
    opacity: 0.6;
  }

  .field-input-minimal::placeholder {
    color: #666;
  }

  .price-range-sep-minimal {
    font-size: 13px;
    font-weight: 700;
    color: #000;
    padding: 0 12px;
    font-family: 'Montserrat', sans-serif;
    text-transform: uppercase;
  }

  .filter-header span:first-child {
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.01em;
  }

  .filter-icon {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .line-vertical {
    transition: transform 0.3s ease, opacity 0.2s ease;
    transform-origin: center;
  }

  .filter-group.active .line-vertical {
    transform: rotate(90deg);
    opacity: 0;
  }

  .filter-checkbox-label {
    display: flex;
    align-items: center;
    gap: 12px;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    margin-bottom: 2px;
  }

  .filter-label-text {
    font-size: 16px;
    font-weight: 500;
    color: #000;
  }

  .custom-checkbox {
    width: 18px;
    height: 18px;
    border: 1px solid #ccc;
    border-radius: 6px;
    position: relative;
    background: #fff;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
  }

  input[type='checkbox']:checked + .custom-checkbox {
    background: #000;
    border-color: #000;
    transform: scale(1.05);
  }

  input[type='checkbox']:checked + .custom-checkbox::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 2px;
    width: 4px;
    height: 8px;
    border: solid white;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
  }

  .filter-checkbox-label:hover .custom-checkbox {
    border-color: #000;
  }

  .filter-list li {
    margin-bottom: 12px;
  }

  /* AJAX Loading State */
  #ProductGridContainer {
    position: relative;
    transition: opacity 0.3s ease;
  }

  .loading-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.7);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 10;
    backdrop-filter: blur(2px);
  }

  #ProductGridContainer.is-loading .loading-overlay {
    display: flex;
  }

  .loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid #eee;
    border-top: 3px solid #000;
    border-radius: 50%;
    animation: spin 1s linear infinite;
  }

  @keyframes spin {
    0% {
      transform: rotate(0deg);
    }
    100% {
      transform: rotate(360deg);
    }
  }

  /* Top Bar */
  .collection-top-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 50px;
    padding-bottom: 0;
  }

  .collection-sorting {
    display: flex;
    align-items: center;
    gap: 0;
  }

  .product-count {
    font-size: 14px;
    font-weight: 500;
    color: #000;
    opacity: 0.6;
    font-family: 'Montserrat', sans-serif;
  }

  .collection-sorting label {
    font-size: 14px;
    font-weight: 600;
    margin-right: 8px;
    font-family: 'Montserrat', sans-serif;
  }

  .sort-wrapper {
    position: relative;
    display: inline-flex;
    align-items: center;
  }

  .sort-select {
    border: none;
    background: transparent;
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    padding: 5px 25px 5px 5px;
    appearance: none;
    color: #000;
    outline: none;
  }

  .sort-chevron {
    position: absolute;
    right: 5px;
    pointer-events: none;
    transition: transform 0.3s ease;
  }

  .sort-select:focus + .sort-chevron {
    transform: rotate(180deg);
  }

  /* View Toggles & List Styles */
  .collection-grid.list-view {
    grid-template-columns: 1fr !important;
  }

  .collection-grid.list-view .product-card-inner {
    flex-direction: row;
    height: 300px;
  }

  .collection-grid.list-view .product-image-wrapper {
    width: 250px;
    height: 300px;
    aspect-ratio: unset;
  }

  .collection-grid.list-view .product-info-wrapper {
    flex: 1;
    padding: 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: #f4f4f4;
    border-radius: 12px;
  }

  .collection-card {
    background: transparent;
    border: none;
    box-shadow: none;
    height: auto;
  }

  .product-card-inner {
    background: transparent;
    border-radius: 0;
    padding: 0;
    overflow: hidden;
    height: 100%;
    display: flex;
    flex-direction: column;
    gap: 15px;
  }

  .product-image-wrapper {
    aspect-ratio: 4 / 5;
    display: flex;

    justify-content: center;
    overflow: hidden;
    position: relative;
    background: #fff;
  }

  .quick-view-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 44px;
    height: 44px;
    background: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
    opacity: 0;
    transform: translateY(-10px);
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    z-index: 10;
  }

  .product-card:hover .quick-view-btn {
    opacity: 1;
    transform: translateY(0);
  }

  .quick-add-wrapper {
    position: absolute;
    bottom: 20px;
    left: 20px;
    right: 20px;
    z-index: 10;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
  }

  .product-card:hover .quick-add-wrapper {
    opacity: 1;
    transform: translateY(0);
  }

  .quick-add-btn {
    width: 100%;
    background: #fff !important;
    color: #000 !important;
    border: none !important;
    font-family: 'Montserrat', sans-serif !important;
    font-size: 14px !important;
    padding: 16px 20px !important;
    border-radius: 50px !important;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12) !important;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    letter-spacing: 0.02em;
  }

  .quick-add-btn:hover {
    background: #000 !important;
    color: #fff !important;
    transform: scale(1.02);
  }

  .quick-add-btn:disabled {
    background: #eee !important;
    color: #999 !important;
    cursor: not-allowed;
    box-shadow: none !important;
  }

  .collection-img {
    width: 100%;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    object-fit: cover;
  }

  .product-card:hover .collection-img {
    transform: scale(1.1);
  }

  .product-price {
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    font-weight: 600;
    opacity: 0.8;
  }

  /* Mobile Filter Bar Styling */
  .mobile-filter-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
    padding: 10px 0;
    border-bottom: 1px solid #eee;
  }

  .filter-toggle-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    border: 1px solid #eee;
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
  }

  .mobile-view-options {
    display: flex;
    gap: 10px;
  }

  .view-option {
    background: #fff;
    border: 1px solid #eee;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #000;
  }

  .view-option.active {
    background: #000;
    color: #fff;
    border-color: #000;
  }

  /* Utility Classes */
  .desktop-only {
    display: block;
  }
  .mobile-only {
    display: none;
  }

  @media (max-width: 991px) {
    .desktop-only {
      display: none !important;
    }
    .mobile-only {
      display: flex !important;
    }

    .collection-grid {
      grid-template-columns: repeat(2, 1fr) !important;
      gap: 15px !important;
    }

    .product-info-wrapper {
      padding: 15px 15px 20px !important;
    }

    .product-title {
      font-size: 15px !important;
      margin-bottom: 6px !important;
      color: #000 !important;
      text-decoration: none !important;
    }

    .product-price {
      font-size: 13px !important;
    }

    .mobile-bag-btn {
      position: absolute;
      bottom: 10px;
      right: 10px;
      width: 36px;
      height: 36px;
      background: #fff;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      border: none;
      box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
      z-index: 5;
    }

    .product-image-wrapper {
      padding: 0 !important;
    }
  }

  /* Final Proportions */
  .product-image-wrapper {
    flex-grow: 1;
  }

  .product-info-wrapper {
    flex-shrink: 0;
  }

  /* Pagination */
  .pagination-wrapper {
    grid-column: 1 / -1;
    margin-bottom: 40px;
    display: flex;
    justify-content: center;
  }

  /* Ensure base.css styles win or are matched here */
  .pagination__item--current {
    transform: scale(1.1);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  }

  @media (max-width: 1200px) {
    .collection-layout {
      gap: 30px;
    }
    .collection-grid {
      grid-template-columns: repeat(3, 1fr);
    }
  }

  @media (max-width: 991px) {
    .collection-layout {
      grid-template-columns: 1fr;
      gap: 30px;
    }

    .collection-sidebar {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: #fff;
      z-index: 10001;
      padding: 40px 25px;
      transform: translateX(-100%);
      transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
      display: block !important;
      visibility: hidden;
      overflow-y: auto;
    }

    body.sidebar-open .collection-sidebar {
      transform: translateX(0);
      visibility: visible;
      box-shadow: 10px 0 30px rgba(0, 0, 0, 0.1);
    }

    .sidebar-mobile-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 30px;
    }

    .close-sidebar {
      font-size: 32px;
      border: none;
      background: none;
      cursor: pointer;
    }

    body.sidebar-open::after {
      content: '';
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: rgba(0, 0, 0, 0.3);
      z-index: 10000;
      backdrop-filter: blur(2px);
    }

    .collection-grid {
      grid-template-columns: repeat(2, 1fr) !important;
      gap: 15px !important;
    }

    .desktop-only {
      display: none !important;
    }
    .mobile-only {
      display: flex !important;
    }
  }

  @media (max-width: 576px) {
    .collection-grid {
      grid-template-columns: 1fr;
    }
  }
/* END_SECTION:collection */

/* START_SECTION:collections (INDEX:5) */
.container.wide-layout {
    max-width: 2000px;
    margin: 0 auto;
    padding: 0 60px;
    padding-top: 100px;
  }

  .collection-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 80px;
    align-items: flex-start;
  }

  .collection-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
  }

  .collection-header-centered {
    text-align: center;
    margin-bottom: 60px;
  }

  .collection-header-centered .main-title {
    font-size: 32px;
    font-weight: 600;
    margin-bottom: 30px;
    letter-spacing: -0.02em;
  }

  .filter-group {
    border-bottom: 1px solid #eee;
    margin-bottom: 5px;
    padding-bottom: 5px;
    background: transparent;
  }

  .filter-header {
    width: 100%;
    padding: 20px 0;
    background: transparent;
    border: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-family: 'Montserrat', sans-serif;
    font-size: 20px;
    font-weight: 700;
    text-align: left;
    color: #000;
  }

  .filter-list {
    list-style: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .filter-label-text {
    font-size: 16px;
    font-weight: 500;
    color: #333;
    transition: all 0.2s ease;
  }

  .filter-label-text:hover {
    color: #000;
    padding-left: 5px;
  }

  .product-card {
    border: none !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  .product-image-wrapper {
    background: #fff;
    border-radius: 20px;
    overflow: hidden;
    aspect-ratio: 1/1;
  }

  .product-info-wrapper {
    background: #f4f4f4 !important;
    border-radius: 12px !important;
    padding: 20px !important;
    margin-top: 15px;
  }

  .collection-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s ease;
  }

  .product-card:hover .collection-img {
    transform: scale(1.1);
  }

  .product-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 5px;
  }

  .product-title-link {
    text-decoration: none;
    color: #000;
  }

  @media (max-width: 991px) {
    .collection-layout {
      grid-template-columns: 1fr;
      gap: 30px;
    }

    .collection-sidebar {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: #fff;
      z-index: 10001;
      padding: 40px 25px;
      transform: translateX(-100%);
      transition: transform 0.4s ease;
      display: block !important;
      visibility: hidden;
      overflow-y: auto;
    }

    body.sidebar-open .collection-sidebar {
      transform: translateX(0);
      visibility: visible;
      box-shadow: 10px 0 30px rgba(0, 0, 0, 0.1);
    }

    body.sidebar-open::after {
      content: '';
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      background: rgba(0, 0, 0, 0.3);
      z-index: 10000;
      backdrop-filter: blur(2px);
    }

    .mobile-only {
      display: flex !important;
    }

    .collection-grid {
      grid-template-columns: repeat(2, 1fr) !important;
    }
  }

  @media (max-width: 576px) {
    .collection-grid {
      grid-template-columns: 1fr !important;
    }
  }
/* END_SECTION:collections */

/* START_SECTION:custom-section (INDEX:10) */
.custom-section {
    position: relative;
    overflow: hidden;
    width: 100%;
  }
  .custom-section__background {
    position: absolute;
    width: 100%;
    height: 100%;
    z-index: -1;
    overflow: hidden;
  }
  .custom-section__background img {
    position: absolute;
    width: 100%;
    height: auto;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .custom-section__content {
    display: grid;
    grid-template-columns: var(--content-grid);
  }
  .custom-section__content > * {
    grid-column: 2;
  }
/* END_SECTION:custom-section */

/* START_SECTION:gift-card-rise (INDEX:14) */
.gc-immersive-container {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 20px;
    position: relative;
    overflow: hidden;
    font-family: 'Montserrat', sans-serif;
  }

  .gc-bg-image-layer,
  .gc-bg-overlay {
    position: absolute;
    inset: 0;
  }

  .gc-bg-image-layer {
    background-size: cover;
    background-position: center;
  }

  .gc-bg-overlay {
    pointer-events: none;
  }

  .gc-content {
    width: 100%;
    max-width: 620px;
    text-align: center;
    position: relative;
    z-index: 2;
    padding: 16px;
    border-radius: 20px;
  }

  .gc-logo-slot {
    position: absolute;
    z-index: 20;
    max-width: min(45vw, 360px);
    line-height: 1;
  }
  .gc-logo-slot.logo-pos-top_left { top: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .gc-logo-slot.logo-pos-top_center { top: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .gc-logo-slot.logo-pos-top_right { top: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }
  .gc-logo-slot.logo-pos-bottom_left { bottom: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .gc-logo-slot.logo-pos-bottom_center { bottom: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .gc-logo-slot.logo-pos-bottom_right { bottom: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }

  .gc-shop-name { font-size: 1.2rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }
  .gc-shop-name-fallback { display: none; }
  .gc-logo-slot.gc-logo-fallback .gc-shop-name-fallback { display: block; }
  .gc-logo-img { width: 100%; height: auto; object-fit: contain; display: block; margin: 0 auto; }

  .gc-hero-image-wrapper { margin-bottom: 40px; display: flex; justify-content: center; perspective: 1000px; }
  .gc-hero-image {
    width: 100%;
    max-width: 300px;
    height: auto;
    filter: drop-shadow(0 20px 40px rgba(0, 0, 0, 0.15));
    transform: rotateY(-10deg) rotateX(5deg);
    transition: transform 0.6s cubic-bezier(0.23, 1, 0.32, 1);
  }
  .gc-hero-image-wrapper:hover .gc-hero-image { transform: rotateY(0deg) rotateX(0deg) scale(1.05); }

  .gc-balance-wrapper { margin-bottom: 36px; }
  .gc-balance { font-size: clamp(2.4rem, 8vw, 5rem); font-weight: 800; line-height: 1; letter-spacing: -0.03em; }
  .gc-status-badge {
    display: inline-block; margin-top: 15px; padding: 8px 20px; background: #f4f4f4; border-radius: 50px;
    font-size: 0.9rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em; color: #000;
  }
  .gc-status-badge--expired { background: #000; color: #fff; }

  .gc-code-section { margin-bottom: 36px; max-width: 460px; margin-left: auto; margin-right: auto; }
  .gc-instructions { margin-bottom: 16px; font-size: 1rem; font-weight: 500; }
  .code-pill-container {
    display: flex; align-items: center; width: 100%; height: 56px; background-color: #f3f4f6;
    border-radius: 9999px; padding: 0 12px 0 24px; transition: all 0.3s ease; position: relative;
  }
  .code-pill-container.copied { background-color: #e8fae8; }
  .code-icon { display: flex; align-items: center; justify-content: center; margin-right: 16px; opacity: 0.5; color: #000; }
  .gc-code-input {
    flex-grow: 1; background: transparent; border: none; outline: none; font-family: 'Montserrat', monospace;
    font-size: 1.05rem; font-weight: 700; color: #000; letter-spacing: 0.08em; text-align: left; width: 100%;
  }
  .copy-circle-btn {
    width: 40px; height: 40px; border-radius: 50%; background: #000; color: #fff; border: none; display: flex;
    align-items: center; justify-content: center; cursor: pointer; flex-shrink: 0; transition: transform 0.2s ease, background-color 0.2s ease;
  }
  .copy-circle-btn:hover { transform: scale(1.08); background: #333; }
  .copy-tooltip {
    position: absolute; top: -45px; right: 0; background: #000; color: #fff; padding: 8px 16px; border-radius: 8px;
    font-size: 0.85rem; font-weight: 700; opacity: 0; transform: translateY(10px); transition: all 0.3s ease; pointer-events: none;
  }
  .code-pill-container.copied .copy-tooltip { opacity: 1; transform: translateY(0); }

  .gc-footer-actions { display: flex; flex-direction: column; gap: 18px; align-items: center; margin-top: 24px; }
  .btn-brutal {
    display: inline-flex; align-items: center; justify-content: center; padding: 16px 34px; background: #000; color: #fff; border-radius: 9999px;
    text-decoration: none; font-weight: 800; font-size: 1.1rem; text-transform: uppercase; letter-spacing: 0.05em; transition: all 0.3s ease;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1); width: 100%; max-width: 340px;
  }
  .btn-text-link { color: inherit; text-decoration: none; font-size: 0.95rem; font-weight: 600; background: none; border: none; cursor: pointer; padding: 10px; }

  @media (max-width: 640px) {
    .gc-logo-slot {
      max-width: min(60vw, 260px);
    }

    .gc-immersive-container { padding: 30px 15px; }
    .gc-hero-image { max-width: 220px; }
    .gc-balance { font-size: clamp(2rem, 11vw, 3rem); }
    .code-pill-container { height: 52px; padding-left: 18px; }
    .gc-code-input { font-size: 0.95rem; }
    .copy-circle-btn { width: 36px; height: 36px; }
    .btn-brutal { padding: 15px 24px; font-size: 0.92rem; max-width: 300px; }
  }
/* END_SECTION:gift-card-rise */

/* START_SECTION:hello-world (INDEX:16) */
.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:kv1-botox-molecular-split (INDEX:17) */
.botox-molecular-split {
    font-family: 'Montserrat', sans-serif;
  }

  .bms-card {
    border: 1px solid;
    overflow: hidden;
  }

  .bms-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: {{ section.settings.min_height_desktop }}px;
    align-items: stretch;
  }

  .bms-left {
    padding: {{ section.settings.left_padding }}px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .bms-sub {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    margin-bottom: 16px;
  }

  .bms-title {
    font-size: 42px;
    line-height: 1.05;
    font-weight: 900;
    margin: 0 0 22px 0;
    text-transform: none;
  }

  .bms-desc {
    font-size: 15px;
    line-height: 1.7;
    opacity: 0.95;
    max-width: 520px;
    margin-bottom: 28px;
  }

  .bms-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 18px 34px;
    border-radius: 999px;
    text-decoration: none;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: none;
  }

  .bms-right {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
  }

  .bms-image {
    width: 100%;
    height: 100%;
    max-height: 520px;
    border-radius: 18px;
  }

  @media (max-width: 991px) {
    .bms-grid {
      grid-template-columns: 1fr;
      min-height: auto;
    }

    .bms-left {
      padding: {{ section.settings.left_padding_mobile }}px;
    }

    .bms-title {
      font-size: 30px;
      margin-bottom: 16px;
    }

    .bms-desc {
      margin-bottom: 22px;
    }

    .bms-right {
      padding: {{ section.settings.right_padding_mobile }}px;
    }

    .bms-image {
      max-height: 420px;
    }
  }
/* END_SECTION:kv1-botox-molecular-split */

/* START_SECTION:kv1-categories-scroll (INDEX:18) */
.categories-flex-wrapper {
    display: flex;
    gap: 60px;
    align-items: flex-start;
  }

  .categories-sidebar {
    flex: 0 0 350px;
    position: sticky;
    top: 150px;
    padding-left: var(--sidebar-padding-left, 0px);
    text-align: var(--sidebar-text-align, left);
  }

  .categories-sidebar .sub-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: block;
    margin-bottom: 20px;
  }

  .categories-sidebar .main-title {
    font-size: 42px;
    margin-bottom: 24px;
    line-height: 1.1;
  }

  .categories-sidebar .description {
    font-size: 14px;
    line-height: 1.6;
    opacity: 0.8;
  }

  .categories-scroll-area {
    flex-grow: 1;
    display: flex;
    gap: var(--cats-card-gap, 24px);
    overflow-x: auto;
    padding-bottom: 30px;
    scrollbar-width: none;
    -ms-overflow-style: none;
    padding-top: 10px;
    justify-content: var(--cards-justify, flex-start);
  }

  .categories-scroll-area::-webkit-scrollbar {
    display: none;
  }

  .category-card {
    min-width: 320px;
    flex: 1 1 320px;
    max-width: 400px;
    position: relative;
    background: #fff;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 24px;
    min-height: var(--card-min-height, 450px);
  }

  .category-link {
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    height: 100%;
  }

  .category-image {
    flex-grow: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 24px;
    overflow: hidden;
  }

  .cat-img {
    width: 100%;
    height: auto;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  }

  .category-card:hover .cat-img {
    transform: scale(1.1);
  }

  .category-info {
    position: relative;
    padding-right: 60px;
  }

  .category-title {
    font-size: 18px;
    margin-bottom: 4px;
  }

  .item-count {
    font-size: 14px;
    opacity: 0.6;
  }

  .arrow-icon {
    position: absolute;
    right: 24px;
    top: 50%;
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    background: var(--color-background-secondary);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.3s ease;
  }

  .category-card:hover .arrow-icon {
    background: var(--color-accent);
    color: #fff;
  }

  @media (max-width: 1024px) {
    .categories-flex-wrapper {
      gap: 35px;
    }

    .category-card {
      min-width: 280px;
    }

    .categories-sidebar {
      padding-left: 0;
      text-align: left;
    }
  }

  /* --- Single card layout controls (para 1 producto/categoría) --- */
  .categories-scroll-area.single-align-left { justify-content: flex-start; }
  .categories-scroll-area.single-align-center { justify-content: center; }
  .categories-scroll-area.single-align-right { justify-content: flex-end; }

  .categories-scroll-area.is-single .category-card {
    /* Eliminamos restricciones para poder ocupar 1/2/3 "slots" como si fueran 3 columnas */
    min-width: 0;
    flex: 0 0 auto;
    max-width: none;
    width: calc(
      ((100% - (var(--cats-card-gap, 24px) * 2)) / 3) * var(--single-card-span, 1)
      + (var(--cats-card-gap, 24px) * (var(--single-card-span, 1) - 1))
    );
  }
/* END_SECTION:kv1-categories-scroll */

/* START_SECTION:kv1-faq-pro (INDEX:20) */
.faq-container {
    max-width: 1400px;
  }

  .faq-section {
    display: grid;
    grid-template-columns: 350px 1fr;
    gap: 80px;
  }

  .faq-header .main-title {
    font-size: 42px;
    margin-bottom: 25px;
    font-weight: 700;
  }

  .faq-header .description {
    font-size: 15px;
    line-height: 1.5;
    opacity: 0.9;
    margin-bottom: 40px;
  }

  .btn-black {
    background: #000 !important;
    color: #fff !important;
    padding: 16px 40px;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 700;
  }

  .faq-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  .faq-item {
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 16px;
    transition: box-shadow 0.3s ease;
  }

  .faq-item:hover {
    box-shadow: 0 4px 15px rgba(0,0,0,0.05);
  }

  .faq-trigger {
    width: 100%;
    padding: 24px 32px;
    background: transparent;
    border: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    cursor: pointer;
    font-family: inherit;
    font-size: 16px;
    font-weight: 600;
    text-align: left;
    color: #000;
  }

  .faq-trigger svg {
    transition: transform 0.3s ease;
    opacity: 0.6;
  }

  .faq-item.active .faq-trigger svg {
    transform: rotate(45deg);
  }

  .faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  }

  .faq-answer p {
    padding: 0 32px 24px;
    font-size: 15px;
    line-height: 1.6;
    opacity: 0.7;
  }


  @media (max-width: 991px) {
    .faq-section {
      grid-template-columns: 1fr;
      gap: 40px;
    }
  }

  .pro-dist-cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
  }

  .pro-card {
    position: relative;
    height: 450px;
    border-radius: 30px;
    overflow: hidden;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: flex-end;
    padding: 60px;
    color: #fff;
  }

  .card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(0deg, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 100%);
  }

  .card-content {
    position: relative;
    z-index: 2;
  }

  .card-title {
    font-size: 28px;
    font-weight: 700;
    margin-bottom: 20px;
    letter-spacing: 0.05em;
  }

  .card-text {
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: 30px;
    opacity: 0.9;
    max-width: 450px;
  }

  .btn-outline {
    display: inline-block;
    padding: 16px 32px;
    border: 1px solid #fff;
    border-radius: 50px;
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: all 0.3s ease;
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(10px);
  }

  .btn-outline:hover {
    background: #fff;
    color: #000;
  }

  @media (max-width: 991px) {
    .faq-section {
      grid-template-columns: 1fr;
      gap: 40px;
    }
    .pro-dist-cards {
      grid-template-columns: 1fr;
    }
    .pro-card {
      padding: 30px;
      height: 400px;
    }
  }
/* END_SECTION:kv1-faq-pro */

/* START_SECTION:kv1-featured-products (INDEX:21) */
.section-header-centered {
    text-align: center;
    margin-bottom: 60px;
  }

  .products-scroll-area {
    display: flex;
    gap: 30px;
    overflow-x: auto;
    padding-bottom: 40px;
    scrollbar-width: none;
  }

  .products-scroll-area::-webkit-scrollbar {
    display: none;
  }

  .featured-products .product-card {
    min-width: 350px;
    flex: 0 0 calc(33.333% - 20px);
    display: flex;
    flex-direction: column;
    padding: 30px;
    background: #fff;
    text-align: center;
  }

  .product-image {
    height: 350px;
    margin-bottom: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .product-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
  }

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

  .product-info {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .product-title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 12px;
  }

  .product-price {
    font-size: 16px;
    font-weight: 600;
    opacity: 0.8;
    margin-bottom: 24px;
  }

  .btn-add-to-cart {
    width: 100%;
    padding: 16px 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
  }

  @media (max-width: 991px) {
    .featured-products .product-card {
      min-width: 300px;
      flex: 0 0 80%;
    }
  }
/* END_SECTION:kv1-featured-products */

/* START_SECTION:kv1-hero-slider (INDEX:22) */
/* --- Slider Styles --- */
  .hero-scroll-wrapper {
    display: flex;
    overflow-x: auto;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -ms-overflow-style: none;
    gap: 20px;
    padding-bottom: 20px;
    cursor: grab;
  }
  .hero-scroll-wrapper.active {
    cursor: grabbing;
    scroll-behavior: auto;
  }
  .hero-scroll-wrapper::-webkit-scrollbar {
    display: none;
  }
  .hero-slide {
    flex: 0 0 calc(100% - 40px);
    scroll-snap-align: center;
    position: relative;
  }
  .hero-image-wrapper {
    height: 650px;
    width: 100%;
    position: relative;
    background: #f4f4f4;
    border-radius: 24px;
    overflow: hidden;
  }
  .hero-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .hero-content {
    position: absolute;
    bottom: 60px;
    left: 0;
    right: 0;
    text-align: center;
    padding: 0 30px;
    z-index: 10;
  }
  .hero-sub {
    font-family: var(--hero-font-family, 'Montserrat', sans-serif);
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.2em;
    display: block;
    margin-bottom: 15px;
  }
  .hero-title {
    font-family: var(--hero-font-family, 'Montserrat', sans-serif);
    font-size: clamp(28px, 4vw, 56px);
    font-weight: 800;
    line-height: 1.1;
    margin: 0 0 30px 0;
    letter-spacing: -0.02em;
  }

  /* --- Dots Styles --- */
  .hero-dots-container {
    padding: 20px 0 10px;
    display: flex;
    justify-content: center;
  }
  .hero-dots {
    display: flex;
    gap: 10px;
    padding: 10px;
    background: rgba(0, 0, 0, 0.03);
    border-radius: 30px;
  }
  .hero-dot {
    width: 12px;
    height: 12px;
    /* Colors injected via inline CSS */
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    padding: 0;
    flex-shrink: 0;
  }
  .hero-dot.active {
    width: 36px;
    border-radius: 12px;
  }

  /* --- Trust Block Clean Layout Styles --- */
  .hero-trust-block {
    margin-top: 60px;
    padding: 40px 0;
    text-align: center;
    font-family: var(--hero-font-family, 'Montserrat', sans-serif);
  }

  .hero-btn {
    font-family: var(--hero-font-family, 'Montserrat', sans-serif);
  }

  /* Titles */
  .trust-main-title {
    font-size: clamp(32px, 5vw, 48px);
    font-weight: 800;
    margin: 0 0 30px 0;
    letter-spacing: -0.02em;
    line-height: 1.1;
  }

  /* Middle Row (Image - Text - Image) */
  .trust-middle-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    margin-bottom: 60px;
  }

  .trust-sub-title {
    font-size: clamp(24px, 4vw, 36px);
    font-weight: 600;
    margin: 0;
    letter-spacing: -0.01em;
    line-height: 1.2;
  }

  /* Clean Images */
  .trust-img-wrapper {
    width: 220px; /* Adjusted size */
    height: auto;
    border-radius: 24px;
    overflow: hidden;
    flex-shrink: 0;
    /* Removed shadows and transforms for clean look */
  }
  .trust-img-wrapper img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
  }

  /* Badges (Pills) */
  .trust-badges {
    display: flex;
    justify-content: center;
    gap: 20px;
    flex-wrap: wrap;
    max-width: 1000px;
    margin: 0 auto;
  }
  .trust-badge {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 24px;
    /* Background, border, text color injected via liquid */
    border-width: 1px;
    border-style: solid;
    border-radius: 50px;
    font-size: 14px;
    font-weight: 500;
    /* Optional very subtle shadow for depth, remove if want perfectly flat */
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.02);
    transition: all 0.3s ease;
  }
  .trust-badge svg {
    width: 20px;
    height: 20px;
    opacity: 0.8; /* Slightly softer icons */
  }

  /* --- Responsive --- */
  @media (max-width: 991px) {
    .hero-image-wrapper {
      height: 550px;
    }
    .trust-middle-row {
      gap: 20px;
    }
    .trust-img-wrapper {
      width: 160px;
    }
  }

  @media (max-width: 768px) {
    .hero-slide {
      flex: 0 0 100%;
      padding: 0 10px;
    }
    .hero-scroll-wrapper {
      gap: 0;
      padding-left: 10px;
    }
    .hero-image-wrapper {
      height: 450px;
      border-radius: 16px;
    }
    .hero-title {
      font-size: 32px;
      margin-bottom: 20px;
    }
    .hero-content {
      bottom: 40px;
      padding: 0 20px;
    }

    /* Trust block mobile */
    .trust-main-title {
      margin-bottom: 20px;
    }
    .trust-middle-row {
      flex-direction: column; /* Stack vertically on mobile */
      gap: 25px;
    }
    /* Order change: Title -> Subtitle -> Images side-by-side below */
    .trust-sub-title {
      order: -1; /* Move subtitle above images */
    }
    /* Container for images to sit side-by-side on mobile */
    .trust-middle-row::after {
      content: '';
      display: flex;
      gap: 15px;
      width: 100%;
      justify-content: center;
    }
    .trust-img-wrapper.left {
      order: 1;
    }
    .trust-img-wrapper.right {
      order: 2;
    }

    .trust-img-wrapper {
      width: 45%; /* Share width on mobile */
      max-width: 160px;
    }

    .trust-badges {
      gap: 12px;
    }
    .trust-badge {
      padding: 10px 16px;
      font-size: 13px;
      width: auto; /* Allow them to wrap naturally */
    }
  }
/* END_SECTION:kv1-hero-slider */

/* START_SECTION:kv1-product-ritual (INDEX:23) */
.ritual-grid {
    padding-top: 200px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
  }

  .ritual-image-side .image-container {
    height: 650px;
    background: #fdfdfd;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .ritual-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    padding: 60px;
  }

  .ritual-header {
    text-align: center;
    margin-bottom: 40px;
  }

  .ritual-header .sub-title {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: block;
    margin-bottom: 15px;
  }

  .ritual-header .main-title {
    font-size: 36px;
    margin-bottom: 20px;
    line-height: 1.1;
    font-weight: 700;
  }

  .ritual-header .description {
    font-size: 14px;
    line-height: 1.6;
    opacity: 0.7;
    max-width: 500px;
    margin: 0 auto;
  }

  .ritual-steps {
    margin-bottom: 40px;
  }

  .ritual-step {
    display: flex;
    align-items: center;
    padding: 20px 0;
    border-bottom: 1px solid var(--color-border);
    gap: 20px;
  }

  .step-num-col {
    flex: 0 0 32px;
  }

  .step-number {
    width: 28px;
    height: 28px;
    border: 1px solid var(--color-border);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 600;
    color: #bbb;
  }

  .step-img-col {
    flex: 0 0 60px;
  }

  .step-product-image {
    width: 60px;
    height: 60px;
  }

  .step-product-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .step-info {
    flex-grow: 1;
  }

  .step-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 2px;
  }

  .step-subtitle {
    font-size: 12px;
    opacity: 0.6;
    font-weight: 600;
  }

  .step-price-col {
    flex: 0 0 auto;
  }

  .step-price {
    font-weight: 700;
    font-size: 15px;
  }

  .ritual-footer {
    display: flex;
    justify-content: center;
  }

  .ritual-btn {
    min-width: 280px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
  }

  @media (max-width: 991px) {
    .ritual-grid {
      grid-template-columns: 1fr;
      gap: 50px;
    }
    .ritual-image-side .image-container {
      height: 400px;
    }
  }
/* END_SECTION:kv1-product-ritual */

/* START_SECTION:kv1-split-banner (INDEX:25) */
.banner-wrapper {
    border-radius: 40px;
    overflow: hidden;
    padding: 0;
  }

  .banner-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    min-height: 600px;
    align-items: center;
  }

  .banner-content {
    padding: 80px;
  }

  .banner-sub {
    font-size: 13px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: block;
    margin-bottom: 20px;
  }

  .banner-title {
    font-size: 48px;
    line-height: 1.1;
    margin-bottom: 30px;
    font-weight: 700;
  }

  .banner-desc {
    font-size: 16px;
    line-height: 1.6;
    opacity: 0.8;
    margin-bottom: 40px;
    max-width: 500px;
  }

  .banner-image {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .banner-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  @media (max-width: 991px) {
    .banner-grid {
      grid-template-columns: 1fr;
    }
    .banner-content {
      padding: 40px;
      text-align: center;
    }
    .banner-desc {
      margin: 0 auto 30px;
    }
    .banner-image {
      height: 400px;
    }
  }
/* END_SECTION:kv1-split-banner */

/* START_SECTION:password (INDEX:27) */
/* Ensure Montserrat is available. Add @import if missing in main theme CSS */
  /* @import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700&display=swap'); */

  /* --- Main Container & Layout --- */
  .password-section-container {
    position: relative;
    min-height: 100vh;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    overflow: hidden;
    font-family: 'Montserrat', sans-serif;
  }

  /* --- Background Layers (Video/Image) --- */
  .bg-video-wrapper,
  .bg-image-layer {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none; /* Ensure clicks go through to content */
  }

  .bg-image-layer {
    background-size: cover;
    background-position: center;
  }

  .bg-video-element {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .bg-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
  }

  /* --- Content Styling --- */
  .content-wrapper {
    position: relative;
    z-index: 10; /* Above backgrounds */
    width: 100%;
    max-width: 600px;
    padding: 20px;
    border-radius: 20px;
  }

  .password-logo-image {
    display: block;
    margin: 0 auto;
    object-fit: contain;
  }

  .password-logo-slot {
    position: absolute;
    z-index: 20;
    max-width: min(45vw, 360px);
    line-height: 1;
  }

  .password-logo-slot.logo-pos-top_left { top: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .password-logo-slot.logo-pos-top_center { top: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .password-logo-slot.logo-pos-top_right { top: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }
  .password-logo-slot.logo-pos-bottom_left { bottom: var(--logo-offset-y, 20px); left: var(--logo-offset-x, 20px); }
  .password-logo-slot.logo-pos-bottom_center { bottom: var(--logo-offset-y, 20px); left: 50%; transform: translateX(-50%); }
  .password-logo-slot.logo-pos-bottom_right { bottom: var(--logo-offset-y, 20px); right: var(--logo-offset-x, 20px); }

  .password-logo-fallback-text {
    display: none;
    font-size: 1.125rem;
    font-weight: 700;
  }

  .password-logo-slot.password-logo-fallback .password-logo-fallback-text {
    display: block;
  }

  /* Utility classes for typography & spacing */
  .text-center {
    text-align: center;
  }
  .mb-8 {
    margin-bottom: 2rem;
  }
  .mb-4 {
    margin-bottom: 1rem;
  }
  .mt-8 {
    margin-top: 2rem;
  }
  .max-w-md {
    max-width: 28rem;
  }
  .mx-auto {
    margin-left: auto;
    margin-right: auto;
  }
  .text-3xl {
    font-size: 1.875rem;
    line-height: 1.2;
  }
  .text-2xl {
    font-size: 1.5rem;
    line-height: 1.3;
  }
  .text-base {
    font-size: 1rem;
    line-height: 1.5;
  }
  .text-sm {
    font-size: 0.875rem;
  }
  .font-bold {
    font-weight: 700;
  }
  .font-semibold {
    font-weight: 600;
  }
  .tracking-tight {
    letter-spacing: -0.025em;
  }
  .opacity-80 {
    opacity: 0.8;
  }
  .opacity-60 {
    opacity: 0.6;
  }

  /* --- Pill Input Field Styling --- */
  .input-pill-wrapper {
    display: flex;
    align-items: center;
    width: 100%;
    height: 56px; /* Fixed height for pill look */
    border-radius: 9999px; /* Full rounded corners */
    padding: 0 8px 0 20px; /* Padding for internal elements */
    transition: all 0.3s ease;
    /* Optional shadow for better separation if bg is light */
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  }

  .input-pill-wrapper:focus-within {
    box-shadow: 0 4px 25px rgba(0, 0, 0, 0.08);
    transform: translateY(-1px);
  }

  /* The icon on the left */
  .input-icon-container {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 12px;
    flex-shrink: 0;
  }

  /* The actual input field - transparent */
  .transparent-input {
    flex-grow: 1;
    background: transparent;
    border: none;
    outline: none;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 500;
    height: 100%;
    color: inherit; /* Inherits from wrapper */
  }

  .transparent-input::placeholder {
    opacity: 0.6;
    color: inherit;
  }

  /* The submit button on the right */
  .submit-circle-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }

  .submit-circle-btn:hover {
    transform: scale(1.1);
  }

  .form-error {
    animation: shake 0.4s ease-in-out;
  }
  @keyframes shake {
    0%,
    100% {
      transform: translateX(0);
    }
    20%,
    60% {
      transform: translateX(-5px);
    }
    40%,
    80% {
      transform: translateX(5px);
    }
  }

  /* Footer Links */
  .footer-link-wrapper p {
    margin: 0;
  }
  .footer-link-wrapper a {
    color: inherit;
    text-decoration: underline;
    text-underline-offset: 3px;
    font-weight: 600;
  }
  .footer-link-wrapper a:hover {
    opacity: 1;
  }

  /* Responsive fixes */
  @media (max-width: 640px) {
    .password-logo-slot {
      max-width: min(60vw, 260px);
    }

    .text-3xl {
      font-size: 1.5rem;
    }
    .text-2xl {
      font-size: 1.25rem;
    }
    .input-pill-wrapper {
      height: 50px;
    }
    .submit-circle-btn {
      width: 36px;
      height: 36px;
    }
  }
/* END_SECTION:password */

/* START_SECTION:search (INDEX:29) */
.search-results {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  }
  .search-results .prev,
  .search-results .page,
  .search-results .next {
    grid-column: 1 / -1;
  }
/* END_SECTION:search */

/* CSS from block stylesheet tags */
/* START_BLOCK:group (INDEX:30) */
.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:31) */
.text {
    text-align: var(--text-align);
  }
  .text--title {
    font-size: 2rem;
    font-weight: 700;
  }
  .text--subtitle {
    font-size: 1.5rem;
  }
/* END_BLOCK:text */

/* CSS from snippet stylesheet tags */
/* START_SNIPPET:cart-drawer (INDEX:32) */
.cart-drawer {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 9999;
    visibility: hidden;
    transition: visibility 0.4s ease;
  }

  body.cart-drawer-open {
    overflow: hidden;
  }

  body.cart-drawer-open .cart-drawer {
    visibility: visible;
  }

  .cart-drawer-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(4px);
    opacity: 0;
    transition: opacity 0.4s ease;
  }

  body.cart-drawer-open .cart-drawer-overlay {
    opacity: 1;
  }

  .cart-drawer-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 450px;
    height: 100%;
    background: #fff;
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    padding: 0;
  }

  @media (max-width: 576px) {
    .cart-drawer-content {
      width: 100%;
    }
  }

  body.cart-drawer-open .cart-drawer-content {
    transform: translateX(0);
  }

  .cart-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 30px;
    padding: 40px 40px 0 40px;
  }

  .cart-drawer-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 24px;
    font-weight: 700;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 12px;
  }

  .cart-drawer-header-count {
    background: #000;
    color: #fff;
    font-size: 14px;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .cart-drawer-close {
    background: none;
    border: 1px solid #eee;
    font-size: 28px;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
  }

  .cart-drawer-close:hover {
    background: #f4f4f4;
    transform: rotate(90deg);
  }

  .cart-drawer-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    margin-bottom: 30px;
    padding: 0 40px; /* Padding for content, leaving scrollbar at edge */
  }

  /* Scrollbar Styling */
  .cart-drawer-body::-webkit-scrollbar {
    width: 3px;
  }
  .cart-drawer-body::-webkit-scrollbar-track {
    background: transparent;
  }
  .cart-drawer-body::-webkit-scrollbar-thumb {
    background: #e0e0e0;
    border-radius: 10px;
  }
  .cart-drawer-body::-webkit-scrollbar-thumb:hover {
    background: #ccc;
  }

  .cart-item {
    display: flex;
    gap: 20px;
    padding-bottom: 25px;
    margin-bottom: 25px;
    border-bottom: 1px solid #eee;
  }

  .cart-item-image {
    width: 100px;
    height: 100px;
    border-radius: 12px;
    overflow: hidden;
    background: #f9f9f9;
    flex-shrink: 0;
  }

  .cart-item-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .cart-item-details {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  .cart-item-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 4px;
  }

  .cart-item-title {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    line-height: 1.3;
    max-width: 180px;
  }

  .cart-item-remove {
    background: none;
    border: none;
    font-size: 20px;
    color: #999;
    cursor: pointer;
    transition: color 0.3s ease;
  }

  .cart-item-remove:hover {
    color: #000;
  }

  .cart-item-variant {
    font-size: 13px;
    color: #666;
    margin: 0 0 15px 0;
  }

  .cart-item-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: auto;
  }

  .quantity-selector {
    display: flex;
    align-items: center;
    background: #f4f4f4;
    border-radius: 50px;
    padding: 5px;
  }

  .qty-btn {
    background: none;
    border: none;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 18px;
    transition: opacity 0.3s ease;
  }

  .qty-btn:disabled {
    opacity: 0.3;
    cursor: not-allowed;
  }

  .qty-input {
    width: 30px;
    border: none;
    background: none;
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 700;
    appearance: none;
    -moz-appearance: textfield;
  }

  .qty-input::-webkit-outer-spin-button,
  .qty-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
  }

  .cart-item-price {
    font-size: 15px;
    font-weight: 700;
    color: #000;
  }

  .cart-item-price-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    line-height: 1.1;
  }

  .cart-item-price-compare {
    font-size: 12px;
    color: #8a8a8a;
    font-weight: 600;
  }

  .cart-item-bundle-badge {
    margin: -8px 0 0 0;
    font-size: 12px;
    color: #666;
    animation: fadeInUpSoft 0.18s ease both;
  }

  .cart-item-bundle-badge.is-entering {
    animation: fadeInUpSoft 0.18s ease both;
  }

  .cart-item-bundle-badge.is-leaving {
    animation: fadeOutDownSoft 0.16s ease both;
  }

  @keyframes fadeInUpSoft {
    from { opacity: 0; transform: translateY(4px); }
    to { opacity: 1; transform: translateY(0); }
  }

  @keyframes fadeOutDownSoft {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(4px); }
  }

  .cart-drawer-footer {
    border-top: 1px solid #eee;
    padding: 30px 40px 40px 40px; /* Specific padding for footer */
  }

  .cart-subtotal {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
  }

  .subtotal-label {
    font-size: 20px;
    font-weight: 700;
  }

  .subtotal-value {
    font-size: 24px;
    font-weight: 800;
  }

  .cart-subtotal-price-wrap {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    line-height: 1.1;
  }

  .subtotal-compare {
    font-size: 12px;
    color: #8a8a8a;
    font-weight: 600;
  }

  .subtotal-compare.is-entering {
    animation: fadeInUpSoft 0.18s ease both;
  }

  .subtotal-compare.is-leaving {
    animation: fadeOutDownSoft 0.16s ease both;
  }

  .cart-tax-info {
    font-size: 13px;
    color: #666;
    line-height: 1.5;
    margin-bottom: 30px;
  }

  .btn-checkout {
    width: 100%;
    background: #000;
    color: #fff;
    border: none;
    border-radius: 50px;
    padding: 20px;
    font-family: 'Montserrat', sans-serif;
    font-size: 16px;
    font-weight: 700;
    text-transform: capitalize;
    cursor: pointer;
    transition: transform 0.3s ease, background 0.3s ease;
  }

  .btn-checkout:hover {
    background: #222;
    transform: scale(1.02);
  }

  .cart-empty-message {
    text-align: center;
    padding: 60px 20px;
  }

  .cart-empty-message p {
    font-size: 18px;
    color: #666;
    margin-bottom: 30px;
  }

  /* Micro-Animations */
  @keyframes countInUp {
    from {
      opacity: 0;
      transform: translateY(15px);
      filter: blur(2px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
      filter: blur(0);
    }
  }
  @keyframes countInDown {
    from {
      opacity: 0;
      transform: translateY(-15px);
      filter: blur(2px);
    }
    to {
      opacity: 1;
      transform: translateY(0);
      filter: blur(0);
    }
  }

  .count-animate-up {
    animation: countInUp 0.15s cubic-bezier(0.23, 1, 0.32, 1) forwards;
  }
  .count-animate-down {
    animation: countInDown 0.15s cubic-bezier(0.23, 1, 0.32, 1) forwards;
  }

  .cart-item.removing {
    animation: slideOutRight 0.5s cubic-bezier(0.165, 0.84, 0.44, 1) forwards;
    pointer-events: none;
  }

  @keyframes slideOutRight {
    to {
      transform: translateX(100%);
      opacity: 0;
      margin-bottom: -125px; /* Collapse height roughly */
    }
  }

  /* Price and Qty Wrapper for Animation */
  .animate-number-wrapper {
    display: inline-block;
    position: relative;
    overflow: hidden;
    vertical-align: middle;
  }

  .quantity-selector,
  .cart-item-price,
  .subtotal-value,
  .cart-drawer-header-count {
    transition: all 0.3s ease;
  }
/* END_SNIPPET:cart-drawer */

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

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

/* START_SNIPPET:quick-view (INDEX:40) */
.quick-view {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 20000;
    visibility: hidden;
  }

  body.quick-view-open {
    overflow: hidden;
  }

  body.quick-view-open .quick-view {
    visibility: visible;
  }

  .quick-view-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(8px);
    opacity: 0;
    transition: opacity 0.4s ease;
  }

  body.quick-view-open .quick-view-overlay {
    opacity: 1;
  }

  .quick-view-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 520px;
    height: 100%;
    background: #fff;
    transform: translateX(100%);
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    box-shadow: -20px 0 50px rgba(0,0,0,0.05);
    z-index: 2;
  }

  @media (max-width: 600px) {
    .quick-view-content {
      width: 100%;
    }
  }

  body.quick-view-open .quick-view-content {
    transform: translateX(0);
  }

  .quick-view-close {
    position: absolute;
    top: 25px;
    right: 25px;
    background: #fff;
    border: 1px solid #eee;
    width: 44px;
    height: 44px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    transition: all 0.3s ease;
    box-shadow: 0 4px 10px rgba(0,0,0,0.05);
  }

  .quick-view-close:hover {
    transform: scale(1.1);
    border-color: #000;
  }

  .quick-view-body {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    position: relative;
    scrollbar-width: none;
  }

  .quick-view-body::-webkit-scrollbar {
    display: none;
  }

  .qv-product {
    padding: 20px 20px 100px 20px; /* Space for sticky footer */
  }

  .qv-media-gallery {
    margin-bottom: 25px;
    position: relative;
  }

  .qv-main-image {
    width: 100%;
    aspect-ratio: 1;
    border-radius: 24px;
    overflow: hidden;
    background: #f9f9f9;
  }

  .qv-main-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 20px;
    transition: opacity 0.3s ease, transform 0.3s ease;
  }

  .qv-fade-out {
    opacity: 0;
    transform: scale(0.95);
  }

  .qv-fade-in {
    opacity: 1;
    transform: scale(1);
    animation: qvFadeIn 0.4s ease forwards;
  }

  @keyframes qvFadeIn {
    from { opacity: 0; transform: scale(0.98); }
    to { opacity: 1; transform: scale(1); }
  }

  .qv-media-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 15px;
    margin-top: 15px;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    font-size: 14px;
  }

  .qv-nav-btn {
    background: none;
    border: none;
    cursor: pointer;
    padding: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0.6;
    transition: opacity 0.2s;
  }

  .qv-nav-btn:hover {
    opacity: 1;
  }

  .qv-info {
    padding: 0 10px;
  }

  .qv-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 32px;
    font-weight: 700;
    margin: 0 0 15px 0;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: #000;
  }

  .qv-price {
    font-size: 28px;
    font-weight: 800;
    color: #000;
  }

  .qv-price-container {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 5px;
  }

  .qv-total-price {
    font-size: 16px;
    font-weight: 700;
    color: #666;
    background: #f8f8f8;
    padding: 4px 12px;
    border-radius: 100px;
  }

  .qv-tax-note {
    display: none !important; /* Force hidden as requested */
  }

  .qv-stock-status {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 25px;
    font-weight: 700;
    font-size: 14px;
    padding: 6px 14px;
    background: rgba(16, 185, 129, 0.08);
    border-radius: 50px;
    width: fit-content;
  }

  .qv-stock-status.in-stock {
    color: #10b981;
    background: rgba(16, 185, 129, 0.08);
  }

  .qv-stock-status.out-of-stock {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.08);
  }

  .qv-stock-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
    box-shadow: 0 0 8px currentColor;
  }

  .qv-description {
    font-size: 16px;
    line-height: 1.6;
    color: #333;
    margin-bottom: 35px;
  }

  .qv-description b, .qv-description strong {
    font-weight: 800;
    color: #000;
  }

  .qv-actions {
    display: flex;
    gap: 12px;
    margin-bottom: 40px;
  }

  .qv-qty-selector {
    display: flex;
    align-items: center;
    background: #f6f6f6;
    border-radius: 50px;
    padding: 4px;
    min-width: 140px;
  }

  .qv-qty-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s;
  }

  .qv-qty-btn:hover {
    background: #eee;
  }

  .qv-qty-input {
    flex: 1;
    border: none;
    background: transparent;
    text-align: center;
    font-weight: 700;
    font-size: 16px;
    width: 30px;
    transition: transform 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }

  .qv-animate-pop {
    animation: qvPop 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  }

  @keyframes qvPop {
    0% { transform: scale(1); }
    50% { transform: scale(1.3); }
    100% { transform: scale(1); }
  }

  .qv-add-btn {
    flex: 2;
    background: #000;
    color: #fff;
    border: none;
    border-radius: 60px;
    padding: 16px;
    font-weight: 700;
    font-size: 15px;
    cursor: pointer;
    transition: all 0.3s;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
  }

  .qv-add-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(0,0,0,0.1);
  }

  /* Sticky Footer CTA */
  .qv-sticky-footer {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    background: #fff;
    border-top: 1px solid #eee;
    padding: 0;
    z-index: 10;
  }

  .qv-details-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 24px 30px;
    text-decoration: none;
    color: #000;
    font-weight: 700;
    font-size: 16px;
    transition: background 0.3s;
  }

  .qv-details-btn:hover {
    background: #f9f9f9;
  }

  /* Error State Styles */
  .qv-error-container {
    padding: 100px 40px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }

  .qv-error-icon {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 2px solid #eee;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 30px;
    color: #ccc;
    font-family: serif;
    font-size: 32px;
    font-style: italic;
  }

  .qv-error-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 24px;
    font-weight: 700;
    color: #000;
    margin-bottom: 15px;
  }

  .qv-error-text {
    font-size: 16px;
    line-height: 1.5;
    color: #666;
    margin-bottom: 40px;
    max-width: 300px;
  }

  .qv-close-pill {
    background: #000;
    color: #fff;
    border: none;
    border-radius: 50px;
    padding: 18px 50px;
    font-weight: 700;
    font-size: 16px;
    cursor: pointer;
    transition: transform 0.3s;
  }

  .qv-close-pill:hover {
    transform: scale(1.05);
  }
/* END_SNIPPET:quick-view */

/* START_SNIPPET:search-drawer (INDEX:41) */
.search-drawer {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 10000;
    visibility: hidden;
    transition: visibility 0.4s ease;
  }

  body.search-drawer-open {
    overflow: hidden;
  }

  body.search-drawer-open .search-drawer {
    visibility: visible;
  }

  .search-drawer-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(2px);
    opacity: 0;
    transition: opacity 0.4s ease;
  }

  body.search-drawer-open .search-drawer-overlay {
    opacity: 1;
  }

  .search-drawer-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 480px;
    height: 100%;
    background: #fff;
    transform: translateX(100%);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    padding: 20px;
  }

  @media (max-width: 576px) {
    .search-drawer-content {
      width: 100%;
    }
  }

  body.search-drawer-open .search-drawer-content {
    transform: translateX(0);
  }

  .search-drawer-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 20px 30px 20px;
  }

  .search-drawer-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 32px;
    font-weight: 600;
    margin: 0;
    letter-spacing: -0.02em;
  }

  .search-drawer-close {
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    line-height: 1;
    opacity: 0.6;
    transition: opacity 0.3s;
  }

  .search-drawer-close:hover {
    opacity: 1;
  }

  .search-drawer-body {
    flex: 1;
    overflow-y: auto;
    padding: 0 20px 40px 20px;
  }

  .search-input-wrapper {
    position: relative;
    margin-bottom: 40px;
    display: flex;
    align-items: center;
    background: #f6f6f6;
    border-radius: 50px;
    padding: 15px 25px;
    transition: background 0.3s;
  }

  .search-input-wrapper:focus-within {
    background: #f0f0f0;
  }

  .search-icon {
    width: 20px;
    height: 20px;
    color: #000;
    margin-right: 15px;
  }

  .search-input {
    flex: 1;
    border: none;
    outline: none;
    font-family: 'Montserrat', sans-serif;
    font-size: 20px;
    background: transparent;
    color: #000;
    font-weight: 500;
  }

  .search-clear {
    background: none;
    border: none;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #666;
    cursor: pointer;
    margin-left: 10px;
  }

  /* Results Styling */
  .search-section {
    margin-bottom: 40px;
  }

  .search-section-title {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 25px;
    color: #000;
  }

  .search-item {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-bottom: 20px;
    text-decoration: none;
    color: inherit;
    transition: transform 0.2s ease;
  }

  .search-item:hover {
    transform: translateX(5px);
  }

  .search-item-image {
    width: 80px;
    height: 80px;
    border-radius: 12px;
    overflow: hidden;
    background: #f9f9f9;
    flex-shrink: 0;
  }

  .search-item-image img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .search-item-info {
    flex: 1;
  }

  .search-item-name {
    font-size: 18px;
    font-weight: 600;
    margin: 0;
    line-height: 1.3;
    color: #000;
  }

  .search-list-item {
    display: block;
    font-size: 15px;
    font-weight: 500;
    margin-bottom: 12px;
    text-decoration: none;
    color: #000;
    opacity: 0.8;
  }

  .search-list-item:hover {
    opacity: 1;
    text-decoration: underline;
  }

  .search-row-links {
    display: flex;
    flex-wrap: wrap;
    gap: 15px 25px;
  }

  .search-row-links .search-list-item {
    margin-bottom: 0;
  }

  .search-footer {
    border-top: 1px solid #eee;
    margin-top: 10px;
    padding-top: 10px;
  }

  .search-all-link {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    color: #000;
    padding: 15px 0;
    transition: all 0.2s ease;
  }

  .search-all-link:hover {
    color: #333;
    transform: translateX(5px);
  }

  hr.search-divider {
    border: 0;
    border-top: 1px solid #eee;
    margin: 25px 0;
  }
/* END_SNIPPET:search-drawer */