    /* ---------- Category description (unchanged) ---------- */
    .category-description { margin-top:20px; line-height:1.6; }
    .category-description ul { list-style:disc; margin-left:20px; margin-bottom:10px; }
    .category-description p { margin-bottom:1em; }
    .search-header { display:flex; flex-direction:column; align-items:flex-start; gap:2px; }
    .search-header h1 { margin-bottom:2px !important; }
    .search-header nav[aria-label="breadcrumb"] { margin-bottom:2px !important; }
    .search-header nav[aria-label="breadcrumb"] ol li,
    .search-header nav[aria-label="breadcrumb"] ol li a,
    .search-header nav[aria-label="breadcrumb"] ol li span { font-size:0.7rem; }
    @media (max-width:576px){
      .sort-form{ width:100%; margin-left:0 !important; display:flex; justify-content:space-between; margin-top:2px; }
      .sort-label{ font-size:0.9rem; margin-right:6px; }
      .sort-select{ flex:0 0 auto; }
    }
    #sentinel{height:1px;}

    /* =======================================================
       FANCY SIZE POPUP – with fixes for close button + mobile CTA
       ======================================================= */
    :root{
      --ks-green:#1b8f1a;
      --ks-green-dark:#157213;
      --ks-amber:#ff9800;
      --ks-border:#ececec;
      --ks-muted:#667085;
    }

    .size-overlay{
      position:fixed; inset:0;
      background:rgba(0,0,0,.42);
      backdrop-filter:saturate(120%) blur(2px);
      display:none; align-items:center; justify-content:center;
      padding:16px; z-index:1000;
    }
    .size-overlay.show{ display:flex; }

    .size-popup{
      position:relative;                 /* Keep absolute children (close) inside */
      width:min(700px,94vw);
      max-height:86vh;
      background:#fff; border-radius:16px;
      box-shadow:0 10px 30px rgba(0,0,0,.2);
      overflow:hidden; display:flex; flex-direction:column;
      animation:popIn .18s ease-out;
    }
    @keyframes popIn{ from{transform:scale(.96);opacity:0;} to{transform:scale(1);opacity:1;} }

    /* Close button – ensure always visible above sticky header */
    .close-btn{
      position:absolute; right:10px; top:10px;
      width:36px; height:36px; border:1px solid #eee; border-radius:999px;
      background:#fff; color:#333; cursor:pointer;
      display:flex; align-items:center; justify-content:center;
      z-index:5;                              /* Higher than .popup-header (z-index:2) */
      box-shadow:0 2px 8px rgba(0,0,0,.08);
    }
    .close-btn:hover{ background:#f7f7f7; }

    /* Header */
    .popup-header{
      position:sticky; top:0; z-index:2;
      display:grid; grid-template-columns:64px 1fr max-content; /* right fits content */
      gap:12px; align-items:center;
      padding:16px 18px;
      padding-right:64px;                    /* Reserve space so close button never overlaps */
      border-bottom:1px solid var(--ks-border); background:#fff;
    }
    .popup-header img#popupImage{
      width:64px; height:64px; object-fit:cover; border-radius:10px; border:1px solid var(--ks-border);
    }
    .popup-product-title{ font-weight:600; font-size:1.02rem; line-height:1.3; }

    .go-cart-btn-header{
      height:36px; padding:0 14px; border:none; border-radius:10px; cursor:pointer;
      background:var(--ks-green); color:#fff; font-weight:600;
      white-space:nowrap;                    /* Keep in one line */
    }
    .go-cart-btn-header:hover{ background:var(--ks-green-dark); }

    .size-popup h4{
      margin:0; padding:12px 18px; font-size:.95rem; color:#111;
      border-bottom:1px solid var(--ks-border);
    }

    #variantList{ list-style:none; margin:0; padding:0; overflow:auto; flex:1; background:#fff; }

    #variantList li{
      display:grid; grid-template-columns:1fr auto;
      gap:10px; align-items:center;
      padding:14px 18px; border-bottom:1px solid #f3f4f6;
    }

    .variant-top-line{ display:flex; align-items:center; gap:8px; min-width:0; }
    .variant-name{ font-weight:600; color:#111; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

    .size-price-row{ display:flex; align-items:center; gap:12px; }
    .variant-price{ font-weight:700; font-size:1rem; color:#111; }
    .variant-price s{ margin-left:6px; color:#9aa3af; font-weight:500; font-size:.95rem; }

    .variant-discount{
      font-size:.78rem; font-weight:700;
      padding:4px 8px; border-radius:999px; background:#fff7e6; color:#a35500;
      border:1px solid #ffe0b2;
    }

    .cart-btn-slot{ display:flex; align-items:center; }
    .add-to-cart-btn{
      height:36px; padding:0 14px; border:none; border-radius:10px; cursor:pointer;
      background:var(--ks-green); color:#fff; font-weight:700; box-shadow:0 2px 0 rgba(0,0,0,.06);
    }
    .add-to-cart-btn:hover{ background:var(--ks-green-dark); }
    .add-to-cart-btn.sold-out-btn{ background:#e5e7eb; color:#6b7280; cursor:not-allowed; box-shadow:none; }

    .qty-container{ display:flex; align-items:center; gap:8px; background:#f6f8fa; border:1px solid #e5e7eb; border-radius:10px; height:36px; padding:0 8px; }
    .qty-btn, .trash-btn{ width:28px; height:28px; border:none; border-radius:8px; cursor:pointer; display:flex; align-items:center; justify-content:center; background:#fff; }
    .qty-btn:hover, .trash-btn:hover{ background:#f0f0f0; }
    .qty-label{ min-width:18px; text-align:center; font-weight:700; }

    /* -------- Mobile-only refinements -------- */
    @media (max-width:480px){
      .size-popup{ width:96vw; }
      .popup-header{
        grid-template-columns:56px 1fr max-content;
        gap:10px;
        padding:12px 14px;
        padding-right:58px;                 /* still keep gap for close button */
      }
      .go-cart-btn-header{
        font-size:.85rem;                   /* smaller text to avoid wrap */
        height:34px;
        padding:0 12px;
        white-space:nowrap;                 /* never break */
      }
      #variantList li{ grid-template-columns:1fr; align-items:flex-start; }
      .size-price-row{ justify-content:space-between; width:100%; }
      .close-btn{ right:8px; top:8px; width:34px; height:34px; } /* fit tight on mobile */
    }
    
    
     :root { --ks-filter-footer-h: 72px; }

    /* ---------- HEADER AREA ---------- */
    .search-header{
      display:grid;
      grid-template-columns: 1fr auto auto;
      align-items:center;
      /* Tighter vertical rhythm: was 12px -> 6px */
      gap:6px; /* reduces the space between breadcrumb and the controls row */
    }
    .search-header h1{ grid-column:1 / -1; margin:0; }
    /* Remove any default spacing on the breadcrumb block */
    .search-header nav{ grid-column:1 / -1; margin:0; padding:0; }

    /* Controls row container */
 
 /* Controls row: keep layout; no extra top margin */
.ks-controls-row{
  grid-column: 1 / -1;                 /* span full width of header grid */
  display:grid;
  align-items:center;
  gap:12px;
  background:#fff;
  margin-top:0;                         /* avoid any extra gap */
}

/* DESKTOP: prevent the Filter button from stretching full width */
@media (min-width: 769px){
  .ks-controls-row{
    /* Left track fits to content (Filter), right track holds Sort form */
    grid-template-columns: max-content auto;
  }
  .ks-controls-row > .ks-filter-toggle-btn{
    justify-self: start;                /* stop grid stretch on desktop */
    width: auto;                        /* natural width only */
  }
}

/* MOBILE: keep the sticky behaviour exactly as before */
@media(max-width:768px){
  .ks-controls-row{
    position: -webkit-sticky;           /* iOS Safari */
    position: sticky;
    top: calc(var(--ks-sticky-top, 56px) + env(safe-area-inset-top));
    z-index: 600;                        /* overlays are 3500/4000 */
    padding:4px 12px;                    /* compact padding */
    box-shadow: 0 2px 10px rgba(0,0,0,.08);
    box-sizing: border-box;

    /* On small screens let both items sit side-by-side naturally */
    grid-template-columns: auto auto;
  }
  /* Fixed fallback when sticky is blocked by an ancestor */
  .ks-controls-row.is-fixed{
    position: fixed !important;
    left: var(--ks-fixed-left, 0);
    width: var(--ks-fixed-width, 100vw);
    right: auto;
    top: calc(var(--ks-sticky-top, 56px) + env(safe-area-inset-top));
    z-index: 600;
    padding:4px 12px;
    box-sizing: border-box;
  }
  .ks-sticky-ph{ display:block; height:0; } /* prevents layout jump */
}


    /* Keep Sort aligned to the right side */
    .sort-form{ justify-self:end; margin-left:0 !important; }
    .sort-form .sort-select{ height:36px; padding:8px 10px; border-radius:8px; border:1px solid #ddd; }

    /* Filter button height matches the select for visual alignment */
    .ks-filter-toggle-btn{
      height:36px;
      display:inline-flex;align-items:center;gap:8px;
      padding:8px 12px;border:1px solid #ddd;border-radius:8px;background:#fff;
      cursor:pointer;font-weight:600;margin-left:12px
    }
    .ks-filter-toggle-btn i{font-size:14px}

    /* Filter drawer + backdrop (unchanged) */
    .ks-filter-panel-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;z-index:3500}
    .ks-filter-panel-backdrop.show{display:block}

    /* LEFT drawer */
    .ks-filter-panel{
      position:fixed;top:0;left:-380px;
      height:100vh; height:100dvh;
      width:360px;background:#fff;
      box-shadow:8px 0 24px rgba(0,0,0,.15);
      transition:left .25s ease;z-index:4000;
      display:flex;flex-direction:column
    }
    .ks-filter-panel.show{left:0}

    .ks-filter-head{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #eee;flex-shrink:0}
    .ks-filter-title{font-weight:700;font-size:16px}
    .ks-filter-close{background:none;border:none;font-size:18px;cursor:pointer}

    .ks-filter-body{
      padding:14px 16px;overflow:auto;flex:1;
      padding-bottom: calc(var(--ks-filter-footer-h) + 20px + env(safe-area-inset-bottom));
    }

    .ks-filter-group{margin-bottom:18px}
    .ks-filter-group h4{font-size:14px;margin:0 0 10px 0;font-weight:700;color:#222}
    .ks-checklist{display:flex;flex-direction:column;gap:8px;max-height:220px;overflow:auto}
    .ks-price-row{display:flex;gap:10px}
    .ks-price-row input{width:100%;padding:8px 10px;border:1px solid #ddd;border-radius:6px}

    .ks-filter-footer{
      position:sticky;bottom:0;left:0;right:0;
      border-top:1px solid #eee;
      padding:12px 16px calc(12px + env(safe-area-inset-bottom));
      background:#fff;display:flex;gap:10px;flex-shrink:0;
      box-shadow:0 -8px 16px rgba(0,0,0,.08);
      min-height:var(--ks-filter-footer-h);
      z-index:1;
    }

    .ks-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:8px;cursor:pointer;text-decoration:none;border:1px solid transparent;font-weight:600;width:50%}
    .ks-btn-primary{background:#16a34a;color:#fff}.ks-btn-primary:hover{background:#128a3e}
    .ks-btn-ghost{background:#fff;color:#333;border-color:#ddd}.ks-btn-ghost:hover{background:#f8f8f8}

    /* Mobile: drawer width */
    @media(max-width:768px){
      .ks-filter-panel{width:92vw;left:-92vw}
    }